#! /usr/bin/perl -w -I .. # # UDP Connection Based Tests via check_udp # # $Id$ # use strict; use Test::More; use NPTest; my $res; plan tests => 14; $res = NPTest->testCmd( "./check_udp2 -H localhost -p 3333" ); cmp_ok( $res->return_code, '==', 3, "Need send/expect string"); like ( $res->output, '/With UDP checks, a send/expect string must be specified./', "Output OK"); $res = NPTest->testCmd( "./check_udp2 -H localhost -p 3333 -s send" ); cmp_ok( $res->return_code, '==', 3, "Need expect string"); like ( $res->output, '/With UDP checks, a send/expect string must be specified./', "Output OK"); $res = NPTest->testCmd( "./check_udp2 -H localhost -p 3333 -e expect" ); cmp_ok( $res->return_code, '==', 3, "Need send string"); like ( $res->output, '/With UDP checks, a send/expect string must be specified./', "Output OK"); $res = NPTest->testCmd( "./check_udp2 -H localhost -p 3333 -s foo -e bar" ); cmp_ok( $res->return_code, '==', 2, "Errors correctly because no udp service running" ); like ( $res->output, '/No data received from host/', "Output OK"); SKIP: { skip "No netcat available", 6 unless (system("which nc > /dev/null") == 0); open (NC, "echo 'barbar' | nc -l -p 3333 -u |"); sleep 1; $res = NPTest->testCmd( "./check_udp2 -H localhost -p 3333 -s '' -e barbar -4" ); cmp_ok( $res->return_code, '==', 0, "Got barbar response back" ); like ( $res->output, '/\[barbar\]/', "Output OK"); close NC; my $pid = open(NC, "nc -l -p 3333 -u |"); # Start up a udp server listening on port 3333 alarm(7); sleep 1; $SIG{ALRM} = sub { kill 'INT', $pid }; my $start = time; $res = NPTest->testCmd( "./check_udp2 -H localhost -p 3333 -s foofoo -e barbar -t 5 -4" ); my $duration = time - $start; cmp_ok( $res->return_code, '==', '2', "Hung waiting for response"); like ( $res->output, '/Socket timeout after 5 seconds/', "Timeout message"); cmp_ok( $duration, '==', 5, "Timeout exactly right"); my $read_nc = <NC>; # nc gets killed here - I think expects a linefeed from stdin, so doesn't exit itself close NC; cmp_ok( $read_nc, 'eq', "foofoo", "Data received correctly" ); }