2 # Ensure "install -C" works. (basic tests)
4 # Copyright (C) 2008-2025 Free Software Foundation, Inc.
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.
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.
16 # You should have received a copy of the GNU General Public License
17 # along with this program. If not, see <https://www.gnu.org/licenses/>.
19 .
"${srcdir=.}/tests/init.sh"; path_prepend_ .
/src
22 skip_if_nondefault_group_
24 # Note if a group is not specified, install(1) will assume that a file
25 # would be installed with the current user's group ID, and thus if the
26 # file is the same except that it does have a different group due to
27 # its parent directory being g+s for example, then the copy will be
28 # done again redundantly in a futile attempt to reset the group ID to
29 # that of the current user.
31 # install -d -g wheel -m 2775 test # Create setgid dir
32 # touch test/a # Create source
33 # install -Cv -m664 test/a test/i1 # install source with mode
34 # install -Cv -m664 test/i1 test/i2 # install dest
35 # install -Cv -m664 test/i1 test/i2 # again to see redundant install
37 # Similarly if an existing file exists that is the same and has the
38 # current users group ID, but when an actual install of the file would
39 # reset to a different group ID due to the directory being g+s for example,
40 # then the install will not be done when it should.
42 # install -Cv -m664 -g "$(id -nrg)" test/i1 test/i2 # set i2 to uesr's gid
43 # install -Cv -m664 test/i1 test/i2 # this should install but doesn't
45 # Therefore we skip the test in the presence of setgid dirs
46 # An additional complication on HFS is that it...
53 echo test > a || framework_failure_
54 echo "'a' -> 'b'" > out_installed_first || framework_failure_
56 'a' -> 'b'" > out_installed_second || framework_failure_
57 > out_empty || framework_failure_
59 # destination file does not exist
60 ginstall
-Cv -m$mode1 a b
> out || fail
=1
61 compare out out_installed_first || fail
=1
63 # destination file exists
64 ginstall
-Cv -m$mode1 a b
> out || fail
=1
65 compare out out_empty || fail
=1
67 # destination file exists (long option)
68 ginstall
-v --compare -m$mode1 a b
> out || fail
=1
69 compare out out_empty || fail
=1
71 # destination file exists but -C is not given
72 ginstall
-v -m$mode1 a b
> out || fail
=1
73 compare out out_installed_second || fail
=1
75 # option -C ignored if any non-permission mode should be set
76 ginstall
-Cv -m$mode3 a b
> out || fail
=1
77 compare out out_installed_second || fail
=1
78 ginstall
-Cv -m$mode3 a b
> out || fail
=1
79 compare out out_installed_second || fail
=1
82 ginstall
-v -m$mode1 a b
> out || fail
=1 # reset to regular mode
83 compare out out_installed_second || fail
=1
84 # symlink source is always dereferenced (and so regular here)
85 ginstall
-v -m$mode1 a d
> out || fail
=1 # create regular dest
86 echo "'a' -> 'd'" > out_installed_first_ad || framework_failure_
87 compare out out_installed_first_ad || fail
=1
88 ln -s a c || framework_failure_
89 ginstall
-Cv -m$mode1 c d
> out || fail
=1
90 compare out out_empty || fail
=1
91 # symlink dest never created by install so deemed non regular
92 ln -nsf b d || framework_failure_
93 ginstall
-Cv -m$mode1 c d
> out || fail
=1
95 'c' -> 'd'" > out_installed_second_cd
96 compare out out_installed_second_cd || fail
=1
98 # destination file exists but content differs
99 echo test1
> a || framework_failure_
100 ginstall
-Cv -m$mode1 a b
> out || fail
=1
101 compare out out_installed_second || fail
=1
102 ginstall
-Cv -m$mode1 a b
> out || fail
=1
103 compare out out_empty || fail
=1
105 # destination file exists but content differs (same size)
106 echo test2
> a || framework_failure_
107 ginstall
-Cv -m$mode1 a b
> out || fail
=1
108 compare out out_installed_second || fail
=1
109 ginstall
-Cv -m$mode1 a b
> out || fail
=1
110 compare out out_empty || fail
=1
112 # destination file exists but mode differs
113 ginstall
-Cv -m$mode2 a b
> out || fail
=1
114 compare out out_installed_second || fail
=1
115 ginstall
-Cv -m$mode2 a b
> out || fail
=1
116 compare out out_empty || fail
=1
118 # options -C and --preserve-timestamps are mutually exclusive
119 returns_
1 ginstall
-C --preserve-timestamps a b || fail
=1
121 # options -C and --strip are mutually exclusive
122 returns_
1 ginstall
-C --strip --strip-program=echo a b || fail
=1