summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2001-01-13 15:55:35 +0000
committerJim Meyering <jim@meyering.net>2001-01-13 15:55:35 +0000
commite268536dba3be1d39e0f58151a976b89818f31a4 (patch)
tree9221210a53f17a28e96e0798485103eeffb6ef34
parente2aae9e1660ff0f99794a5f050e3eef269e0c86d (diff)
downloadcoreutils-e268536dba3be1d39e0f58151a976b89818f31a4.tar.xz
*** empty log message ***
-rwxr-xr-xtests/mv/into-self-437
1 files changed, 37 insertions, 0 deletions
diff --git a/tests/mv/into-self-4 b/tests/mv/into-self-4
new file mode 100755
index 000000000..f0e1de668
--- /dev/null
+++ b/tests/mv/into-self-4
@@ -0,0 +1,37 @@
+#!/bin/sh
+# confirm that `mv symlink symlink' doesn't remove symlink
+# Based on an example from David Luyer.
+
+if test "$VERBOSE" = yes; then
+ set -x
+ mv --version
+fi
+
+. $srcdir/../envvar-check
+
+pwd=`pwd`
+tmp=mv-slink2.$$
+trap 'status=$?; cd $pwd; rm -rf $tmp && exit $status' 0
+trap '(exit $?); exit' 1 2 13 15
+
+framework_failure=0
+mkdir $tmp || framework_failure=1
+cd $tmp || framework_failure=1
+touch file || framework_failure=1
+ln -s file s || framework_failure=1
+
+if test $framework_failure = 1; then
+ echo 'failure in testing framework' 1>&2
+ (exit 1); exit
+fi
+
+fail=0
+
+# This must fail.
+mv s s 2> /dev/null && fail=1
+
+# But the symlink, s, must not be removed.
+# Before 4.0.36, `s' would have been removed.
+test -f s || fail=1
+
+(exit $fail); exit