From: Erik Auerswald Date: Tue, 6 Feb 2024 20:52:31 +0000 (+0100) Subject: Test edge cases of -f and -g X-Git-Url: https://git.gsnw.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=ef74f642d12bf699c77cf76ce74a6ae4b8955ebd;p=fping.git Test edge cases of -f and -g * -f with non-existing file * -f with input file containing comment and empty line * -g with non-numeric address in "CIDR" format * -g with one non-numeric address in start resp. end position * -g with one IPv6 address in start resp. end position --- diff --git a/ci/test-06-options-f-h.pl b/ci/test-06-options-f-h.pl index b730763..1e22602 100755 --- a/ci/test-06-options-f-h.pl +++ b/ci/test-06-options-f-h.pl @@ -1,6 +1,6 @@ #!/usr/bin/perl -w -use Test::Command tests => 51; +use Test::Command tests => 72; use Test::More; use File::Temp; @@ -14,6 +14,10 @@ my $tmpfile = File::Temp->new(); print $tmpfile "127.0.0.1\n127.0.0.2\n"; close($tmpfile); +my $tmpfile2 = File::Temp->new(); +print $tmpfile2 "# comment\n127.0.0.1\n\n127.0.0.2\n"; +close($tmpfile2); + # fping without option (-> equivalent to 'fping -f -') { my $cmd = Test::Command->new(cmd => "cat ".$tmpfile->filename." | fping"); @@ -38,6 +42,22 @@ $cmd->stdout_is_eq("127.0.0.1 is alive\n127.0.0.2 is alive\n"); $cmd->stderr_is_eq(""); } +# fping -f file (with comment and empty line) +{ +my $cmd = Test::Command->new(cmd => "fping -f ".$tmpfile2->filename); +$cmd->exit_is_num(0); +$cmd->stdout_is_eq("127.0.0.1 is alive\n127.0.0.2 is alive\n"); +$cmd->stderr_is_eq(""); +} + +# fping -f non-existing-file (error) +{ +my $cmd = Test::Command->new(cmd => "fping -f file-does-not-exist"); +$cmd->exit_is_num(4); +$cmd->stdout_is_eq(""); +$cmd->stderr_like(qr{: fopen :}); +} + # fping -g (error: no argument) { my $cmd = Test::Command->new(cmd => "fping -g"); @@ -53,6 +73,31 @@ $cmd->exit_is_num(1); $cmd->stdout_is_eq(""); $cmd->stderr_like(qr{^Usage: fping \[options\] \[targets\.\.\.\]}); } + +# fping -g (error: CIDR network is not an IP address) +{ +my $cmd = Test::Command->new(cmd => "fping -g xxx/32"); +$cmd->exit_is_num(1); +$cmd->stdout_is_eq(""); +$cmd->stderr_like(qr{can't parse address xxx}); +} + +# fping -g (error: start of range is not an IP address) +{ +my $cmd = Test::Command->new(cmd => "fping -g xxx 127.0.0.1"); +$cmd->exit_is_num(1); +$cmd->stdout_is_eq(""); +$cmd->stderr_like(qr{can't parse address xxx}); +} + +# fping -g (error: end of range is not an IP address) +{ +my $cmd = Test::Command->new(cmd => "fping -g 127.0.0.1 yyy"); +$cmd->exit_is_num(1); +$cmd->stdout_is_eq(""); +$cmd->stderr_like(qr{can't parse address yyy}); +} + # fping -g (error: too many arguments) { my $cmd = Test::Command->new(cmd => "fping -g 127.0.0.1 127.0.0.2 127.0.0.3"); @@ -136,6 +181,28 @@ SKIP: { $cmd->stderr_is_eq("fping: -g works only with IPv4 addresses\n"); } +# fping -g (range - no IPv6 generator - start address IPv6) +SKIP: { + if($ENV{SKIP_IPV6}) { + skip 'Skip IPv6 tests', 3; + } + my $cmd = Test::Command->new(cmd => "fping -6 -g ::1 127.0.0.1"); + $cmd->exit_is_num(1); + $cmd->stdout_is_eq(""); + $cmd->stderr_is_eq("fping: -g works only with IPv4 addresses\n"); +} + +# fping -g (range - no IPv6 generator - end address IPv6) +SKIP: { + if($ENV{SKIP_IPV6}) { + skip 'Skip IPv6 tests', 3; + } + my $cmd = Test::Command->new(cmd => "fping -6 -g 127.0.0.1 ::1"); + $cmd->exit_is_num(1); + $cmd->stdout_is_eq(""); + $cmd->stderr_is_eq("fping: -g works only with IPv4 addresses\n"); +} + # fping -g (CIDR - no IPv6 generator) SKIP: { if($ENV{SKIP_IPV6}) {