diff options
Diffstat (limited to 'tests/tap/perl/Test/RRA/Config.pm')
| -rw-r--r-- | tests/tap/perl/Test/RRA/Config.pm | 138 | 
1 files changed, 70 insertions, 68 deletions
| diff --git a/tests/tap/perl/Test/RRA/Config.pm b/tests/tap/perl/Test/RRA/Config.pm index 3e77650..a5b0d0d 100644 --- a/tests/tap/perl/Test/RRA/Config.pm +++ b/tests/tap/perl/Test/RRA/Config.pm @@ -4,9 +4,6 @@  # configuration file to store some package-specific data.  This module loads  # that configuration and provides the namespace for the configuration  # settings. -# -# The canonical version of this file is maintained in the rra-c-util package, -# which can be found at <http://www.eyrie.org/~eagle/software/rra-c-util/>.  package Test::RRA::Config; @@ -30,22 +27,23 @@ BEGIN {      @ISA       = qw(Exporter);      @EXPORT_OK = qw(        $COVERAGE_LEVEL @COVERAGE_SKIP_TESTS @CRITIC_IGNORE $LIBRARY_PATH -      $MINIMUM_VERSION %MINIMUM_VERSION @POD_COVERAGE_EXCLUDE @STRICT_IGNORE -      @STRICT_PREREQ +      $MINIMUM_VERSION %MINIMUM_VERSION @MODULE_VERSION_IGNORE +      @POD_COVERAGE_EXCLUDE @STRICT_IGNORE @STRICT_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.05'; +    $VERSION = '5.10';  }  # 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.  Don't use Test::RRA::Automake since it may -# not exist. +# 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') { +for my $base ($ENV{BUILD}, $ENV{SOURCE}, 't', 'tests') {      next if !defined($base);      my $path = "$base/data/perl.conf";      if (-r $path) { @@ -64,6 +62,7 @@ our @CRITIC_IGNORE;  our $LIBRARY_PATH;  our $MINIMUM_VERSION = '5.008';  our %MINIMUM_VERSION; +our @MODULE_VERSION_IGNORE;  our @POD_COVERAGE_EXCLUDE;  our @STRICT_IGNORE;  our @STRICT_PREREQ; @@ -78,8 +77,8 @@ if (!do($PATH)) {  __END__  =for stopwords -Allbery rra-c-util Automake perlcritic .libs namespace subdirectory -sublicense MERCHANTABILITY NONINFRINGEMENT +Allbery rra-c-util Automake perlcritic .libs namespace subdirectory sublicense +MERCHANTABILITY NONINFRINGEMENT regexes  =head1 NAME @@ -92,19 +91,17 @@ Test::RRA::Config - Perl test configuration  =head1 DESCRIPTION -Test::RRA::Config encapsulates per-package configuration for generic Perl -test programs that are shared between multiple packages using the -rra-c-util infrastructure.  It handles locating and loading the test -configuration file for both C Automake packages and stand-alone Perl -modules. +Test::RRA::Config encapsulates per-package configuration for generic Perl test +programs that are shared between multiple packages using the rra-c-util +infrastructure.  It handles locating and loading the test configuration file +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. +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.  The following variables are supported: @@ -112,70 +109,75 @@ The following variables are supported:  =item $COVERAGE_LEVEL -The coverage level achieved by the test suite for Perl test coverage -testing using Test::Strict, as a percentage.  The test will fail if test -coverage less than this percentage is achieved.  If not given, defaults -to 100. +The coverage level achieved by the test suite for Perl test coverage testing +using Test::Strict, as a percentage.  The test will fail if test coverage less +than this percentage is achieved.  If not given, defaults to 100.  =item @COVERAGE_SKIP_TESTS  Directories under F<t> whose tests should be skipped when doing coverage -testing.  This can be tests that won't contribute to coverage or tests -that don't run properly under Devel::Cover for some reason (such as ones -that use taint checking).  F<docs> and F<style> will always be skipped -regardless of this setting. +testing.  This can be tests that won't contribute to coverage or tests that +don't run properly under Devel::Cover for some reason (such as ones that use +taint checking).  F<docs> and F<style> will always be skipped regardless of +this setting.  =item @CRITIC_IGNORE -Additional directories to ignore when doing recursive perlcritic testing. -The contents of this directory must be either top-level directory names or +Additional directories to ignore when doing recursive perlcritic testing.  The +contents of this directory must be either top-level directory names or  directory names starting with F<tests/>.  =item $LIBRARY_PATH  Add this directory (or a F<.libs> subdirectory) relative to the top of the -source tree to LD_LIBRARY_PATH when checking the syntax of Perl modules. -This may be required to pick up libraries that are used by in-tree Perl -modules so that Perl scripts can pass a syntax check. +source tree to LD_LIBRARY_PATH when checking the syntax of Perl modules.  This +may be required to pick up libraries that are used by in-tree Perl modules so +that Perl scripts can pass a syntax check.  =item $MINIMUM_VERSION -Default minimum version requirement for included Perl scripts.  If not -given, defaults to 5.008. +Default minimum version requirement for included Perl scripts.  If not given, +defaults to 5.008.  =item %MINIMUM_VERSION  Minimum version exceptions for specific directories.  The keys should be  minimum versions of Perl to enforce.  The value for each key should be a -reference to an array of either top-level directory names or directory -names starting with F<tests/>.  All files in those directories will have -that minimum Perl version constraint imposed instead of $MINIMUM_VERSION. +reference to an array of either top-level directory names or directory names +starting with F<tests/>.  All files in those directories will have that +minimum Perl version constraint imposed instead of $MINIMUM_VERSION. + +=item @MODULE_VERSION_IGNORE + +File names to ignore when checking that all modules in a distribution have the +same version.  Sometimes, some specific modules need separate, special version +handling, such as modules defining database schemata for DBIx::Class, and +can't follow the version of the larger package.  =item @POD_COVERAGE_EXCLUDE  Regexes that match method names that should be excluded from POD coverage -testing.  Normally, all methods have to be documented in the POD for a -Perl module, but methods matching any of these regexes will be considered -private and won't require documentation. +testing.  Normally, all methods have to be documented in the POD for a Perl +module, but methods matching any of these regexes will be considered private +and won't require documentation.  =item @STRICT_IGNORE -Additional directories to ignore when doing recursive Test::Strict testing -for C<use strict> and C<use warnings>.  The contents of this directory -must be either top-level directory names or directory names starting with -F<tests/>. +Additional directories to ignore when doing recursive Test::Strict testing for +C<use strict> and C<use warnings>.  The contents of this directory must be +either top-level directory names or directory names starting with F<tests/>.  =item @STRICT_PREREQ  A list of Perl modules that have to be available in order to do meaningful  Test::Strict testing.  If any of the modules cannot be loaded via C<use>, -Test::Strict checking will be skipped.  There is currently no way to -require specific versions of the modules. +Test::Strict checking will be skipped.  There is currently no way to require +specific versions of the modules.  =back -No variables are exported by default, but the variables can be imported -into the local namespace to avoid long variable names. +No variables are exported by default, but the variables can be imported into +the local namespace to avoid long variable names.  =head1 AUTHOR @@ -186,31 +188,31 @@ Russ Allbery <eagle@eyrie.org>  Copyright 2013, 2014 The Board of Trustees of the Leland Stanford Junior  University -Permission is hereby granted, free of charge, to any person obtaining a -copy of this software and associated documentation files (the "Software"), -to deal in the Software without restriction, including without limitation -the rights to use, copy, modify, merge, publish, distribute, sublicense, -and/or sell copies of the Software, and to permit persons to whom the -Software is furnished to do so, subject to the following conditions: +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software.  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL -THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING -FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER -DEALINGS IN THE SOFTWARE. +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE.  =head1 SEE ALSO -perlcritic(1), Test::MinimumVersion(3), Test::RRA(3), -Test::RRA::Automake(3), Test::Strict(3) +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/>. +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/>.  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/>. | 
