Merge pull request #33 from ifupdown-ng/feature/gre-executor
gre executor
This commit is contained in:
commit
184526401b
5 changed files with 94 additions and 1 deletions
29
executor-scripts/linux/gre
Executable file
29
executor-scripts/linux/gre
Executable file
|
@ -0,0 +1,29 @@
|
|||
#!/bin/sh
|
||||
|
||||
# Executor for advanced GRE tunnel management.
|
||||
|
||||
[ -z "$IF_GRE_LOCAL" ] && exit 1
|
||||
[ -z "$IF_GRE_REMOTE" ] && exit 1
|
||||
[ -z "$IF_GRE_MODE" ] && IF_GRE_MODE="gre"
|
||||
|
||||
COMMAND="link"
|
||||
FAMILY="-4"
|
||||
[ "$IF_GRE_MODE" = "ip6gre" ] && FAMILY="-6"
|
||||
|
||||
PARAMS="mode $IF_GRE_MODE local '$IF_GRE_LOCAL' remote '$IF_GRE_REMOTE'"
|
||||
[ -n "$IF_GRE_TTL" ] && PARAMS="$PARAMS ttl '$IF_GRE_TTL'"
|
||||
[ -n "$IF_GRE_FLAGS" ] && PARAMS="$PARAMS $IF_GRE_FLAGS"
|
||||
|
||||
[ -n "$PARAMS" ] || exit 0
|
||||
|
||||
case "$PHASE" in
|
||||
pre-up)
|
||||
${MOCK} eval ip $FAMILY $COMMAND add $IFACE $PARAMS
|
||||
;;
|
||||
post-down)
|
||||
${MOCK} ip $FAMILY $COMMAND del $IFACE
|
||||
;;
|
||||
depend)
|
||||
echo "$IF_GRE_DEV"
|
||||
;;
|
||||
esac
|
12
tests/fixtures/gre.interfaces
vendored
Normal file
12
tests/fixtures/gre.interfaces
vendored
Normal file
|
@ -0,0 +1,12 @@
|
|||
auto tun0
|
||||
iface tun0
|
||||
gre-local 203.0.113.2
|
||||
gre-remote 203.0.113.1
|
||||
gre-dev eth0
|
||||
gre-ttl 255
|
||||
gre-flags nopmtudisc ignore-df
|
||||
address 203.0.113.10/30
|
||||
gateway 203.0.113.9
|
||||
|
||||
iface eth0
|
||||
address 203.0.113.2/30
|
|
@ -28,7 +28,8 @@ tests_init \
|
|||
tunnel_legacy_dependency \
|
||||
tunnel_legacy_rewrite \
|
||||
tunnel_ifupdown2_dependency \
|
||||
tunnel_ifupdown2_rewrite
|
||||
tunnel_ifupdown2_rewrite \
|
||||
gre_dependency
|
||||
|
||||
noargs_body() {
|
||||
atf_check -s exit:1 -e ignore ifquery -S/dev/null
|
||||
|
@ -180,3 +181,8 @@ tunnel_ifupdown2_rewrite_body() {
|
|||
-o match:"tunnel-ttl 255" \
|
||||
ifquery -E $EXECUTORS_LINUX -i $FIXTURES/tunnel-ifupdown2.interfaces tun0
|
||||
}
|
||||
|
||||
gre_dependency_body() {
|
||||
atf_check -s exit:0 -o match:"requires eth0" \
|
||||
ifquery -E $EXECUTORS_LINUX -i $FIXTURES/gre.interfaces tun0
|
||||
}
|
||||
|
|
|
@ -9,3 +9,4 @@ atf_test_program{name='static_test'}
|
|||
atf_test_program{name='vrf_test'}
|
||||
atf_test_program{name='ppp_test'}
|
||||
atf_test_program{name='tunnel_test'}
|
||||
atf_test_program{name='gre_test'}
|
||||
|
|
45
tests/linux/gre_test
Executable file
45
tests/linux/gre_test
Executable file
|
@ -0,0 +1,45 @@
|
|||
#!/usr/bin/env atf-sh
|
||||
|
||||
. $(atf_get_srcdir)/../test_env.sh
|
||||
EXECUTOR="$(atf_get_srcdir)/../../executor-scripts/linux/gre"
|
||||
|
||||
tests_init \
|
||||
basic_bringup \
|
||||
basic_teardown \
|
||||
flags_bringup
|
||||
|
||||
basic_bringup_body() {
|
||||
export MOCK=echo IFACE=tun0 PHASE=pre-up \
|
||||
IF_GRE_LOCAL=1.2.3.4 IF_GRE_REMOTE=5.6.7.8 \
|
||||
IF_GRE_TTL=255
|
||||
atf_check -s exit:0 \
|
||||
-o match:"ip -4 link add tun0" \
|
||||
-o match:"mode gre" \
|
||||
-o match:"ttl '255'" \
|
||||
-o match:"local '1.2.3.4'" \
|
||||
-o match:"remote '5.6.7.8'" \
|
||||
${EXECUTOR}
|
||||
}
|
||||
|
||||
basic_teardown_body() {
|
||||
export MOCK=echo IFACE=tun0 PHASE=post-down \
|
||||
IF_GRE_LOCAL=1.2.3.4 IF_GRE_REMOTE=5.6.7.8 \
|
||||
IF_GRE_TTL=255
|
||||
atf_check -s exit:0 \
|
||||
-o match:"ip -4 link del tun0" \
|
||||
${EXECUTOR}
|
||||
}
|
||||
|
||||
flags_bringup_body() {
|
||||
export MOCK=echo IFACE=tun0 PHASE=pre-up \
|
||||
IF_GRE_LOCAL=1.2.3.4 IF_GRE_REMOTE=5.6.7.8 \
|
||||
IF_GRE_TTL=255 IF_GRE_FLAGS="nopmtudisc ignore-df"
|
||||
atf_check -s exit:0 \
|
||||
-o match:"ip -4 link add tun0" \
|
||||
-o match:"mode gre" \
|
||||
-o match:"ttl '255'" \
|
||||
-o match:"local '1.2.3.4'" \
|
||||
-o match:"remote '5.6.7.8'" \
|
||||
-o match:"nopmtudisc ignore-df" \
|
||||
${EXECUTOR}
|
||||
}
|
Loading…
Reference in a new issue