summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/h2xs.t74
-rw-r--r--utils/h2xs.PL19
2 files changed, 80 insertions, 13 deletions
diff --git a/lib/h2xs.t b/lib/h2xs.t
index 1b26c89131..8ec241a37f 100644
--- a/lib/h2xs.t
+++ b/lib/h2xs.t
@@ -5,7 +5,9 @@
# hence are not checked. File existence is checked with -e though.
# This test depends on File::Path::rmtree() to clean up with.
# - pvhp
-
+#
+# We are now checking that the correct use $version; is present in
+# Makefile.PL and $module.pm
BEGIN {
chdir 't' if -d 't';
@INC = '../lib';
@@ -38,9 +40,14 @@ if ($^O eq 'MacOS') {
# not already be found in the t/ subdirectory for perl.
my $name = 'h2xst';
my $header = "$name.h";
+my $thisversion = sprintf "%vd", $^V;
my @tests = (
-"-f -n $name", <<"EOXSFILES",
+"-f -n $name", $], <<"EOXSFILES",
+Defaulting to backwards compatibility with perl $thisversion
+If you intend this module to be compatible with earlier perl versions, please
+specify a minimum perl version with the -b option.
+
Writing $name/$name.pm
Writing $name/$name.xs
Writing $name/fallback.c
@@ -52,7 +59,43 @@ Writing $name/Changes
Writing $name/MANIFEST
EOXSFILES
-"\"-X\" -f -n $name", <<"EONOXSFILES",
+"-f -n $name -b $thisversion", $], <<"EOXSFILES",
+Writing $name/$name.pm
+Writing $name/$name.xs
+Writing $name/fallback.c
+Writing $name/fallback.xs
+Writing $name/Makefile.PL
+Writing $name/README
+Writing $name/t/1.t
+Writing $name/Changes
+Writing $name/MANIFEST
+EOXSFILES
+
+"-f -n $name -b 5.6.1", "5.006001", <<"EOXSFILES",
+Writing $name/$name.pm
+Writing $name/$name.xs
+Writing $name/fallback.c
+Writing $name/fallback.xs
+Writing $name/Makefile.PL
+Writing $name/README
+Writing $name/t/1.t
+Writing $name/Changes
+Writing $name/MANIFEST
+EOXSFILES
+
+"-f -n $name -b 5.5.3", "5.00503", <<"EOXSFILES",
+Writing $name/$name.pm
+Writing $name/$name.xs
+Writing $name/fallback.c
+Writing $name/fallback.xs
+Writing $name/Makefile.PL
+Writing $name/README
+Writing $name/t/1.t
+Writing $name/Changes
+Writing $name/MANIFEST
+EOXSFILES
+
+"\"-X\" -f -n $name -b $thisversion", $], <<"EONOXSFILES",
Writing $name/$name.pm
Writing $name/Makefile.PL
Writing $name/README
@@ -61,7 +104,7 @@ Writing $name/Changes
Writing $name/MANIFEST
EONOXSFILES
-"-f -n $name $header", <<"EOXSFILES",
+"-f -n $name $header -b $thisversion", $], <<"EOXSFILES",
Writing $name/$name.pm
Writing $name/$name.xs
Writing $name/fallback.c
@@ -75,10 +118,11 @@ EOXSFILES
);
my $total_tests = 3; # opening, closing and deleting the header file.
-for (my $i = $#tests; $i > 0; $i-=2) {
+for (my $i = $#tests; $i > 0; $i-=3) {
# 1 test for running it, 1 test for the expected result, and 1 for each file
+ # plus 1 to open and 1 to check for the use in $name.pm and Makefile.PL
# use the () to force list context and hence count the number of matches.
- $total_tests += 2 + (() = $tests[$i] =~ /(Writing)/sg);
+ $total_tests += 6 + (() = $tests[$i] =~ /(Writing)/sg);
}
plan tests => $total_tests;
@@ -90,7 +134,7 @@ print HEADER <<HEADER or die $!;
HEADER
ok (close (HEADER));
-while (my ($args, $expectation) = splice @tests, 0, 2) {
+while (my ($args, $version, $expectation) = splice @tests, 0, 3) {
# h2xs warns about what it is writing hence the (possibly unportable)
# 2>&1 dupe:
# does it run?
@@ -109,9 +153,7 @@ while (my ($args, $expectation) = splice @tests, 0, 2) {
# Was the output the list of files that were expected?
ok ($result, $expectation, "running $prog");
- $expectation =~ s/Writing //; # remove leader
- foreach (split(/Writing /,$expectation)) {
- chomp; # remove \n
+ foreach ($expectation =~ /Writing\s+(\S+)/gm) {
if ($^O eq 'MacOS') {
$_ = ':' . join(':',split(/\//,$_));
$_ =~ s/$name:t:1.t/$name:t\/1.t/; # is this an h2xs bug?
@@ -119,6 +161,18 @@ while (my ($args, $expectation) = splice @tests, 0, 2) {
ok (-e $_, 1, "$_ missing");
}
+ foreach my $leaf ("$name.pm", 'Makefile.PL') {
+ my $file = ($^O eq 'MacOS') ? ":$name:$leaf" : "$name/$leaf";
+ if (ok (open (FILE, $file), 1, "open $file")) {
+ my $match = qr/use $version;/;
+ my $found;
+ while (<FILE>) {
+ last if $found = /$match/;
+ }
+ ok ($found, 1, "looking for /$match/ in $file");
+ close FILE or die "close $file: $!";
+ }
+ }
# clean up
rmtree($name);
}
diff --git a/utils/h2xs.PL b/utils/h2xs.PL
index b8b91e807f..100d6b113d 100644
--- a/utils/h2xs.PL
+++ b/utils/h2xs.PL
@@ -126,7 +126,8 @@ For versions < 5.6.0, the changes are.
- no 'use warnings'
Specifying a compatibility version higher than the version of perl you
-are using to run h2xs will have no effect.
+are using to run h2xs will have no effect. If unspecified h2xs will default
+to compatibility with the version of perl you are using to run h2xs.
=item B<-c>, B<--omit-constant>
@@ -551,8 +552,20 @@ if( $opt_b ){
usage "You must provide the backwards compatibility version in X.Y.Z form. "
. "(i.e. 5.5.0)\n";
my ($maj,$min,$sub) = split(/\./,$opt_b,3);
- $compat_version = sprintf("%d.%03d%02d",$maj,$min,$sub);
-}
+ if ($maj < 5 || ($maj == 5 && $min < 6)) {
+ $compat_version = sprintf("%d.%03d%02d",$maj,$min,$sub);
+ } else {
+ $compat_version = sprintf("%d.%03d%03d",$maj,$min,$sub);
+ }
+} else {
+ my ($maj,$min,$sub) = $compat_version =~ /(\d+)\.(\d\d\d)(\d\d\d?)/;
+ warn sprintf <<'EOF', $maj,$min,$sub;
+Defaulting to backwards compatibility with perl %d.%d.%d
+If you intend this module to be compatible with earlier perl versions, please
+specify a minimum perl version with the -b option.
+
+EOF
+}
if( $opt_v ){
$TEMPLATE_VERSION = $opt_v;