mirror of
https://git.openafs.org/openafs.git
synced 2025-01-18 23:10:58 +00:00
4514dbb1c4
We don't have a man page for the 'version' subcommand, which has "always" been present but only recently was exposed to the usage. It's okay to not have a man page for it, so tell the test infrastructure to not complain about its absence. Change-Id: Ife834d41797d1d1efe403b204736ac85d62724e9 Reviewed-on: http://gerrit.openafs.org/11452 Tested-by: BuildBot <buildbot@rampaginggeek.com> Reviewed-by: Jeffrey Altman <jaltman@your-file-system.com> Reviewed-by: D Brashear <shadow@your-file-system.com> Tested-by: D Brashear <shadow@your-file-system.com>
93 lines
2.5 KiB
Perl
93 lines
2.5 KiB
Perl
#
|
|
# This is probably horrific code to any Perl coder. I'm sorry,
|
|
# I'm not one. It runs.
|
|
#
|
|
# Proposed Coding Standard:
|
|
#
|
|
# * Subroutines starting with test_ should be TAP tests
|
|
# utilizing ok(), is(), etc... and return the number
|
|
# of tests run if they get that far (could exit early
|
|
# from a BAIL_OUT())
|
|
#
|
|
use File::Basename;
|
|
use Test::More;
|
|
|
|
sub check_command_binary {
|
|
my $c = shift(@_);
|
|
if (! -e "$c") {
|
|
BAIL_OUT("Cannot find $c");
|
|
}
|
|
}
|
|
|
|
#
|
|
# Run the command help to determine the list of sub-commands.
|
|
#
|
|
sub lookup_sub_commands {
|
|
my ($srcdir, $command) = @_;
|
|
|
|
my $fullpathcommand = "$srcdir/$command";
|
|
check_command_binary($fullpathcommand);
|
|
|
|
# build up our list of available commands from the help output
|
|
open(HELPOUT, "$fullpathcommand help 2>&1 |") or BAIL_OUT("can't fork: $!");
|
|
my @subcommlist;
|
|
my @comm;
|
|
while (<HELPOUT>) {
|
|
# Skip the header thingy
|
|
next if /Commands are/;
|
|
# Skip the version subcommand, it's always present but not interesting
|
|
next if /^version/;
|
|
@comm = split();
|
|
push(@subcommlist, $comm[0]);
|
|
}
|
|
close HELPOUT;
|
|
@subcommlist = sort(@subcommlist);
|
|
return @subcommlist;
|
|
}
|
|
|
|
# TAP test: test_command_man_pages
|
|
#
|
|
# Test if a man page exists for each command sub-command.
|
|
# Runs one test per sub-command.
|
|
#
|
|
# Arguments:
|
|
#
|
|
# builddir : A path to the OpenAFS build directory,
|
|
# such as /tmp/1.4.14
|
|
#
|
|
# command : the name of the command (e.g. vos)
|
|
#
|
|
# subcommlist : a list of sub-commands for command
|
|
#
|
|
sub test_command_man_pages {
|
|
my ($builddir, $command, @subcommlist) = @_;
|
|
|
|
# The following is because File::Find makes no sense to me
|
|
# for this purpose, and actually seems totally misnamed
|
|
my $found = 0;
|
|
my $subcommand = "";
|
|
my $frex = "";
|
|
# Since we don't know what man section it might be in,
|
|
# search all existing man page files for a filename match
|
|
my @mandirglob = glob("$builddir/doc/man-pages/man[1-8]/*");
|
|
# For every subcommand, see if command_subcommand.[1-8] exists
|
|
# in our man page build dir.
|
|
foreach (@subcommlist) {
|
|
my $subcommand = $_;
|
|
$found = 0;
|
|
my $frex = $command . '_' . $subcommand . '.[1-8]';
|
|
# diag("Looking for $frex");
|
|
foreach my $x (@mandirglob) {
|
|
# diag("TRYING: $x");
|
|
$x = basename($x);
|
|
if ($x =~ /$frex$/) {
|
|
# diag("FOUND");
|
|
$found = 1;
|
|
last;
|
|
}
|
|
}
|
|
ok($found eq 1, "existence of man page for $command" . "_$subcommand");
|
|
}
|
|
}
|
|
1;
|