diff options
author | Andrew Lewis <nerf@judo.za.org> | 2020-09-07 15:14:22 +0200 |
---|---|---|
committer | Andrew Lewis <nerf@judo.za.org> | 2020-09-07 15:14:22 +0200 |
commit | c07cb6a8c4f45d0cf35baacf539d5c78145fe1de (patch) | |
tree | b67b987e045203d927aa87c1982dc43ea6fda5e6 /test/functional/lib | |
parent | 27ad207da620685499aa04c8e9c7d4e4eafa11dc (diff) | |
download | rspamd-c07cb6a8c4f45d0cf35baacf539d5c78145fe1de.tar.gz rspamd-c07cb6a8c4f45d0cf35baacf539d5c78145fe1de.zip |
[Test] Use HTTP & simplified test style
Diffstat (limited to 'test/functional/lib')
-rw-r--r-- | test/functional/lib/rspamd.py | 14 | ||||
-rw-r--r-- | test/functional/lib/rspamd.robot | 63 |
2 files changed, 75 insertions, 2 deletions
diff --git a/test/functional/lib/rspamd.py b/test/functional/lib/rspamd.py index b8bc6ac03..ce05bdc8a 100644 --- a/test/functional/lib/rspamd.py +++ b/test/functional/lib/rspamd.py @@ -139,8 +139,18 @@ def rspamc(addr, port, filename): r = s.recv(2048) return r.decode('utf-8') -def scan_file(addr, port, filename): - return str(urlopen("http://%s:%s/symbols?file=%s" % (addr, port, filename)).read()) +def Scan_File(filename, **headers): + addr = BuiltIn().get_variable_value("${LOCAL_ADDR}") + port = BuiltIn().get_variable_value("${PORT_NORMAL}") + headers["Queue-Id"] = BuiltIn().get_variable_value("${TEST_NAME}") + c = http.client.HTTPConnection("%s:%s" % (addr, port)) + c.request("POST", "/checkv2", open(filename, "rb"), headers) + r = c.getresponse() + assert r.status == 200 + d = demjson.decode(r.read()) + c.close() + BuiltIn().set_test_variable("${SCAN_RESULT}", d) + return def Send_SIGUSR1(pid): pid = int(pid) diff --git a/test/functional/lib/rspamd.robot b/test/functional/lib/rspamd.robot index b6c05db62..fccf2e429 100644 --- a/test/functional/lib/rspamd.robot +++ b/test/functional/lib/rspamd.robot @@ -44,6 +44,10 @@ Check Rspamc Match String Run Keyword If ${inverse} == False Should Contain ${subject} ${str} ... ELSE Should Not Contain ${subject} ${str} +Do Not Expect Symbol + [Arguments] ${symbol} + Run Keyword And Expect Error * Expect Symbol ${symbol} + Generic Setup [Arguments] @{vargs} &{kwargs} &{d} = Run Rspamd @{vargs} &{kwargs} @@ -54,6 +58,59 @@ Generic Setup ... ELSE Fail 'RSPAMD_SCOPE must be Test or Suite' END +Expect Action + [Arguments] ${action} + Should Be Equal ${SCAN_RESULT}[action] ${action} + +Expect Email + [Arguments] ${email} + List Should Contain Value ${SCAN_RESULT}[emails] ${email} + +Expect Required Score + [Arguments] ${required_score} + Should Be Equal As Numbers ${SCAN_RESULT}[required_score] ${required_score} + +Expect Required Score To Be Null + Should Be Equal ${SCAN_RESULT}[required_score] ${NONE} + +Expect Score + [Arguments] ${score} + Should Be Equal As Numbers ${SCAN_RESULT}[score] ${score} + +Expect Symbol + [Arguments] ${symbol} + Dictionary Should Contain Key ${SCAN_RESULT}[symbols] ${symbol} + ... msg=Symbol ${symbol} wasn't found in result + +Expect URL + [Arguments] ${url} + List Should Contain Value ${SCAN_RESULT}[urls] ${url} + +Expect Symbol With Exact Options + [Arguments] ${symbol} @{options} + Expect Symbol ${symbol} + ${have_options} = Convert To List ${SCAN_RESULT}[symbols][${symbol}][options] + Lists Should Be Equal ${have_options} ${options} + ... msg="Symbol ${symbol} has options ${SCAN_RESULT}[symbols][${symbol}][options] but expected ${options}" + +Expect Symbol With Option + [Arguments] ${symbol} ${option} + Expect Symbol ${symbol} + ${have_options} = Convert To List ${SCAN_RESULT}[symbols][${symbol}][options] + Should Contain ${have_options} ${option} + ... msg="Options for symbol ${symbol} ${SCAN_RESULT}[symbols][${symbol}][options] doesn't contain ${option}" + +Expect Symbol With Score + [Arguments] ${symbol} ${score} + Expect Symbol ${symbol} + Should Be Equal As Numbers ${SCAN_RESULT}[symbols][${symbol}][score] ${score} + ... msg="Symbol ${symbol} has score of ${SCAN_RESULT}[symbols][${symbol}][score] but expected ${score}" + +Expect Symbol With Score And Exact Options + [Arguments] ${symbol} ${score} @{options} + Expect Symbol With Exact Options ${symbol} @{options} + Expect Symbol With Score ${symbol} ${score} + Generic Teardown Run Keyword If '${CONTROLLER_ERRORS}' == 'True' Check Controller Errors Shutdown Process With Children ${RSPAMD_PID} @@ -155,6 +212,12 @@ Run Rspamd Simple Teardown Generic Teardown +Scan File By Reference + [Arguments] ${filename} &{headers} + Set To Dictionary ${headers} File=${filename} + ${result} = Scan File /dev/null &{headers} + [Return] ${result} + Scan Message With Rspamc [Arguments] ${msg_file} @{vargs} ${result} = Run Rspamc -p -h ${LOCAL_ADDR}:${PORT_NORMAL} @{vargs} ${msg_file} |