use $Config{path_sep} in tests, not :
[p5sagit/local-lib.git] / t / bad_variables.t
CommitLineData
1b0fe50a 1use strict;
2use warnings;
3use Test::More tests => 5;
4use File::Temp 'tempdir';
6ba49acc 5use Config;
1b0fe50a 6use local::lib ();
7
8# remember the original value of this, in case we are already running inside a
9# local::lib
0d174bf6 10my $orig_llr = $ENV{PERL_LOCAL_LIB_ROOT} || '';
1b0fe50a 11
12my $dir1 = tempdir('test_local_lib-XXXXX', DIR => Cwd::abs_path('t'), CLEANUP => 1);
13my $dir2 = tempdir('test_local_lib-XXXXX', DIR => Cwd::abs_path('t'), CLEANUP => 1);
14my $dir3 = tempdir('test_local_lib-XXXXX', DIR => Cwd::abs_path('t'), CLEANUP => 1);
15
16ok(!(grep { $dir1 eq $_ } @INC), 'new dir is not already in @INC');
6ba49acc 17ok(!(grep { $dir1 eq $_ } split /\Q$Config{path_sep}\E/, ($ENV{PERL5LIB}||'')), 'new dir is not already in PERL5LIB');
1b0fe50a 18
19local::lib->import($dir1);
20local::lib->import($dir2);
21
22# we have junk in here now
6ba49acc 23$ENV{PERL_LOCAL_LIB_ROOT} .= $Config{path_sep} . $dir3;
1b0fe50a 24
25local::lib->import($dir1);
26
27is(
28 $ENV{PERL_LOCAL_LIB_ROOT},
6ba49acc 29 join($Config{path_sep}, (grep { $_ } $orig_llr, $dir2, $dir1)),
1b0fe50a 30 'dir1 should have been removed and added back in at the top',
31);
32
33ok((grep { /\Q$dir1\E/ } @INC), 'new dir has been added to @INC');
6ba49acc 34ok((grep { /\Q$dir1\E/ } split /\Q$Config{path_sep}\E/, $ENV{PERL5LIB}), 'new dir has been added to PERL5LIB');
1b0fe50a 35