Skip error/warn frames within CAG - saner callsite error messages this way
[dbsrgits/DBIx-Class.git] / t / 54taint.t
1 #!/usr/bin/env perl -T
2
3 # the above line forces Test::Harness into taint-mode
4 # DO NOT REMOVE
5
6 use strict;
7 use warnings;
8
9 # When in taint mode, PERL5LIB is ignored (but *not* unset)
10 # Put it back in INC so that local-lib users can actually
11 # run this test
12 use Config;
13 BEGIN {
14   for (map { defined $ENV{$_} ? $ENV{$_} : () } (qw/PERLLIB PERL5LIB/) ) {  # we unshift, so reverse precedence
15     my ($envvar) = ($_ =~ /^(.+)$/);  # untaint
16     unshift @INC, map { length($_) ? $_ : () } (split /\Q$Config{path_sep}\E/, $envvar);
17   }
18 }
19
20 use Test::More;
21 use Test::Exception;
22 use lib qw(t/lib);
23
24 throws_ok (
25   sub { $ENV{PATH} . (kill (0)) },
26   qr/Insecure dependency in kill/,
27   'taint mode active'
28 );
29
30 {
31   package DBICTest::Taint::Classes;
32
33   use Test::More;
34   use Test::Exception;
35
36   use base qw/DBIx::Class::Schema/;
37
38   lives_ok (sub {
39     __PACKAGE__->load_classes(qw/Manual/);
40     ok( __PACKAGE__->source('Manual'), 'The Classes::Manual source has been registered' );
41     __PACKAGE__->_unregister_source (qw/Manual/);
42   }, 'Loading classes with explicit load_classes worked in taint mode' );
43
44   lives_ok (sub {
45     __PACKAGE__->load_classes();
46     ok( __PACKAGE__->source('Auto'), 'The Classes::Auto source has been registered' );
47       ok( __PACKAGE__->source('Auto'), 'The Classes::Manual source has been re-registered' );
48   }, 'Loading classes with Module::Find/load_classes worked in taint mode' );
49 }
50
51 {
52   package DBICTest::Taint::Namespaces;
53
54   use Test::More;
55   use Test::Exception;
56
57   use base qw/DBIx::Class::Schema/;
58
59   lives_ok (sub {
60     __PACKAGE__->load_namespaces();
61     ok( __PACKAGE__->source('Test'), 'The Namespaces::Test source has been registered' );
62   }, 'Loading classes with Module::Find/load_namespaces worked in taint mode' );
63 }
64
65 done_testing;