From 443cba72705398c0b12beb0796ba0c5504fb4dd2 Mon Sep 17 00:00:00 2001 From: Ismo Puustinen Date: Wed, 7 Jun 2017 11:35:59 +0300 Subject: tests: added tests for ordering files in include dirs. Test that the files are ordered properly by introducing included files which have internal dependencies. Signed-off-by: Ismo Puustinen Signed-off-by: Pablo Neira Ayuso --- tests/shell/testcases/include/0011dir_dependency_0 | 48 +++++++++++++++++++++ tests/shell/testcases/include/0012dir_dependency_1 | 50 ++++++++++++++++++++++ 2 files changed, 98 insertions(+) create mode 100755 tests/shell/testcases/include/0011dir_dependency_0 create mode 100755 tests/shell/testcases/include/0012dir_dependency_1 (limited to 'tests/shell/testcases') diff --git a/tests/shell/testcases/include/0011dir_dependency_0 b/tests/shell/testcases/include/0011dir_dependency_0 new file mode 100755 index 00000000..8ee193fd --- /dev/null +++ b/tests/shell/testcases/include/0011dir_dependency_0 @@ -0,0 +1,48 @@ +#!/bin/bash + +set -e + +tmpdir=$(mktemp -d) +if [ ! -d $tmpdir ] ; then + echo "Failed to create tmp directory" >&2 + exit 0 +fi + +tmpfile1="$tmpdir/01_file.nft" +touch $tmpfile1 +if [ ! -w $tmpfile1 ] ; then + echo "Failed to create tmp file" >&2 + exit 0 +fi + +tmpfile2="$tmpdir/02_file.nft" +touch $tmpfile2 +if [ ! -w $tmpfile2 ] ; then + echo "Failed to create tmp file" >&2 + exit 0 +fi + +tmpfile3=$(mktemp) +if [ ! -w $tmpfile3 ] ; then + echo "Failed to create tmp file" >&2 + exit 0 +fi + +# cleanup if aborted +trap "rm -rf $tmpfile1 $tmpfile2 $tmpfile3 && rmdir $tmpdir" EXIT + +# add interdependent rulesets +RULESET1="add table x" +RULESET2="add chain x y" +RULESET3="include \"$tmpdir/\"" + +echo "$RULESET1" > $tmpfile1 +echo "$RULESET2" > $tmpfile2 +echo "$RULESET3" > $tmpfile3 + +$NFT -f $tmpfile3 + +if [ $? -ne 0 ] ; then + echo "E: unable to load good ruleset" >&2 + exit 1 +fi diff --git a/tests/shell/testcases/include/0012dir_dependency_1 b/tests/shell/testcases/include/0012dir_dependency_1 new file mode 100755 index 00000000..c81ca327 --- /dev/null +++ b/tests/shell/testcases/include/0012dir_dependency_1 @@ -0,0 +1,50 @@ +#!/bin/bash + +set -e + +tmpdir=$(mktemp -d) +if [ ! -d $tmpdir ] ; then + echo "Failed to create tmp directory" >&2 + exit 0 +fi + +tmpfile1="$tmpdir/01_file.nft" +touch $tmpfile1 +if [ ! -w $tmpfile1 ] ; then + echo "Failed to create tmp file" >&2 + exit 0 +fi + +tmpfile2="$tmpdir/02_file.nft" +touch $tmpfile2 +if [ ! -w $tmpfile2 ] ; then + echo "Failed to create tmp file" >&2 + exit 0 +fi + +tmpfile3=$(mktemp) +if [ ! -w $tmpfile3 ] ; then + echo "Failed to create tmp file" >&2 + exit 0 +fi + +# cleanup if aborted +trap "rm -rf $tmpfile1 $tmpfile2 $tmpfile3 && rmdir $tmpdir" EXIT + +# add interdependent rulesets +RULESET1="add table x" +RULESET2="add chain x y" +RULESET3="include \"$tmpdir/\"" + +# Note different order when compared with 0011dir_depencency_0. The idea +# here is to introduce wrong order to get the loading fail. +echo "$RULESET1" > $tmpfile2 +echo "$RULESET2" > $tmpfile1 +echo "$RULESET3" > $tmpfile3 + +$NFT -f $tmpfile3 + +if [ $? -eq 0 ] ; then + echo "E: did not catch wrong file order in include directory" >&2 + exit 1 +fi -- cgit v1.2.3