Blame SOURCES/0042-tests-shell-Merge-and-extend-return-codes-test.patch

87db66
From c5f07a7d718f812f916686926567adbac6c1b125 Mon Sep 17 00:00:00 2001
87db66
From: Phil Sutter <phil@nwl.cc>
87db66
Date: Thu, 6 Aug 2020 18:52:34 +0200
87db66
Subject: [PATCH] tests: shell: Merge and extend return codes test
87db66
87db66
Merge scripts for iptables and ip6tables, they were widely identical.
87db66
Also extend the test by one check (removing a non-existent rule with
87db66
valid chain and target) and quote the error messages where differences
87db66
are deliberately ignored.
87db66
87db66
Signed-off-by: Phil Sutter <phil@nwl.cc>
87db66
Acked-by: Pablo Neira Ayuso <pablo@netfilter.org>
87db66
(cherry picked from commit cd3e83d1b04fd2683f0fb06e496ee5be08a96b4f)
87db66
87db66
Conflicts:
87db66
	iptables/tests/shell/testcases/ip6tables/0004-return-codes_0
87db66
	iptables/tests/shell/testcases/iptables/0004-return-codes_0
87db66
-> Missing upstream commit a7f1e208cdf9c ("nft: split parsing from
87db66
   netlink commands") which added a few tests to both files.
87db66
87db66
Signed-off-by: Phil Sutter <psutter@redhat.com>
87db66
---
87db66
 .../testcases/ip6tables/0004-return-codes_0   |  38 -------
87db66
 .../testcases/iptables/0004-return-codes_0    | 104 ++++++++++--------
87db66
 2 files changed, 58 insertions(+), 84 deletions(-)
87db66
 delete mode 100755 iptables/tests/shell/testcases/ip6tables/0004-return-codes_0
87db66
87db66
diff --git a/iptables/tests/shell/testcases/ip6tables/0004-return-codes_0 b/iptables/tests/shell/testcases/ip6tables/0004-return-codes_0
87db66
deleted file mode 100755
87db66
index f023b7915498e..0000000000000
87db66
--- a/iptables/tests/shell/testcases/ip6tables/0004-return-codes_0
87db66
+++ /dev/null
87db66
@@ -1,38 +0,0 @@
87db66
-#!/bin/sh
87db66
-
87db66
-# make sure error return codes are as expected useful cases
87db66
-# (e.g. commands to check ruleset state)
87db66
-
87db66
-global_rc=0
87db66
-
87db66
-cmd() { # (rc, cmd, [args ...])
87db66
-	rc_exp=$1; shift
87db66
-
87db66
-	$XT_MULTI "$@"
87db66
-	rc=$?
87db66
-
87db66
-	[ $rc -eq $rc_exp ] || {
87db66
-		echo "---> expected $rc_exp, got $rc for command '$@'"
87db66
-		global_rc=1
87db66
-	}
87db66
-}
87db66
-
87db66
-# test chain creation
87db66
-cmd 0 ip6tables -N foo
87db66
-cmd 1 ip6tables -N foo
87db66
-# iptables-nft allows this - bug or feature?
87db66
-#cmd 2 ip6tables -N "invalid name"
87db66
-
87db66
-# test rule adding
87db66
-cmd 0 ip6tables -A INPUT -j ACCEPT
87db66
-cmd 1 ip6tables -A noexist -j ACCEPT
87db66
-
87db66
-# test rule checking
87db66
-cmd 0 ip6tables -C INPUT -j ACCEPT
87db66
-cmd 1 ip6tables -C FORWARD -j ACCEPT
87db66
-cmd 1 ip6tables -C nonexist -j ACCEPT
87db66
-cmd 2 ip6tables -C INPUT -j foobar
87db66
-cmd 2 ip6tables -C INPUT -m foobar -j ACCEPT
87db66
-cmd 3 ip6tables -t foobar -C INPUT -j ACCEPT
87db66
-
87db66
-exit $global_rc
87db66
diff --git a/iptables/tests/shell/testcases/iptables/0004-return-codes_0 b/iptables/tests/shell/testcases/iptables/0004-return-codes_0
87db66
index ce02e0bcb128b..67f1698945753 100755
87db66
--- a/iptables/tests/shell/testcases/iptables/0004-return-codes_0
87db66
+++ b/iptables/tests/shell/testcases/iptables/0004-return-codes_0
87db66
@@ -13,69 +13,81 @@ cmd() { # (rc, msg, cmd, [args ...])
87db66
 		msg_exp="$1"; shift
87db66
 	}
87db66
 
87db66
-	msg="$($XT_MULTI "$@" 2>&1 >/dev/null)"
87db66
-	rc=$?
87db66
+	for ipt in iptables ip6tables; do
87db66
+		msg="$($XT_MULTI $ipt "$@" 2>&1 >/dev/null)"
87db66
+		rc=$?
87db66
 
87db66
-	[ $rc -eq $rc_exp ] || {
87db66
-		echo "---> expected return code $rc_exp, got $rc for command '$@'"
87db66
-		global_rc=1
87db66
-	}
87db66
+		[ $rc -eq $rc_exp ] || {
87db66
+			echo "---> expected return code $rc_exp, got $rc for command '$ipt $@'"
87db66
+			global_rc=1
87db66
+		}
87db66
 
87db66
-	[ -n "$msg_exp" ] || return
87db66
-	grep -q "$msg_exp" <<< $msg || {
87db66
-		echo "---> expected error message '$msg_exp', got '$msg' for command '$@'"
87db66
-		global_rc=1
87db66
-	}
87db66
+		[ -n "$msg_exp" ] || continue
87db66
+		msg_exp_full="${ipt}$msg_exp"
87db66
+		grep -q "$msg_exp_full" <<< $msg || {
87db66
+			echo "---> expected error message '$msg_exp_full', got '$msg' for command '$ipt $@'"
87db66
+			global_rc=1
87db66
+		}
87db66
+	done
87db66
 }
