summaryrefslogtreecommitdiffstats
path: root/tests/shell/testcases/sets/0060set_multistmt_0
blob: 8e17444e9ec5a3a3a3973d06d65fb1921b02ff42 (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
42
43
44
45
46
47
48
49
50
51
52
#!/bin/bash

# NFT_TEST_REQUIRES(NFT_TEST_HAVE_set_with_two_expressions)

RULESET="table x {
	set y {
		type ipv4_addr
		limit rate 1/second counter
		elements = { 5.5.5.5 limit rate 1/second counter packets 0 bytes 0 }
	}
	chain y {
		type filter hook output priority filter; policy accept;
		ip daddr @y
	}
}"

$NFT -f - <<< $RULESET
# should work
if [ $? -ne 0 ]
then
	exit 1
fi

# should work
$NFT add element x y { 1.1.1.1 limit rate 1/second counter }
if [ $? -ne 0 ]
then
	exit 1
fi

# should fail
$NFT add element x y { 2.2.2.2 limit rate 1/second }
if [ $? -eq 0 ]
then
	exit 1
fi

# should fail
$NFT add element x y { 3.3.3.3 counter limit rate 1/second }
if [ $? -eq 0 ]
then
	exit 1
fi

# should work
$NFT add element x y { 4.4.4.4 }
if [ $? -ne 0 ]
then
	exit 1
fi

exit 0