diff options
Diffstat (limited to 'tests/shell/testcases/nft-f/0005rollback_map_0')
-rwxr-xr-x | tests/shell/testcases/nft-f/0005rollback_map_0 | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/tests/shell/testcases/nft-f/0005rollback_map_0 b/tests/shell/testcases/nft-f/0005rollback_map_0 new file mode 100755 index 0000000..913595d --- /dev/null +++ b/tests/shell/testcases/nft-f/0005rollback_map_0 @@ -0,0 +1,43 @@ +#!/bin/bash + +# test a kernel rollback operation +# fail reason: invalid map + +GOOD_RULESET="table ip t { + set t { + type ipv4_addr + elements = { 1.1.1.1 } + } + + chain c { + ct state new + tcp dport { 22222, 33333 } + ip saddr @t drop + jump other + } + + chain other { + } +}" + +BAD_RULESET="flush ruleset +table ip t2 { + chain c2 { + tcp dport map { 22222: jump other, 11111: jump invalid } + } + + chain other { + } +}" + +$NFT -f - <<< "$GOOD_RULESET" +if [ $? -ne 0 ] ; then + echo "E: unable to load good ruleset" >&2 + exit 1 +fi + +$NFT -f - <<< "$BAD_RULESET" 2>/dev/null +if [ $? -eq 0 ] ; then + echo "E: bogus ruleset loaded?" >&2 + exit 1 +fi |