Apparently this is more stable historically... boggle
[dbsrgits/DBIx-Class.git] / t / 54taint.t
CommitLineData
f54428ab 1#!/usr/bin/env perl -T
83542a7d 2
3# the above line forces Test::Harness into taint-mode
f54428ab 4# DO NOT REMOVE
83542a7d 5
6use strict;
7use warnings;
8
9f72d93a 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
12use Config;
13BEGIN {
14 for (map { defined $ENV{$_} ? $ENV{$_} : () } (qw/PERLLIB PERL5LIB/) ) { # we unshift, so reverse precedence
f9139687 15 my ($envvar) = ($_ =~ /^(.*)$/s); # untaint
9f72d93a 16 unshift @INC, map { length($_) ? $_ : () } (split /\Q$Config{path_sep}\E/, $envvar);
17 }
18}
19
6fc6d60c 20# We need to specify 'lib' here as well because even if it was already in
21# @INC, the above will have put our local::lib in front of it, so now an
22# installed DBIx::Class will take precedence over the one we're trying to test.
23# In some cases, prove will have supplied ./lib as an absolute path so it
24# doesn't seem worth trying to remove the second copy since it won't hurt
25# anything.
26use lib qw(t/lib lib);
27
91b0ad0b 28use Test::More;
f54428ab 29use Test::Exception;
8d6b1478 30use DBICTest;
83542a7d 31
f54428ab 32throws_ok (
33 sub { $ENV{PATH} . (kill (0)) },
34 qr/Insecure dependency in kill/,
35 'taint mode active'
36);
83542a7d 37
f54428ab 38{
39 package DBICTest::Taint::Classes;
83542a7d 40
f54428ab 41 use Test::More;
42 use Test::Exception;
91b0ad0b 43
f54428ab 44 use base qw/DBIx::Class::Schema/;
91b0ad0b 45
f54428ab 46 lives_ok (sub {
47 __PACKAGE__->load_classes(qw/Manual/);
48 ok( __PACKAGE__->source('Manual'), 'The Classes::Manual source has been registered' );
49 __PACKAGE__->_unregister_source (qw/Manual/);
50 }, 'Loading classes with explicit load_classes worked in taint mode' );
91b0ad0b 51
f54428ab 52 lives_ok (sub {
53 __PACKAGE__->load_classes();
54 ok( __PACKAGE__->source('Auto'), 'The Classes::Auto source has been registered' );
55 ok( __PACKAGE__->source('Auto'), 'The Classes::Manual source has been re-registered' );
56 }, 'Loading classes with Module::Find/load_classes worked in taint mode' );
57}
83542a7d 58
f54428ab 59{
60 package DBICTest::Taint::Namespaces;
83542a7d 61
f54428ab 62 use Test::More;
63 use Test::Exception;
91b0ad0b 64
f54428ab 65 use base qw/DBIx::Class::Schema/;
83542a7d 66
f54428ab 67 lives_ok (sub {
68 __PACKAGE__->load_namespaces();
69 ok( __PACKAGE__->source('Test'), 'The Namespaces::Test source has been registered' );
70 }, 'Loading classes with Module::Find/load_namespaces worked in taint mode' );
71}
91b0ad0b 72
f54428ab 73done_testing;