commit 1fa1fe9: [Test] Some more tests for logging

Andrew Lewis nerf at judo.za.org
Mon Jul 29 17:51:07 UTC 2024


Author: Andrew Lewis
Date: 2024-01-01 16:01:50 +0200
URL: https://github.com/rspamd/rspamd/commit/1fa1fe96cd429562657952f55a4b44ed90cf144c (refs/pull/4767/head)

[Test] Some more tests for logging

---
 .../000_console/000_systemd_logger.robot}          |  5 ++++-
 .../410_logging/000_console/001_timestamps.robot   | 24 ++++++++++++++++++++++
 .../cases/410_logging/001_file/000_json.robot      | 17 +++++++++++++++
 test/functional/configs/loggingtest-local.conf     |  5 +++++
 .../configs/{systemd.conf => loggingtest.conf}     |  2 +-
 test/functional/configs/systemd-local.conf         |  4 ----
 test/functional/lib/rspamd.py                      |  9 ++++++++
 7 files changed, 60 insertions(+), 6 deletions(-)

diff --git a/test/functional/cases/410_systemd_logger.robot b/test/functional/cases/410_logging/000_console/000_systemd_logger.robot
similarity index 76%
rename from test/functional/cases/410_systemd_logger.robot
rename to test/functional/cases/410_logging/000_console/000_systemd_logger.robot
index f90d16065..88178461b 100644
--- a/test/functional/cases/410_systemd_logger.robot
+++ b/test/functional/cases/410_logging/000_console/000_systemd_logger.robot
@@ -6,7 +6,10 @@ Resource        ${RSPAMD_TESTDIR}/lib/rspamd.robot
 Variables       ${RSPAMD_TESTDIR}/lib/vars.py
 
 *** Variables ***
-${CONFIG}                         ${RSPAMD_TESTDIR}/configs/systemd.conf
+${CONFIG}                         ${RSPAMD_TESTDIR}/configs/loggingtest.conf
+${RSPAMD_LOGGINGTYPE}             console
+${RSPAMD_JSON}                    false
+${RSPAMD_SYSTEMD}                 true
 ${RSPAMD_SCOPE}                   Suite
 
 *** Test Cases ***
diff --git a/test/functional/cases/410_logging/000_console/001_timestamps.robot b/test/functional/cases/410_logging/000_console/001_timestamps.robot
new file mode 100644
index 000000000..bd8e2c349
--- /dev/null
+++ b/test/functional/cases/410_logging/000_console/001_timestamps.robot
@@ -0,0 +1,24 @@
+*** Settings ***
+Suite Setup     Rspamd Setup
+Suite Teardown  Console Timestamps Teardown
+Library         ${RSPAMD_TESTDIR}/lib/rspamd.py
+Resource        ${RSPAMD_TESTDIR}/lib/rspamd.robot
+Variables       ${RSPAMD_TESTDIR}/lib/vars.py
+
+*** Variables ***
+${CONFIG}                         ${RSPAMD_TESTDIR}/configs/loggingtest.conf
+${RSPAMD_LOGGINGTYPE}             console
+${RSPAMD_JSON}                    false
+${RSPAMD_SYSTEMD}                 false
+${RSPAMD_SCOPE}                   Suite
+
+*** Test Cases ***
+EMPTY TEST
+  Pass Execution  No worries
+
+*** Keywords ***
+Console Timestamps Teardown
+  Touch  ${RSPAMD_TMPDIR}/rspamd.log
+  Rspamd Teardown
+  ${log} =  Get File  ${EXECDIR}/robot-save/rspamd.stderr.last
+  Should Match Regexp  ${log}  \\n\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2}  #\\d+\\(main\\) lua; lua_cfg_transform\\.lua:\\d+: overriding actions from the legacy metric settings\\n
diff --git a/test/functional/cases/410_logging/001_file/000_json.robot b/test/functional/cases/410_logging/001_file/000_json.robot
new file mode 100644
index 000000000..a2f04e85c
--- /dev/null
+++ b/test/functional/cases/410_logging/001_file/000_json.robot
@@ -0,0 +1,17 @@
+*** Settings ***
+Test Setup      Rspamd Setup
+Library         ${RSPAMD_TESTDIR}/lib/rspamd.py
+Resource        ${RSPAMD_TESTDIR}/lib/rspamd.robot
+Variables       ${RSPAMD_TESTDIR}/lib/vars.py
+
+*** Variables ***
+${CONFIG}                         ${RSPAMD_TESTDIR}/configs/loggingtest.conf
+${RSPAMD_LOGGINGTYPE}             file
+${RSPAMD_JSON}                    true
+${RSPAMD_SYSTEMD}                 true
+${RSPAMD_SCOPE}                   Test
+
+*** Test Cases ***
+JSON LOGS
+  Rspamd Teardown
+  Check JSON Log  ${EXECDIR}/robot-save/rspamd.log.last
diff --git a/test/functional/configs/loggingtest-local.conf b/test/functional/configs/loggingtest-local.conf
new file mode 100644
index 000000000..7330d972e
--- /dev/null
+++ b/test/functional/configs/loggingtest-local.conf
@@ -0,0 +1,5 @@
+logging {
+  type = "{= env.LOGGINGTYPE =}";
+  json = {= env.JSON =};
+  systemd = {= env.SYSTEMD =};
+}
diff --git a/test/functional/configs/systemd.conf b/test/functional/configs/loggingtest.conf
similarity index 85%
rename from test/functional/configs/systemd.conf
rename to test/functional/configs/loggingtest.conf
index f57827c48..99026df81 100644
--- a/test/functional/configs/systemd.conf
+++ b/test/functional/configs/loggingtest.conf
@@ -1,3 +1,3 @@
 .include(duplicate=append,priority=0) "{= env.TESTDIR =}/configs/trivial.conf"
 
-.include(priority=1,duplicate=merge) "{= env.TESTDIR =}/configs/systemd-local.conf"
+.include(priority=1,duplicate=merge) "{= env.TESTDIR =}/configs/loggingtest-local.conf"
diff --git a/test/functional/configs/systemd-local.conf b/test/functional/configs/systemd-local.conf
deleted file mode 100644
index ed796a95e..000000000
--- a/test/functional/configs/systemd-local.conf
+++ /dev/null
@@ -1,4 +0,0 @@
-logging {
-  type = "console";
-  systemd = true;
-}
diff --git a/test/functional/lib/rspamd.py b/test/functional/lib/rspamd.py
index 49c21a449..3976ca949 100644
--- a/test/functional/lib/rspamd.py
+++ b/test/functional/lib/rspamd.py
@@ -24,6 +24,15 @@ def Check_JSON(j):
     assert 'error' not in d
     return d
 
+def check_json_log(fn):
+    line_count = 0
+    f = open(fn, 'r')
+    for l in f.readlines():
+        d = demjson.decode(l, strict=True)
+        assert len(d) > 0
+        line_count = line_count + 1
+    assert line_count > 0
+
 def cleanup_temporary_directory(directory):
     shutil.rmtree(directory)
 


More information about the Commits mailing list