c9ff881c86e04f7b4518bc40877327fa922b2853
[dbsrgits/DBIx-Class.git] / maint / Makefile.PL.inc / 11_authortests.pl
1 require File::Spec;
2 require File::Find;
3
4 my $xt_dirs;
5 File::Find::find(sub {
6   return if $xt_dirs->{$File::Find::dir};
7   $xt_dirs->{$File::Find::dir} = 1 if (
8     $_ =~ /\.t$/ and -f $_
9   );
10 }, 'xt');
11
12 my @xt_tests = map { File::Spec->catfile($_, '*.t') } sort keys %$xt_dirs;
13
14 # this will add the xt tests to the `make test` target among other things
15 Meta->tests(join (' ', map { $_ || () } Meta->tests, @xt_tests ) );
16
17 # inject an explicit xt test run, mainly to check the contents of
18 # lib and the generated POD's *before* anything is copied around
19 postamble <<"EOP";
20
21 dbic_clonedir_copy_generated_pod : test_xt
22
23 test_xt : pm_to_blib
24 @{[
25   # When xt tests are explicitly requested, we want to run with RELEASE_TESTING=1
26   # so that all optdeps are turned into a hard failure
27   # However portably modifying ENV for a single command is surprisingly hard
28   # So instead we (ab)use perl's ability to stack -e options, and simply modify
29   # the ENV from within perl itself
30   $mm_proto->test_via_harness(
31     # perl cmd
32     join( ' ',
33       '$(ABSPERLRUN)',
34       # $'s need to be escaped (doubled) before inserting into the Makefile
35       map { $mm_proto->quote_literal($_) } qw(-e $$ENV{RELEASE_TESTING}=1;) 
36     ),
37     # test list
38     join( ' ',
39       map { $mm_proto->quote_literal($_) } @xt_tests
40     ),
41   )
42 ]}
43
44 EOP
45
46 # keep the Makefile.PL eval happy
47 1;