blob: 2c55edcfb56814a5777676f6ea28feaaddc54619 (
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
#!/bin/bash
#
# (C) 2013 by Arturo Borrero Gonzalez <arturo.borrero.glez@gmail.com>
#
# This program is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This is a small testbench for adding nftables tables to kernel
# in XML format.
BINARY="../examples/nft-table-xml-add"
NFT="$( which nft )"
MKTEMP="$( which mktemp)"
TMPFILE="$( $MKTEMP )"
if [ ! -x "$BINARY" ] ; then
echo "E: Binary not found $BINARY"
exit 1
fi
if [ ! -x "$MKTEMP" ] ; then
echo "E: mktemp not found and is neccesary"
exit 1
fi
if [ ! -w "$TMPFILE" ] ; then
echo "E: Unable to create temp file via mktemp"
exit 1
fi
if [ ! -x "$NFT" ] ; then
echo "W: nftables main binary not found but continuing anyway $NFT"
fi
# This is valid
XML="<table name=\"filter_test\" version=\"0\">
<properties>
<family>2</family>
<table_flags>0</table_flags>
</properties>
</table>"
$NFT delete table filter_test 2>/dev/null >&2
echo $XML > $TMPFILE
if ! $BINARY "$TMPFILE" ; then
echo "E: Unable to add XML:"
echo "$XML"
rm -rf $TMPFILE 2>/dev/null
exit 1
fi
# This is valid
XML="<table name=\"filter6_test\" version=\"0\">
<properties>
<family>10</family>
<table_flags>0</table_flags>
</properties>
</table>"
$NFT delete table filter6_test 2>/dev/null >&2
echo $XML > $TMPFILE
if ! $BINARY "$TMPFILE" ; then
echo "E: Unable to add XML:"
echo "$XML"
rm -rf $TMPFILE 2>/dev/null
exit 1
fi
rm -rf $TMPFILE 2>/dev/null
echo "I: Test OK"
|