Merge branch 'develop' of github.com:schweikert/fping into develop

pull/145/head
David Schweikert 6 years ago
commit a74d32cfb1

@ -1,6 +1,11 @@
fping 4.2 (UNRELEASED)
======================
## New features
- New option -x / --reachable to check if the number of reachable hosts is >= a certain
number. Useful for example to implement connectivity-checks (#138, thanks @deepak0004)
## Bugfixes and other changes
- Allow decimal numbers for '-t', '-i', '-p', and '-Q'

@ -1,6 +1,6 @@
#!/usr/bin/perl -w
use Test::Command tests => 6;
use Test::Command tests => 12;
# -u show targets that are unreachable
# -v show version
@ -22,3 +22,19 @@ fping: comments to david\@schweikert\.ch
});
$cmd->stderr_is_eq("");
}
# fping -x
{
my $cmd = Test::Command->new(cmd => "fping -x 1 8.8.0.0 127.0.0.1");
$cmd->exit_is_num(0);
$cmd->stdout_is_eq("Enough hosts reachable (required: 1, reachable: 1)\n");
$cmd->stderr_is_eq("");
}
# fping -x
{
my $cmd = Test::Command->new(cmd => "fping -x 2 8.8.0.0 127.0.0.1");
$cmd->exit_is_num(1);
$cmd->stdout_is_eq("Not enough hosts reachable (required: 2, reachable: 1)\n");
$cmd->stderr_is_eq("");
}

@ -225,6 +225,11 @@ Show targets that are unreachable.
Print B<fping> version information.
=item B<-x>, B<--reachable>=I<N>
Given a list of hosts, this mode checks if number of reachable hosts is >= N
and exits true in that case.
=back
=head1 EXAMPLES

@ -248,7 +248,7 @@ unsigned int interval = DEFAULT_INTERVAL * 100;
unsigned int perhost_interval = DEFAULT_PERHOST_INTERVAL * 100;
float backoff = DEFAULT_BACKOFF_FACTOR;
unsigned int ping_data_size = DEFAULT_PING_DATA_SIZE;
unsigned int count = 1;
unsigned int count = 1, min_reachable = 0;
unsigned int trials;
unsigned int report_interval = 0;
unsigned int ttl = 0;
@ -419,6 +419,7 @@ int main(int argc, char** argv)
{ NULL, 'T', OPTPARSE_REQUIRED },
{ "unreach", 'u', OPTPARSE_NONE },
{ "version", 'v', OPTPARSE_NONE },
{ "reachable", 'x', OPTPARSE_REQUIRED },
{ 0, 0, 0 }
};
@ -623,6 +624,11 @@ int main(int argc, char** argv)
printf("%s: comments to %s\n", prog, EMAIL);
exit(0);
case 'x':
if (!(min_reachable = (unsigned int)atoi(optparse_state.optarg)))
usage(1);
break;
case 'f':
filename = optparse_state.optarg;
break;
@ -751,7 +757,7 @@ int main(int argc, char** argv)
exit(1);
}
if (alive_flag || unreachable_flag)
if (alive_flag || unreachable_flag || min_reachable)
verbose_flag = 0;
if (count_flag) {
@ -1342,6 +1348,16 @@ void finish()
if (stats_flag)
print_global_stats();
if (min_reachable) {
if ((num_hosts-num_unreachable) >= min_reachable) {
printf("Enough hosts reachable (required: %d, reachable: %d)\n", min_reachable, num_hosts-num_unreachable);
exit(0);
} else {
printf("Not enough hosts reachable (required: %d, reachable: %d)\n", min_reachable, num_hosts-num_unreachable);
exit(1);
}
}
if (num_noaddress)
exit(2);
else if (num_alive != num_hosts)
@ -2786,5 +2802,6 @@ void usage(int is_error)
fprintf(out, " -s, --stats print final stats\n");
fprintf(out, " -u, --unreach show targets that are unreachable\n");
fprintf(out, " -v, --version show version\n");
fprintf(out, " -x, --reachable=N shows if >=N hosts are reachable or not\n");
exit(is_error);
}

Loading…
Cancel
Save