Blame tests/field_descent.sh

Packit 1422b7
# added 2014-12-11 by singh.janmejay
Packit 1422b7
# This file is part of the liblognorm project, released under ASL 2.0
Packit 1422b7
Packit 1422b7
uname -a | grep "SunOS.*5.10"
Packit 1422b7
if [ $? -eq 0 ] ; then
Packit 1422b7
   echo platform: `uname -a`
Packit 1422b7
   echo This looks like solaris 10, we disable known-failing tests to
Packit 1422b7
   echo permit OpenCSW to build packages. However, this are real failurs
Packit 1422b7
   echo and so a fix should be done as soon as time permits.
Packit 1422b7
   exit 77
Packit 1422b7
fi
Packit 1422b7
. $srcdir/exec.sh
Packit 1422b7
Packit 1422b7
test_def $0 "descent based parsing field"
Packit 1422b7
Packit 1422b7
#descent with default tail field
Packit 1422b7
add_rule 'rule=:blocked on %device:word% %net:descent:./child.rulebase%at %tm:date-rfc5424%'
Packit 1422b7
reset_rules 'child'
Packit 1422b7
add_rule 'rule=:%ip_addr:ipv4% %tail:rest%' 'child'
Packit 1422b7
add_rule 'rule=:%subnet_addr:ipv4%/%mask:number% %tail:rest%' 'child'
Packit 1422b7
execute 'blocked on gw-1 10.20.30.40 at 2014-12-08T08:53:33.05+05:30'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"ip_addr": "10.20.30.40"}, "tm": "2014-12-08T08:53:33.05+05:30"}'
Packit 1422b7
execute 'blocked on gw-1 10.20.30.40/16 at 2014-12-08T08:53:33.05+05:30'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"subnet_addr": "10.20.30.40", "mask": "16"}, "tm": "2014-12-08T08:53:33.05+05:30"}'
Packit 1422b7
Packit 1422b7
#descent with tail field being explicitly named 'tail'
Packit 1422b7
reset_rules
Packit 1422b7
add_rule 'rule=:blocked on %device:word% %net:descent:./field.rulebase:tail%at %tm:date-rfc5424%'
Packit 1422b7
reset_rules 'field'
Packit 1422b7
add_rule 'rule=:%ip_addr:ipv4% %tail:rest%' 'field'
Packit 1422b7
add_rule 'rule=:%subnet_addr:ipv4%/%mask:number% %tail:rest%' 'field'
Packit 1422b7
execute 'blocked on gw-1 10.20.30.40 at 2014-12-08T08:53:33.05+05:30'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"ip_addr": "10.20.30.40"}, "tm": "2014-12-08T08:53:33.05+05:30"}'
Packit 1422b7
execute 'blocked on gw-1 10.20.30.40/16 at 2014-12-08T08:53:33.05+05:30'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"subnet_addr": "10.20.30.40", "mask": "16"}, "tm": "2014-12-08T08:53:33.05+05:30"}'
Packit 1422b7
Packit 1422b7
#descent with tail field having arbirary name
Packit 1422b7
reset_rules
Packit 1422b7
add_rule 'rule=:blocked on %device:word% %net:descent:./subset.rulebase:remaining%at %tm:date-rfc5424%'
Packit 1422b7
reset_rules 'subset'
Packit 1422b7
add_rule 'rule=:%ip_addr:ipv4% %remaining:rest%' 'subset'
Packit 1422b7
add_rule 'rule=:%subnet_addr:ipv4%/%mask:number% %remaining:rest%' 'subset'
Packit 1422b7
execute 'blocked on gw-1 10.20.30.40 at 2014-12-08T08:53:33.05+05:30'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"ip_addr": "10.20.30.40"}, "tm": "2014-12-08T08:53:33.05+05:30"}'
Packit 1422b7
execute 'blocked on gw-1 10.20.30.40/16 at 2014-12-08T08:53:33.05+05:30'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"subnet_addr": "10.20.30.40", "mask": "16"}, "tm": "2014-12-08T08:53:33.05+05:30"}'
Packit 1422b7
Packit 1422b7
#head call handling with with separate rulebase and tail field with with arbitrary name (this is what recursive field can't do)
Packit 1422b7
reset_rules
Packit 1422b7
add_rule 'rule=:%net:descent:./alt.rulebase:remains%blocked on %device:word%'
Packit 1422b7
reset_rules 'alt'
Packit 1422b7
add_rule 'rule=:%ip_addr:ipv4% %remains:rest%' 'alt'
Packit 1422b7
add_rule 'rule=:%subnet_addr:ipv4%/%mask:number% %remains:rest%' 'alt'
Packit 1422b7
execute '10.20.30.40 blocked on gw-1'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"ip_addr": "10.20.30.40"}}'
Packit 1422b7
execute '10.20.30.40/16 blocked on gw-1'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"subnet_addr": "10.20.30.40", "mask": "16"}}'
Packit 1422b7
Packit 1422b7
#descent-field which calls another descent-field
Packit 1422b7
reset_rules
Packit 1422b7
add_rule 'rule=:%op:descent:./op.rulebase:rest% on %device:word%'
Packit 1422b7
reset_rules 'op'
Packit 1422b7
add_rule 'rule=:%net:descent:./alt.rulebase:remains%%action:word%%rest:rest%' 'op'
Packit 1422b7
reset_rules 'alt'
Packit 1422b7
add_rule 'rule=:%ip_addr:ipv4% %remains:rest%' 'alt'
Packit 1422b7
add_rule 'rule=:%subnet_addr:ipv4%/%mask:number% %remains:rest%' 'alt'
Packit 1422b7
execute '10.20.30.40 blocked on gw-1'
Packit 1422b7
assert_output_json_eq '{"op": {"action": "blocked", "net": {"ip_addr": "10.20.30.40"}}, "device": "gw-1"}'
Packit 1422b7
execute '10.20.30.40/16 unblocked on gw-2'
Packit 1422b7
assert_output_json_eq '{"op": {"action": "unblocked", "net": {"subnet_addr": "10.20.30.40", "mask": "16"}}, "device": "gw-2"}'
Packit 1422b7
Packit 1422b7
#descent with file name having lognorm special char
Packit 1422b7
add_rule 'rule=:blocked on %device:word% %net:descent:./part\x3anet.rulebase%at %tm:date-rfc5424%'
Packit 1422b7
reset_rules 'part:net'
Packit 1422b7
add_rule 'rule=:%ip_addr:ipv4% %tail:rest%' 'part:net'
Packit 1422b7
add_rule 'rule=:%subnet_addr:ipv4%/%mask:number% %tail:rest%' 'part:net'
Packit 1422b7
execute 'blocked on gw-1 10.20.30.40 at 2014-12-08T08:53:33.05+05:30'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"ip_addr": "10.20.30.40"}, "tm": "2014-12-08T08:53:33.05+05:30"}'
Packit 1422b7
execute 'blocked on gw-1 10.20.30.40/16 at 2014-12-08T08:53:33.05+05:30'
Packit 1422b7
assert_output_json_eq '{"device": "gw-1", "net": {"subnet_addr": "10.20.30.40", "mask": "16"}, "tm": "2014-12-08T08:53:33.05+05:30"}'
Packit 1422b7
Packit 1422b7
Packit 1422b7
cleanup_tmp_files
Packit 1422b7