+++ /dev/null
-#!/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
+++ /dev/null
-# 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()
--- /dev/null
+# 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)