doc: move @shortcontents and @contents from end to start
[platform/upstream/coreutils.git] / tests / cp / thru-dangling
1 #!/bin/sh
2 # Ensure that cp works as documented, when the destination is a dangling symlink
3
4 # Copyright (C) 2007-2008 Free Software Foundation, Inc.
5
6 # This program is free software: you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation, either version 3 of the License, or
9 # (at your option) any later version.
10
11 # This program is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 # GNU General Public License for more details.
15
16 # You should have received a copy of the GNU General Public License
17 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
18
19 if test "$VERBOSE" = yes; then
20   set -x
21   cp --version
22 fi
23
24 . $srcdir/test-lib.sh
25
26 ln -s no-such dangle || framework_failure
27 echo hi > f || framework_failure
28 echo hi > exp || framework_failure
29 echo "cp: not writing through dangling symlink \`dangle'" \
30     > exp-err || framework_failure
31
32 fail=0
33
34 # Starting with 6.9.90, this usage fails, by default:
35 cp f dangle > err 2>&1 && fail=1
36
37 compare err exp-err || fail=1
38 test -f no-such && fail=1
39
40 # But you can set POSIXLY_CORRECT to get the historical behavior.
41 env POSIXLY_CORRECT=1 cp f dangle > out 2>&1 || fail=1
42 cat no-such >> out || fail=1
43
44 compare out exp || fail=1
45
46 Exit $fail