summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorMichael G Schwern <schwern@pobox.com>2005-07-11 12:16:10 -0700
committerSteve Hay <SteveHay@planit.com>2005-07-12 11:42:07 +0000
commit1ef594674c6d3ce517bc3c014da975c47316ef0b (patch)
treefc407176bb0b7b83b688bb31ab0533439455e078 /lib
parent83519ebf741b18d4584f441b54b093db74aea412 (diff)
downloadperl-1ef594674c6d3ce517bc3c014da975c47316ef0b.tar.gz
[perl #36502] File::Copy::mv fails to replicate behavior of Unix mv
From: "Michael G Schwern via RT" <perlbug-followup@perl.org> Message-ID: <rt-3.0.11-36502-116917.0.56038652013207@perl.org> p4raw-id: //depot/perl@25122
Diffstat (limited to 'lib')
-rwxr-xr-xlib/File/Copy.t30
1 files changed, 27 insertions, 3 deletions
diff --git a/lib/File/Copy.t b/lib/File/Copy.t
index 557a0e1d0b..f01830e03e 100755
--- a/lib/File/Copy.t
+++ b/lib/File/Copy.t
@@ -9,12 +9,23 @@ use Test::More;
my $TB = Test::More->builder;
-plan tests => 46;
+plan tests => 48;
+
+# We're going to override rename() later on but Perl has to see an override
+# at compile time to honor it.
+BEGIN { *CORE::GLOBAL::rename = sub { CORE::rename($_[0], $_[1]) }; }
+
use File::Copy;
use Config;
-for (1..2) {
+for my $cross_partition_test (0..1) {
+ {
+ # Simulate a cross-partition copy/move by forcing rename to
+ # fail.
+ no warnings 'redefine';
+ *CORE::GLOBAL::rename = sub { 0 } if $cross_partition_test;
+ }
# First we create a file
open(F, ">file-$$") or die;
@@ -72,12 +83,26 @@ for (1..2) {
ok !move("file-$$", "copy-$$"), "move on missing file";
ok -e "copy-$$", ' target still there';
+ # Doesn't really matter what time it is as long as its not now.
+ my $time = 1000000000;
+ utime( $time, $time, "copy-$$" );
+
+ # Recheck the mtime rather than rely on utime in case we're on a
+ # system where utime doesn't work or there's no mtime at all.
+ # The destination file will reflect the same difficulties.
+ my $mtime = (stat("copy-$$"))[9];
+
ok move "copy-$$", "file-$$", 'move';
ok -e "file-$$", ' destination exists';
ok !-e "copy-$$", ' source does not';
open(R, "file-$$") or die; $foo = <R>; close(R);
is $foo, "ok\n";
+ my $dest_mtime = (stat("file-$$"))[9];
+ is $dest_mtime, $mtime,
+ "mtime preserved by copy()".
+ ($cross_partition_test ? " while testing cross-partition" : "");
+
copy "file-$$", "lib";
open(R, "lib/file-$$") or die; $foo = <R>; close(R);
is $foo, "ok\n";
@@ -130,7 +155,6 @@ for (1..2) {
unlink "hardlink-$$";
unlink "file-$$";
}
-
}