87db66
 
87db66
-EEXIST_F="File exists."
87db66
-EEXIST="Chain already exists."
87db66
-ENOENT="No chain/target/match by that name."
87db66
-E2BIG_I="Index of insertion too big."
87db66
-E2BIG_D="Index of deletion too big."
87db66
-E2BIG_R="Index of replacement too big."
87db66
-EBADRULE="Bad rule (does a matching rule exist in that chain?)."
87db66
-ENOTGT="Couldn't load target \`foobar':No such file or directory"
87db66
-ENOMTH="Couldn't load match \`foobar':No such file or directory"
87db66
-ENOTBL="can't initialize iptables table \`foobar': Table does not exist"
87db66
+EEXIST_F=": File exists."
87db66
+EEXIST=": Chain already exists."
87db66
+ENOENT=": No chain/target/match by that name."
87db66
+E2BIG_I=": Index of insertion too big."
87db66
+E2BIG_D=": Index of deletion too big."
87db66
+E2BIG_R=": Index of replacement too big."
87db66
+EBADRULE=": Bad rule (does a matching rule exist in that chain?)."
87db66
+#ENOTGT=" v[0-9\.]* [^ ]*: Couldn't load target \`foobar':No such file or directory"
87db66
+ENOMTH=" v[0-9\.]* [^ ]*: Couldn't load match \`foobar':No such file or directory"
87db66
+ENOTBL=": can't initialize iptables table \`foobar': Table does not exist"
87db66
 
87db66
 # test chain creation
87db66
-cmd 0 iptables -N foo
87db66
-cmd 1 "$EEXIST" iptables -N foo
87db66
+cmd 0 -N foo
87db66
+cmd 1 "$EEXIST" -N foo
87db66
 # iptables-nft allows this - bug or feature?
87db66
-#cmd 2 iptables -N "invalid name"
87db66
+#cmd 2 -N "invalid name"
87db66
 
87db66
 # test chain flushing/zeroing
87db66
-cmd 0 iptables -F foo
87db66
-cmd 0 iptables -Z foo
87db66
-cmd 1 "$ENOENT" iptables -F bar
87db66
-cmd 1 "$ENOENT" iptables -Z bar
87db66
+cmd 0 -F foo
87db66
+cmd 0 -Z foo
87db66
+cmd 1 "$ENOENT" -F bar
87db66
+cmd 1 "$ENOENT" -Z bar
87db66
 
