zeek/testing/btest/language/at-if.zeek
Jon Siwek a994be9eeb Merge remote-tracking branch 'origin/topic/seth/zeek_init'
* origin/topic/seth/zeek_init:
  Some more testing fixes.
  Update docs and tests for bro_(init|done) -> zeek_(init|done)
  Implement the zeek_init handler.
2019-04-19 11:24:29 -07:00

57 lines
742 B
Text

# @TEST-EXEC: bro -b %INPUT >out
# @TEST-EXEC: btest-diff out
function test_case(msg: string, expect: bool)
{
print fmt("%s (%s)", msg, expect ? "PASS" : "FAIL");
}
function foo(c: count): bool
{ return c == 42 ? T : F; }
global TRUE_CONDITION = T;
event zeek_init()
{
local xyz = 0;
# Test "if" without "else"
@if ( F )
xyz += 1;
@endif
@if ( foo(0) )
xyz += 1;
@endif
@if ( T && foo(42) )
xyz += 2;
@endif
test_case( "@if", xyz == 2 );
# Test "if" with an "else"
xyz = 0;
@if ( F )
xyz += 1;
@else
xyz += 2;
@endif
test_case( "@if...@else", xyz == 2 );
xyz = 0;
@if ( T && TRUE_CONDITION )
xyz += 1;
@else
xyz += 2;
@endif
test_case( "@if...@else", xyz == 1 );
}