From e8617232a5c7f86e4281570c634dbd3a2bbabf62 Mon Sep 17 00:00:00 2001 From: shifter Date: Mon, 30 Dec 2024 17:44:31 +0100 Subject: [PATCH] filterx: add light tests for keys function Signed-off-by: shifter --- .../functional_tests/filterx/test_filterx.py | 24 +++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/tests/light/functional_tests/filterx/test_filterx.py b/tests/light/functional_tests/filterx/test_filterx.py index 6ce1469ce..2fa23ac39 100644 --- a/tests/light/functional_tests/filterx/test_filterx.py +++ b/tests/light/functional_tests/filterx/test_filterx.py @@ -2626,3 +2626,27 @@ def test_set_fields(config, syslog_ng): assert file_true.get_stats()["processed"] == 1 assert "processed" not in file_false.get_stats() assert file_true.read_log() == '{"foo":"foo_override","bar":"bar_exists","baz":"baz_override","almafa":"almafa_default"}\n' + + +def test_keys(config, syslog_ng): + (file_true, file_false) = create_config( + config, r""" + dict = {"foo":{"bar":{"baz":"foobarbaz"}},"tik":{"tak":{"toe":"tiktaktoe"}}}; + $MSG = json(); + $MSG.empty = keys(json()); + $MSG.top_level = keys(dict); + $MSG.nested = keys(dict["foo"]); + $MSG.direct_access = keys(dict)[0]; + """, + ) + syslog_ng.start(config) + + assert file_true.get_stats()["processed"] == 1 + assert "processed" not in file_false.get_stats() + exp = ( + r"""{"empty":[],""" + r""""top_level":["foo","tik"],""" + r""""nested":["bar"],""" + r""""direct_access":"foo"}""" + "\n" + ) + assert file_true.read_log() == exp