]> git.ipfire.org Git - thirdparty/bind9.git/commitdiff
Rewrite spf system test to pytest
authorMichal Nowak <mnowak@isc.org>
Fri, 22 Dec 2023 09:57:12 +0000 (10:57 +0100)
committerMichał Kępień <michal@isc.org>
Fri, 22 Dec 2023 14:02:58 +0000 (15:02 +0100)
bin/tests/system/spf/tests.sh [deleted file]
bin/tests/system/spf/tests_sh_spf.py [deleted file]
bin/tests/system/spf/tests_spf_zones.py [new file with mode: 0644]

diff --git a/bin/tests/system/spf/tests.sh b/bin/tests/system/spf/tests.sh
deleted file mode 100644 (file)
index a74f559..0000000
+++ /dev/null
@@ -1,46 +0,0 @@
-#!/bin/sh
-
-# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
-#
-# SPDX-License-Identifier: MPL-2.0
-#
-# This Source Code Form is subject to the terms of the Mozilla Public
-# License, v. 2.0.  If a copy of the MPL was not distributed with this
-# file, you can obtain one at https://mozilla.org/MPL/2.0/.
-#
-# See the COPYRIGHT file distributed with this work for additional
-# information regarding copyright ownership.
-
-set -e
-
-. ../conf.sh
-
-n=1
-status=0
-
-# Wait until all zones are loaded before checking SPF related logs
-for i in 1 2 3 4 5 6 7 8 9 10; do
-  grep "all zones loaded" ns1/named.run >/dev/null && break
-  sleep 1
-done
-
-echo_i "checking that SPF warnings have been correctly generated ($n)"
-ret=0
-
-grep "zone spf/IN: loaded serial 0" ns1/named.run >/dev/null || ret=1
-grep "'y.spf' found type SPF" ns1/named.run >/dev/null || ret=1
-grep "'spf' found type SPF" ns1/named.run >/dev/null && ret=1
-
-grep "zone warn/IN: loaded serial 0" ns1/named.run >/dev/null || ret=1
-grep "'y.warn' found type SPF" ns1/named.run >/dev/null || ret=1
-grep "'warn' found type SPF" ns1/named.run >/dev/null && ret=1
-
-grep "zone nowarn/IN: loaded serial 0" ns1/named.run >/dev/null || ret=1
-grep "'y.nowarn' found type SPF" ns1/named.run >/dev/null && ret=1
-grep "'nowarn' found type SPF" ns1/named.run >/dev/null && ret=1
-n=$((n + 1))
-if [ $ret != 0 ]; then echo_i "failed"; fi
-status=$((status + ret))
-
-echo_i "exit status: $status"
-[ $status -eq 0 ] || exit 1
diff --git a/bin/tests/system/spf/tests_sh_spf.py b/bin/tests/system/spf/tests_sh_spf.py
deleted file mode 100644 (file)
index 53c623d..0000000
+++ /dev/null
@@ -1,14 +0,0 @@
-# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
-#
-# SPDX-License-Identifier: MPL-2.0
-#
-# This Source Code Form is subject to the terms of the Mozilla Public
-# License, v. 2.0.  If a copy of the MPL was not distributed with this
-# file, you can obtain one at https://mozilla.org/MPL/2.0/.
-#
-# See the COPYRIGHT file distributed with this work for additional
-# information regarding copyright ownership.
-
-
-def test_spf(run_tests_sh):
-    run_tests_sh()
diff --git a/bin/tests/system/spf/tests_spf_zones.py b/bin/tests/system/spf/tests_spf_zones.py
new file mode 100644 (file)
index 0000000..550704b
--- /dev/null
@@ -0,0 +1,32 @@
+# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
+#
+# SPDX-License-Identifier: MPL-2.0
+#
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0.  If a copy of the MPL was not distributed with this
+# file, you can obtain one at https://mozilla.org/MPL/2.0/.
+#
+# See the COPYRIGHT file distributed with this work for additional
+# information regarding copyright ownership.
+
+import pytest
+
+
+@pytest.mark.requires_zones_loaded("ns1")
+def test_spf_log(servers):
+    for msg in (
+        "zone spf/IN: 'y.spf' found type SPF record but no SPF TXT record found",
+        "zone warn/IN: 'y.warn' found type SPF record but no SPF TXT record found",
+        "zone spf/IN: loaded serial 0",
+        "zone warn/IN: loaded serial 0",
+        "zone nowarn/IN: loaded serial 0",
+    ):
+        servers["ns1"].log.expect(msg)
+
+    for msg in (
+        "zone nowarn/IN: 'y.nowarn' found type SPF record but no SPF TXT record found",
+        "zone spf/IN: 'spf' found type SPF record but no SPF TXT record found",
+        "zone warn/IN: 'warn' found type SPF record but no SPF TXT record found",
+        "zone nowarn/IN: 'nowarn' found type SPF record but no SPF TXT record found",
+    ):
+        servers["ns1"].log.prohibit(msg)