87db66
 # test chain rename
87db66
-cmd 0 iptables -E foo bar
87db66
-cmd 1 "$EEXIST_F" iptables -E foo bar
87db66
+cmd 0 -E foo bar
87db66
+cmd 1 "$EEXIST_F" -E foo bar
87db66
 
87db66
 # test rule adding
87db66
-cmd 0 iptables -A INPUT -j ACCEPT
87db66
-cmd 1 "$ENOENT" iptables -A noexist -j ACCEPT
87db66
+cmd 0 -A INPUT -j ACCEPT
87db66
+cmd 1 "$ENOENT" -A noexist -j ACCEPT
87db66
+# next three differ:
87db66
+# legacy: Couldn't load target `foobar':No such file or directory
87db66
+# nft:    Chain 'foobar' does not exist
87db66
+cmd 2 "" -I INPUT -j foobar
87db66
+cmd 2 "" -R INPUT 1 -j foobar
87db66
+cmd 2 "" -D INPUT -j foobar
87db66
+cmd 1 "$EBADRULE" -D INPUT -p tcp --dport 22 -j ACCEPT
87db66
 
87db66
 # test rulenum commands
87db66
-cmd 1 "$E2BIG_I" iptables -I INPUT 23 -j ACCEPT
87db66
-cmd 1 "$E2BIG_D" iptables -D INPUT 23
87db66
-cmd 1 "$E2BIG_R" iptables -R INPUT 23 -j ACCEPT
87db66
-cmd 1 "$ENOENT" iptables -I nonexist 23 -j ACCEPT
87db66
-cmd 1 "$ENOENT" iptables -D nonexist 23
87db66
-cmd 1 "$ENOENT" iptables -R nonexist 23 -j ACCEPT
87db66
+cmd 1 "$E2BIG_I" -I INPUT 23 -j ACCEPT
87db66
+cmd 1 "$E2BIG_D" -D INPUT 23
87db66
+cmd 1 "$E2BIG_R" -R INPUT 23 -j ACCEPT
87db66
+cmd 1 "$ENOENT" -I nonexist 23 -j ACCEPT
87db66
+cmd 1 "$ENOENT" -D nonexist 23
87db66
+cmd 1 "$ENOENT" -R nonexist 23 -j ACCEPT
87db66
 
87db66
 # test rule checking
87db66
-cmd 0 iptables -C INPUT -j ACCEPT
87db66
-cmd 1 "$EBADRULE" iptables -C FORWARD -j ACCEPT
87db66
-cmd 1 "$BADRULE" iptables -C nonexist -j ACCEPT
87db66
-cmd 2 "$ENOMTH" iptables -C INPUT -m foobar -j ACCEPT
87db66
+cmd 0 -C INPUT -j ACCEPT
87db66
+cmd 1 "$EBADRULE" -C FORWARD -j ACCEPT
87db66
+cmd 1 "$BADRULE" -C nonexist -j ACCEPT
87db66
+cmd 2 "$ENOMTH" -C INPUT -m foobar -j ACCEPT
87db66
 # messages of those don't match, but iptables-nft ones are actually nicer.
87db66
-#cmd 2 "$ENOTGT" iptables -C INPUT -j foobar
87db66
-#cmd 3 "$ENOTBL" iptables -t foobar -C INPUT -j ACCEPT
87db66
-cmd 2 "" iptables -C INPUT -j foobar
87db66
-cmd 3 "" iptables -t foobar -C INPUT -j ACCEPT
87db66
+# legacy: Couldn't load target `foobar':No such file or directory
87db66
+# nft:    Chain 'foobar' does not exist
87db66
+cmd 2 "" -C INPUT -j foobar
87db66
+# legacy: can't initialize ip6tables table `foobar': Table does not exist (do you need to insmod?)
87db66
+# nft:    table 'foobar' does not exist
87db66
+cmd 3 "" -t foobar -C INPUT -j ACCEPT
87db66
 
87db66
 exit $global_rc
87db66
-- 
87db66
2.28.0
87db66