diff options
| author | Russ Allbery <eagle@eyrie.org> | 2018-06-03 16:58:02 -0700 | 
|---|---|---|
| committer | Russ Allbery <eagle@eyrie.org> | 2018-06-03 16:58:02 -0700 | 
| commit | edf31eba414d9a105791c076fb1444a78d210dff (patch) | |
| tree | 2bac18fa3b71593e616061a0fbcbfdd6ab26a255 /tests/tap/perl | |
| parent | 4b3f858ef567c0d12511e7fea2a56f08f2729635 (diff) | |
| parent | 68c4b05c268cd6e358cc41c8feb44bc2c7fcb898 (diff) | |
New upstream version 1.4
Diffstat (limited to 'tests/tap/perl')
| -rw-r--r-- | tests/tap/perl/Test/RRA.pm | 57 | ||||
| -rw-r--r-- | tests/tap/perl/Test/RRA/Automake.pm | 191 | ||||
| -rw-r--r-- | tests/tap/perl/Test/RRA/Config.pm | 36 | ||||
| -rw-r--r-- | tests/tap/perl/Test/RRA/ModuleVersion.pm | 10 | 
4 files changed, 224 insertions, 70 deletions
| diff --git a/tests/tap/perl/Test/RRA.pm b/tests/tap/perl/Test/RRA.pm index 8608e31..807508c 100644 --- a/tests/tap/perl/Test/RRA.pm +++ b/tests/tap/perl/Test/RRA.pm @@ -5,6 +5,8 @@  # by both C packages with Automake and by stand-alone Perl modules.  See  # Test::RRA::Automake for additional functions specifically for C Automake  # distributions. +# +# SPDX-License-Identifier: MIT  package Test::RRA; @@ -13,6 +15,7 @@ use strict;  use warnings;  use Exporter; +use File::Temp;  use Test::More;  # For Perl 5.006 compatibility. @@ -26,12 +29,56 @@ our (@EXPORT_OK, @ISA, $VERSION);  # consistency is good).  BEGIN {      @ISA       = qw(Exporter); -    @EXPORT_OK = qw(skip_unless_author skip_unless_automated use_prereq); +    @EXPORT_OK = qw( +      is_file_contents skip_unless_author skip_unless_automated use_prereq +    );      # This version should match the corresponding rra-c-util release, but with      # two digits for the minor version, including a leading zero if necessary,      # so that it will sort properly. -    $VERSION = '5.10'; +    $VERSION = '7.02'; +} + +# Compare a string to the contents of a file, similar to the standard is() +# function, but to show the line-based unified diff between them if they +# differ. +# +# $got      - The output that we received +# $expected - The path to the file containing the expected output +# $message  - The message to use when reporting the test results +# +# Returns: undef +#  Throws: Exception on failure to read or write files or run diff +sub is_file_contents { +    my ($got, $expected, $message) = @_; + +    # If they're equal, this is simple. +    open(my $fh, '<', $expected) or BAIL_OUT("Cannot open $expected: $!\n"); +    my $data = do { local $/ = undef; <$fh> }; +    close($fh) or BAIL_OUT("Cannot close $expected: $!\n"); +    if ($got eq $data) { +        is($got, $data, $message); +        return; +    } + +    # Otherwise, we show a diff, but only if we have IPC::System::Simple. +    eval { require IPC::System::Simple }; +    if ($@) { +        ok(0, $message); +        return; +    } + +    # They're not equal.  Write out what we got so that we can run diff. +    my $tmp     = File::Temp->new(); +    my $tmpname = $tmp->filename; +    print {$tmp} $got or BAIL_OUT("Cannot write to $tmpname: $!\n"); +    my @command = ('diff', '-u', $expected, $tmpname); +    my $diff = IPC::System::Simple::capturex([0 .. 1], @command); +    diag($diff); + +    # Remove the temporary file and report failure. +    ok(0, $message); +    return;  }  # Skip this test unless author tests are requested.  Takes a short description @@ -225,10 +272,14 @@ SOFTWARE.  Test::More(3), Test::RRA::Automake(3), Test::RRA::Config(3)  This module is maintained in the rra-c-util package.  The current version is -available from L<http://www.eyrie.org/~eagle/software/rra-c-util/>. +available from L<https://www.eyrie.org/~eagle/software/rra-c-util/>.  The functions to control when tests are run use environment variables defined  by the L<Lancaster  Consensus|https://github.com/Perl-Toolchain-Gang/toolchain-site/blob/master/lancaster-consensus.md>.  =cut + +# Local Variables: +# copyright-at-end-flag: t +# End: diff --git a/tests/tap/perl/Test/RRA/Automake.pm b/tests/tap/perl/Test/RRA/Automake.pm index c6399ec..e4db56c 100644 --- a/tests/tap/perl/Test/RRA/Automake.pm +++ b/tests/tap/perl/Test/RRA/Automake.pm @@ -7,8 +7,11 @@  # require closely following the conventions implemented by the rra-c-util  # utility collection.  # -# All the functions here assume that BUILD and SOURCE are set in the -# environment.  This is normally done via the C TAP Harness runtests wrapper. +# All the functions here assume that C_TAP_BUILD and C_TAP_SOURCE are set in +# the environment.  This is normally done via the C TAP Harness runtests +# wrapper. +# +# SPDX-License-Identifier: MIT  package Test::RRA::Automake; @@ -20,6 +23,7 @@ use warnings;  ## no critic (ClassHierarchies::ProhibitExplicitISA)  use Exporter; +use File::Find qw(find);  use File::Spec;  use Test::More;  use Test::RRA::Config qw($LIBRARY_PATH); @@ -34,9 +38,9 @@ BEGIN {      $PERL_BLIB_ARCH = File::Spec->catdir(qw(perl blib arch));      $PERL_BLIB_LIB  = File::Spec->catdir(qw(perl blib lib)); -    # If BUILD is set, we can come up with better values. -    if (defined($ENV{BUILD})) { -        my ($vol, $dirs) = File::Spec->splitpath($ENV{BUILD}, 1); +    # If C_TAP_BUILD is set, we can come up with better values. +    if (defined($ENV{C_TAP_BUILD})) { +        my ($vol, $dirs) = File::Spec->splitpath($ENV{C_TAP_BUILD}, 1);          my @dirs = File::Spec->splitdir($dirs);          pop(@dirs);          $PERL_BLIB_ARCH = File::Spec->catdir(@dirs, qw(perl blib arch)); @@ -57,47 +61,95 @@ our (@EXPORT_OK, @ISA, $VERSION);  # consistency is good).  BEGIN {      @ISA       = qw(Exporter); -    @EXPORT_OK = qw(automake_setup perl_dirs test_file_path test_tmpdir); +    @EXPORT_OK = qw( +      all_files automake_setup perl_dirs test_file_path test_tmpdir +    );      # This version should match the corresponding rra-c-util release, but with      # two digits for the minor version, including a leading zero if necessary,      # so that it will sort properly. -    $VERSION = '5.10'; +    $VERSION = '7.02';  } -# Perl directories to skip globally for perl_dirs.  We ignore the perl -# directory if it exists since, in my packages, it is treated as a Perl module -# distribution and has its own standalone test suite. -my @GLOBAL_SKIP = qw(.git _build perl); +# Directories to skip globally when looking for all files, or for directories +# that could contain Perl files. +my @GLOBAL_SKIP = qw( +  .git _build autom4te.cache build-aux perl/_build perl/blib +); + +# Additional paths to skip when building a list of all files in the +# distribution.  This primarily skips build artifacts that aren't interesting +# to any of the tests.  These match any path component. +my @FILES_SKIP = qw( +  .deps .dirstamp .libs aclocal.m4 config.h config.h.in config.h.in~ config.log +  config.status configure +);  # The temporary directory created by test_tmpdir, if any.  If this is set,  # attempt to remove the directory stored here on program exit (but ignore  # failure to do so).  my $TMPDIR; +# Returns a list of all files in the distribution. +# +# Returns: List of files +sub all_files { +    my @files; + +    # Turn the skip lists into hashes for ease of querying. +    my %skip       = map { $_ => 1 } @GLOBAL_SKIP; +    my %files_skip = map { $_ => 1 } @FILES_SKIP; + +    # Wanted function for find.  Prune anything matching either of the skip +    # lists, or *.lo files, and then add all regular files to the list. +    my $wanted = sub { +        my $file = $_; +        my $path = $File::Find::name; +        $path =~ s{ \A [.]/ }{}xms; +        if ($skip{$path} || $files_skip{$file} || $file =~ m{ [.] lo \z }xms) { +            $File::Find::prune = 1; +            return; +        } +        if (-f $file) { +            push(@files, $path); +        } +    }; + +    # Do the recursive search and return the results. +    find($wanted, q{.}); +    return @files; +} +  # Perform initial test setup for running a Perl test in an Automake package. -# This verifies that BUILD and SOURCE are set and then changes directory to -# the SOURCE directory by default.  Sets LD_LIBRARY_PATH if the $LIBRARY_PATH -# configuration option is set.  Calls BAIL_OUT if BUILD or SOURCE are missing -# or if anything else fails. +# This verifies that C_TAP_BUILD and C_TAP_SOURCE are set and then changes +# directory to the C_TAP_SOURCE directory by default.  Sets LD_LIBRARY_PATH if +# the $LIBRARY_PATH configuration option is set.  Calls BAIL_OUT if +# C_TAP_BUILD or C_TAP_SOURCE are missing or if anything else fails.  #  # $args_ref - Reference to a hash of arguments to configure behavior: -#   chdir_build - If set to a true value, changes to BUILD instead of SOURCE +#   chdir_build - If set to a true value, changes to C_TAP_BUILD instead of +#                 C_TAP_SOURCE  #  # Returns: undef  sub automake_setup {      my ($args_ref) = @_; -    # Bail if BUILD or SOURCE are not set. -    if (!$ENV{BUILD}) { -        BAIL_OUT('BUILD not defined (run under runtests)'); +    # Bail if C_TAP_BUILD or C_TAP_SOURCE are not set. +    if (!$ENV{C_TAP_BUILD}) { +        BAIL_OUT('C_TAP_BUILD not defined (run under runtests)');      } -    if (!$ENV{SOURCE}) { -        BAIL_OUT('SOURCE not defined (run under runtests)'); +    if (!$ENV{C_TAP_SOURCE}) { +        BAIL_OUT('C_TAP_SOURCE not defined (run under runtests)');      } -    # BUILD or SOURCE will be the test directory.  Change to the parent. -    my $start = $args_ref->{chdir_build} ? $ENV{BUILD} : $ENV{SOURCE}; +    # C_TAP_BUILD or C_TAP_SOURCE will be the test directory.  Change to the +    # parent. +    my $start; +    if ($args_ref->{chdir_build}) { +        $start = $ENV{C_TAP_BUILD}; +    } else { +        $start = $ENV{C_TAP_SOURCE}; +    }      my ($vol, $dirs) = File::Spec->splitpath($start, 1);      my @dirs = File::Spec->splitdir($dirs);      pop(@dirs); @@ -116,8 +168,9 @@ sub automake_setup {      my $root = File::Spec->catpath($vol, File::Spec->catdir(@dirs), q{});      chdir($root) or BAIL_OUT("cannot chdir to $root: $!"); -    # If BUILD is a subdirectory of SOURCE, add it to the global ignore list. -    my ($buildvol, $builddirs) = File::Spec->splitpath($ENV{BUILD}, 1); +    # If C_TAP_BUILD is a subdirectory of C_TAP_SOURCE, add it to the global +    # ignore list. +    my ($buildvol, $builddirs) = File::Spec->splitpath($ENV{C_TAP_BUILD}, 1);      my @builddirs = File::Spec->splitdir($builddirs);      pop(@builddirs);      if ($buildvol eq $vol && @builddirs == @dirs + 1) { @@ -162,9 +215,11 @@ sub automake_setup {  sub perl_dirs {      my ($args_ref) = @_; -    # Add the global skip list. +    # Add the global skip list.  We also ignore the perl directory if it +    # exists since, in my packages, it is treated as a Perl module +    # distribution and has its own standalone test suite.      my @skip = $args_ref->{skip} ? @{ $args_ref->{skip} } : (); -    push(@skip, @GLOBAL_SKIP); +    push(@skip, @GLOBAL_SKIP, 'perl');      # Separate directories to skip under tests from top-level directories.      my @skip_tests = grep { m{ \A tests/ }xms } @skip; @@ -206,9 +261,9 @@ sub perl_dirs {      return @dirs;  } -# Find a configuration file for the test suite.  Searches relative to BUILD -# first and then SOURCE and returns whichever is found first.  Calls BAIL_OUT -# if the file could not be found. +# Find a configuration file for the test suite.  Searches relative to +# C_TAP_BUILD first and then C_TAP_SOURCE and returns whichever is found +# first.  Calls BAIL_OUT if the file could not be found.  #  # $file - Partial path to the file  # @@ -216,7 +271,7 @@ sub perl_dirs {  sub test_file_path {      my ($file) = @_;    BASE: -    for my $base ($ENV{BUILD}, $ENV{SOURCE}) { +    for my $base ($ENV{C_TAP_BUILD}, $ENV{C_TAP_SOURCE}) {          next if !defined($base);          if (-f "$base/$file") {              return "$base/$file"; @@ -236,11 +291,16 @@ sub test_tmpdir {      my $path;      # If we already figured out what directory to use, reuse the same path. -    # Otherwise, create a directory relative to BUILD if set. +    # Otherwise, create a directory relative to C_TAP_BUILD if set.      if (defined($TMPDIR)) {          $path = $TMPDIR;      } else { -        my $base = defined($ENV{BUILD}) ? $ENV{BUILD} : File::Spec->curdir; +        my $base; +        if (defined($ENV{C_TAP_BUILD})) { +            $base = $ENV{C_TAP_BUILD}; +        } else { +            $base = File::Spec->curdir; +        }          $path = File::Spec->catdir($base, 'tmp');      } @@ -297,11 +357,11 @@ layout of a package that uses rra-c-util and C TAP Harness for the test  structure.  Loading this module will also add the directories C<perl/blib/arch> and -C<perl/blib/lib> to the Perl library search path, relative to BUILD if that -environment variable is set.  This is harmless for C Automake projects that -don't contain an embedded Perl module, and for those projects that do, this -will allow subsequent C<use> calls to find modules that are built as part of -the package build process. +C<perl/blib/lib> to the Perl library search path, relative to C_TAP_BUILD if +that environment variable is set.  This is harmless for C Automake projects +that don't contain an embedded Perl module, and for those projects that do, +this will allow subsequent C<use> calls to find modules that are built as part +of the package build process.  The automake_setup() function should be called before calling any other  functions provided by this module. @@ -314,11 +374,20 @@ BAIL_OUT (from Test::More).  =over 4 +=item all_files() + +Returns a list of all "interesting" files in the distribution that a test +suite may want to look at.  This excludes various products of the build system, +the build directory if it's under the source directory, and a few other +uninteresting directories like F<.git>.  The returned paths will be paths +relative to the root of the package. +  =item automake_setup([ARGS]) -Verifies that the BUILD and SOURCE environment variables are set and then -changes directory to the top of the source tree (which is one directory up -from the SOURCE path, since SOURCE points to the top of the tests directory). +Verifies that the C_TAP_BUILD and C_TAP_SOURCE environment variables are set +and then changes directory to the top of the source tree (which is one +directory up from the C_TAP_SOURCE path, since C_TAP_SOURCE points to the top +of the tests directory).  If ARGS is given, it should be a reference to a hash of configuration options.  Only one option is supported: C<chdir_build>.  If it is set to a true value, @@ -343,30 +412,46 @@ C<tests/> that should be skipped.  Given FILE, which should be a relative path, locates that file relative to the  test directory in either the source or build tree.  FILE will be checked for -relative to the environment variable BUILD first, and then relative to SOURCE. -test_file_path() returns the full path to FILE or calls BAIL_OUT if FILE could -not be found. +relative to the environment variable C_TAP_BUILD first, and then relative to +C_TAP_SOURCE.  test_file_path() returns the full path to FILE or calls +BAIL_OUT if FILE could not be found.  =item test_tmpdir()  Create a temporary directory for tests to use for transient files and return -the path to that directory.  The directory is created relative to the BUILD -environment variable, which must be set.  Permissions on the directory are set -using the current umask.  test_tmpdir() returns the full path to the temporary -directory or calls BAIL_OUT if it could not be created. +the path to that directory.  The directory is created relative to the +C_TAP_BUILD environment variable, which must be set.  Permissions on the +directory are set using the current umask.  test_tmpdir() returns the full +path to the temporary directory or calls BAIL_OUT if it could not be created.  The directory is automatically removed if possible on program exit.  Failure  to remove the directory on exit is reported with diag() and otherwise ignored.  =back +=head1 ENVIRONMENT + +=over 4 + +=item C_TAP_BUILD + +The root of the tests directory in Automake build directory for this package, +used to find files as documented above. + +=item C_TAP_SOURCE + +The root of the tests directory in the source tree for this package, used to +find files as documented above. + +=back +  =head1 AUTHOR  Russ Allbery <eagle@eyrie.org>  =head1 COPYRIGHT AND LICENSE -Copyright 2014, 2015 Russ Allbery <eagle@eyrie.org> +Copyright 2014, 2015, 2018 Russ Allbery <eagle@eyrie.org>  Copyright 2013 The Board of Trustees of the Leland Stanford Junior University @@ -393,9 +478,13 @@ SOFTWARE.  Test::More(3), Test::RRA(3), Test::RRA::Config(3)  This module is maintained in the rra-c-util package.  The current version is -available from L<http://www.eyrie.org/~eagle/software/rra-c-util/>. +available from L<https://www.eyrie.org/~eagle/software/rra-c-util/>.  The C TAP Harness test driver and libraries for TAP-based C testing are -available from L<http://www.eyrie.org/~eagle/software/c-tap-harness/>. +available from L<https://www.eyrie.org/~eagle/software/c-tap-harness/>.  =cut + +# Local Variables: +# copyright-at-end-flag: t +# End: diff --git a/tests/tap/perl/Test/RRA/Config.pm b/tests/tap/perl/Test/RRA/Config.pm index a5b0d0d..7cb0916 100644 --- a/tests/tap/perl/Test/RRA/Config.pm +++ b/tests/tap/perl/Test/RRA/Config.pm @@ -4,6 +4,8 @@  # configuration file to store some package-specific data.  This module loads  # that configuration and provides the namespace for the configuration  # settings. +# +# SPDX-License-Identifier: MIT  package Test::RRA::Config; @@ -34,16 +36,16 @@ BEGIN {      # This version should match the corresponding rra-c-util release, but with      # two digits for the minor version, including a leading zero if necessary,      # so that it will sort properly. -    $VERSION = '5.10'; +    $VERSION = '7.02';  } -# If BUILD or SOURCE are set in the environment, look for data/perl.conf under -# those paths for a C Automake package.  Otherwise, look in t/data/perl.conf -# for a standalone Perl module or tests/data/perl.conf for Perl tests embedded -# in a larger distribution.  Don't use Test::RRA::Automake since it may not -# exist. +# If C_TAP_BUILD or C_TAP_SOURCE are set in the environment, look for +# data/perl.conf under those paths for a C Automake package.  Otherwise, look +# in t/data/perl.conf for a standalone Perl module or tests/data/perl.conf for +# Perl tests embedded in a larger distribution.  Don't use Test::RRA::Automake +# since it may not exist.  our $PATH; -for my $base ($ENV{BUILD}, $ENV{SOURCE}, 't', 'tests') { +for my $base ($ENV{C_TAP_BUILD}, $ENV{C_TAP_SOURCE}, './t', './tests') {      next if !defined($base);      my $path = "$base/data/perl.conf";      if (-r $path) { @@ -70,7 +72,7 @@ our @STRICT_PREREQ;  # Load the configuration.  if (!do($PATH)) {      my $error = $@ || $! || 'loading file did not return true'; -    BAIL_OUT("cannot load data/perl.conf: $error"); +    BAIL_OUT("cannot load $PATH: $error");  }  1; @@ -98,10 +100,10 @@ for both C Automake packages and stand-alone Perl modules.  Test::RRA::Config looks for a file named F<data/perl.conf> relative to the  root of the test directory.  That root is taken from the environment variables -BUILD or SOURCE (in that order) if set, which will be the case for C Automake -packages using C TAP Harness.  If neither is set, it expects the root of the -test directory to be a directory named F<t> relative to the current directory, -which will be the case for stand-alone Perl modules. +C_TAP_BUILD or C_TAP_SOURCE (in that order) if set, which will be the case for +C Automake packages using C TAP Harness.  If neither is set, it expects the +root of the test directory to be a directory named F<t> relative to the +current directory, which will be the case for stand-alone Perl modules.  The following variables are supported: @@ -185,6 +187,8 @@ Russ Allbery <eagle@eyrie.org>  =head1 COPYRIGHT AND LICENSE +Copyright 2015, 2016 Russ Allbery <eagle@eyrie.org> +  Copyright 2013, 2014 The Board of Trustees of the Leland Stanford Junior  University @@ -212,9 +216,13 @@ perlcritic(1), Test::MinimumVersion(3), Test::RRA(3), Test::RRA::Automake(3),  Test::Strict(3)  This module is maintained in the rra-c-util package.  The current version is -available from L<http://www.eyrie.org/~eagle/software/rra-c-util/>. +available from L<https://www.eyrie.org/~eagle/software/rra-c-util/>.  The C TAP Harness test driver and libraries for TAP-based C testing are -available from L<http://www.eyrie.org/~eagle/software/c-tap-harness/>. +available from L<https://www.eyrie.org/~eagle/software/c-tap-harness/>.  =cut + +# Local Variables: +# copyright-at-end-flag: t +# End: diff --git a/tests/tap/perl/Test/RRA/ModuleVersion.pm b/tests/tap/perl/Test/RRA/ModuleVersion.pm index f02877a..49acac4 100644 --- a/tests/tap/perl/Test/RRA/ModuleVersion.pm +++ b/tests/tap/perl/Test/RRA/ModuleVersion.pm @@ -3,6 +3,8 @@  # This module contains the common code for testing and updating Perl module  # versions for consistency within a Perl module distribution and within a  # larger package that contains both Perl modules and other code. +# +# SPDX-License-Identifier: MIT  package Test::RRA::ModuleVersion; @@ -31,7 +33,7 @@ BEGIN {      # This version should match the corresponding rra-c-util release, but with      # two digits for the minor version, including a leading zero if necessary,      # so that it will sort properly. -    $VERSION = '5.10'; +    $VERSION = '7.02';  }  # A regular expression matching the version string for a module using the @@ -290,6 +292,10 @@ SOFTWARE.  Test::More(3), Test::RRA::Config(3)  This module is maintained in the rra-c-util package.  The current version -is available from L<http://www.eyrie.org/~eagle/software/rra-c-util/>. +is available from L<https://www.eyrie.org/~eagle/software/rra-c-util/>.  =cut + +# Local Variables: +# copyright-at-end-flag: t +# End: | 
