blob: 659bf70c05bfc3f67a39417eb79db25c66a58d0f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
#!/bin/bash
# This tests the selectiveness of flush command on structures that use the
# generic set infrastructure (sets, maps and meters).
tmpfile=$(mktemp)
if [ ! -w $tmpfile ] ; then
echo "Failed to create tmp file" >&2
exit 0
fi
trap "rm -rf $tmpfile" EXIT # cleanup if aborted
echo "
add table t
add chain t c
add set t s {type ipv4_addr;}
add map t m {type ipv4_addr : inet_service;}
add rule t c tcp dport 80 meter f {ip saddr limit rate 10/second}
" >$tmpfile
$NFT -f $tmpfile
# Commands that should be invalid
declare -a cmds=(
"flush set t m" "flush set t f"
"flush map t s" "flush map t f"
"flush meter t s" "flush meter t m"
)
for i in "${cmds[@]}"
do
echo "$i" >$tmpfile
$NFT -f $tmpfile &>/dev/null
ret=$?
if [ $ret -eq 0 ]; then
exit 1
fi
done
|