summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2007-09-16 11:07:59 +0200
committerJim Meyering <jim@meyering.net>2007-09-16 11:29:57 +0200
commitd423f4a14b19a9771510cc753a0781dbbe1bf0ff (patch)
tree0309d2915856ebfa042216c949a210a8e9de724c
parent2983e54536605385b4487524e7de4ef8908c3984 (diff)
downloadcoreutils-d423f4a14b19a9771510cc753a0781dbbe1bf0ff.tar.xz
tests/CuTmpdir.pm: Use File::Find + chmod syscall, not chmod -R.
Signed-off-by: Jim Meyering <jim@meyering.net>
-rw-r--r--ChangeLog2
-rw-r--r--tests/CuTmpdir.pm31
2 files changed, 31 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index d021f5dc8..5ecf7592d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,7 @@
2007-09-16 Jim Meyering <jim@meyering.net>
+ * tests/CuTmpdir.pm: Use File::Find + chmod syscall, not chmod -R.
+
Revamp most test scripts.
* tests/rm/v-slash: Avoid test failure with non-C locale.
diff --git a/tests/CuTmpdir.pm b/tests/CuTmpdir.pm
index e92feff5d..f8d43d5ff 100644
--- a/tests/CuTmpdir.pm
+++ b/tests/CuTmpdir.pm
@@ -20,11 +20,18 @@ use strict;
use warnings;
use File::Temp;
+use File::Find;
our $ME = $0 || "<???>";
my $dir;
+sub skip_test
+{
+ warn "$ME: skipping test: unsafe working directory name\n";
+ exit 77;
+}
+
sub import {
my $prefix = $_[1];
if ($prefix !~ /^\//)
@@ -33,15 +40,35 @@ sub import {
my $cwd = $@ ? '.' : Cwd::getcwd();
$prefix = "$cwd/$prefix";
}
+
+ # Untaint for the upcoming mkdir.
+ $prefix =~ m!^([-+\@\w./]+)$!
+ or skip_test;
+ $prefix = $1;
+
$dir = File::Temp::tempdir("$prefix.tmp-XXXX", CLEANUP => 1 );
chdir $dir
or warn "$ME: failed to chdir to $dir: $!\n";
}
+sub wanted
+{
+ my $name = $_;
+
+ # Skip symlinks and non-directories.
+ -l $name || !-d _
+ and return;
+
+ chmod 0700, $name;
+}
+
END {
my $saved_errno = $?;
- # FIXME: use File::Find
- system qw (chmod -R 700), $dir;
+ chdir $dir
+ or warn "$ME: failed to chdir to $dir: $!\n";
+ # Perform the equivalent of find . -type d -print0|xargs -0 chmod -R 700.
+ my $options = {untaint => 1, wanted => \&wanted};
+ find ($options, '.');
$? = $saved_errno;
}