summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/filetest.t49
1 files changed, 29 insertions, 20 deletions
diff --git a/lib/filetest.t b/lib/filetest.t
index 7ea977295a..98a19bdf5f 100644
--- a/lib/filetest.t
+++ b/lib/filetest.t
@@ -5,6 +5,7 @@ BEGIN {
@INC = '../lib';
}
+use Config;
use Test::More tests => 15;
# these two should be kept in sync with the pragma itself
@@ -57,30 +58,38 @@ SKIP: {
my $tstfile = "filetest.tst";
skip("No $chflags available", 4) if !-x $chflags;
- skip("Test does not work on OpenBSD, BSD/OS, and Darwin", 4)
- if $^O =~ /^(?:openbsd|bsdos|darwin)$/;
-
- SKIP: {
- eval {
- if (!-e $tstfile) {
- open(T, ">$tstfile") or die "Can't create $tstfile: $!";
- close T;
- }
- system($chflags, "uchg", $tstfile);
- die "Can't exec $chflags uchg" if $? != 0;
- };
- skip("Errors in test using chflags: $@", 4) if $@;
-
- {
- use filetest 'access';
+ my $skip_eff_user_tests = (!$Config{d_setreuid} && !$Config{d_setresuid})
+ ||
+ (!$Config{d_setregid} && !$Config{d_setresgid});
+
+ eval {
+ if (!-e $tstfile) {
+ open(T, ">$tstfile") or die "Can't create $tstfile: $!";
+ close T;
+ }
+ system($chflags, "uchg", $tstfile);
+ die "Can't exec $chflags uchg" if $? != 0;
+ };
+ skip("Errors in test using chflags: $@", 4) if $@;
+
+ {
+ use filetest 'access';
+ SKIP: {
+ skip("No tests on effective user id", 1)
+ if $skip_eff_user_tests;
is(-w $tstfile, undef, "$tstfile should not be recognized as writable");
- is(-W $tstfile, undef, "$tstfile should not be recognized as writable");
}
- {
- no filetest 'access';
+ is(-W $tstfile, undef, "$tstfile should not be recognized as writable");
+ }
+
+ {
+ no filetest 'access';
+ SKIP: {
+ skip("No tests on effective user id", 1)
+ if $skip_eff_user_tests;
is(-w $tstfile, 1, "$tstfile should be recognized as writable");
- is(-W $tstfile, 1, "$tstfile should be recognized as writable");
}
+ is(-W $tstfile, 1, "$tstfile should be recognized as writable");
}
# cleanup