2 # Test for File::Temp - Security levels
4 # Some of the security checking will not work on all platforms
5 # Test a simple open in the cwd and tmpdir foreach of the
10 unshift @INC, '../lib';
11 require Test; import Test;
18 # Set up END block - this needs to happen before we load
19 # File::Temp since this END block must be evaluated after the
20 # END block configured by File::Temp
21 my @files; # list of files to remove
22 END { foreach (@files) { ok( !(-e $_) )} }
24 use File::Temp qw/ tempfile unlink0 /;
27 # The high security tests must currently be skipped on Windows
28 my $skipplat = ( $^O eq 'MSWin32' ? 1 : 0 );
30 # Can not run high security tests in perls before 5.6.0
31 my $skipperl = ($] < 5.006 ? 1 : 0 );
33 # Determine whether we need to skip things and why
36 $skip = "Skip Not supported on this platform";
38 $skip = "Skip Perl version must be v5.6.0 for these tests";
42 print "# We will be skipping some tests : $skip\n" if $skip;
44 # start off with basic checking
46 File::Temp->safe_level( File::Temp::STANDARD );
48 print "# Testing with STANDARD security...\n";
54 File::Temp->safe_level( File::Temp::MEDIUM )
57 print "# Testing with MEDIUM security...\n";
59 # Now we need to start skipping tests
60 &test_security($skip);
64 File::Temp->safe_level( File::Temp::HIGH )
67 print "# Testing with HIGH security...\n";
69 &test_security($skip);
73 # Subroutine to open two temporary files.
74 # one is opened in the current dir and the other in the temp dir
78 # Read in the skip flag
81 # If we are skipping we need to simply fake the correct number
82 # of tests -- we dont use skip since the tempfile() commands will
83 # fail with MEDIUM/HIGH security before the skip() command would be run
89 # plus we need an end block so the tests come out in the right order
90 eval q{ END { skip($skip,1); skip($skip,1) } 1; } || die;
96 my $template = "temptestXXXXXXXX";
97 my ($fh1, $fname1) = tempfile ( $template,
98 DIR => File::Spec->curdir,
101 print "# Fname1 = $fname1\n";
105 my ($fh2, $fname2) = tempfile ($template, UNLINK => 1 );
109 # Store filenames for the end block
110 push(@files, $fname1, $fname2);