summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorngie <ngie@FreeBSD.org>2017-07-17 21:08:24 +0000
committerngie <ngie@FreeBSD.org>2017-07-17 21:08:24 +0000
commitf1e8726bd54871e622d55a3f6ef344b85291efcc (patch)
tree2be14abf4040504d1d8b09b5921c36a360556abb
parent7ddc34d8de6633fe839f7f3f8bdd047c492f0ae2 (diff)
downloadFreeBSD-src-f1e8726bd54871e622d55a3f6ef344b85291efcc.zip
FreeBSD-src-f1e8726bd54871e622d55a3f6ef344b85291efcc.tar.gz
MFC r319855,r319856,r319858:
r319855: Use readlink(1)/stat(1) to query symlinks instead of file(1) file(1) can be compiled out of the system via MK_FILE == no, and the output isn't guaranteed to be stable. It's better to use stat(1)/readlink(1) instead to query symlink/file paths. MFC with: r319714, r319854 r319856: Add a testcase for `ln -sF` The testcase fails today, so mark it with atf_expect_fail: in particular, the target (B) isn't being unlinked and the documentation doesn't suggest special handling for directories. Thus, there's either a doc or an implementation bug in ln(1) that needs to be resolved. MFC with: r319714, r319854, r319855 PR: 219943 r319858: Style fixes: clean up leading whitespace (8 single column spaces -> \t) MFC with: r319714, r319854, r319855, r319856
-rw-r--r--bin/ln/tests/ln_test.sh200
1 files changed, 112 insertions, 88 deletions
diff --git a/bin/ln/tests/ln_test.sh b/bin/ln/tests/ln_test.sh
index 7d878c3..e7aac2d 100644
--- a/bin/ln/tests/ln_test.sh
+++ b/bin/ln/tests/ln_test.sh
@@ -28,193 +28,217 @@
set_umask()
{
- if ! umask 022; then
- atf_fail "setting umask failed"
- fi
+ if ! umask 022; then
+ atf_fail "setting umask failed"
+ fi
}
atf_test_case L_flag
L_flag_head()
{
- atf_set "descr" "Verify that when creating a hard link to a " \
- "symbolic link, '-L' option creates a hard" \
- "link to the target of the symbolic link"
+ atf_set "descr" "Verify that when creating a hard link to a " \
+ "symbolic link, '-L' option creates a hard" \
+ "link to the target of the symbolic link"
}
L_flag_body()
{
- set_umask
- atf_check touch A
- atf_check ln -s A B
- atf_check ln -L B C
- stat_A=$(stat -f %i A)
- stat_C=$(stat -f %i C)
- atf_check_equal "$stat_A" "$stat_C"
- atf_check -o inline:'B: symbolic link to A\n' file B
+ set_umask
+ atf_check touch A
+ atf_check ln -s A B
+ atf_check ln -L B C
+ stat_A=$(stat -f %i A)
+ stat_C=$(stat -f %i C)
+ atf_check_equal "$stat_A" "$stat_C"
+ atf_check -o inline:'Symbolic Link\n' stat -f %SHT B
+ atf_check -o inline:'A\n' readlink B
}
atf_test_case P_flag
P_flag_head()
{
- atf_set "descr" "Verify that when creating a hard link to a " \
- "symbolic link, '-P' option creates a hard " \
- "link to the symbolic link itself"
+ atf_set "descr" "Verify that when creating a hard link to a " \
+ "symbolic link, '-P' option creates a hard " \
+ "link to the symbolic link itself"
}
P_flag_body()
{
- set_umask
- atf_check touch A
- atf_check ln -s A B
- atf_check ln -P B C
- stat_B=$(stat -f %i B)
- stat_C=$(stat -f %i C)
- atf_check_equal "$stat_B" "$stat_C"
+ set_umask
+ atf_check touch A
+ atf_check ln -s A B
+ atf_check ln -P B C
+ stat_B=$(stat -f %i B)
+ stat_C=$(stat -f %i C)
+ atf_check_equal "$stat_B" "$stat_C"
}
atf_test_case f_flag
f_flag_head()
{
- atf_set "descr" "Verify that if the target file already exists, " \
- "'-f' option unlinks it so that link may occur"
+ atf_set "descr" "Verify that if the target file already exists, " \
+ "'-f' option unlinks it so that link may occur"
}
f_flag_body()
{
- set_umask
- atf_check touch A B
- atf_check ln -f A B
- stat_A=$(stat -f %i A)
- stat_B=$(stat -f %i B)
- atf_check_equal "$stat_A" "$stat_B"
+ set_umask
+ atf_check touch A B
+ atf_check ln -f A B
+ stat_A=$(stat -f %i A)
+ stat_B=$(stat -f %i B)
+ atf_check_equal "$stat_A" "$stat_B"
}
atf_test_case target_exists_hard
target_exists_hard_head()
{
- atf_set "descr" "Verify whether creating a hard link fails if the " \
- "target file already exists"
+ atf_set "descr" "Verify whether creating a hard link fails if the " \
+ "target file already exists"
}
target_exists_hard_body()
{
- set_umask
- atf_check touch A B
- atf_check -s exit:1 -e inline:'ln: B: File exists\n' \
- ln A B
+ set_umask
+ atf_check touch A B
+ atf_check -s exit:1 -e inline:'ln: B: File exists\n' \
+ ln A B
}
atf_test_case target_exists_symbolic
target_exists_symbolic_head()
{
- atf_set "descr" "Verify whether creating a symbolic link fails if " \
- "the target file already exists"
+ atf_set "descr" "Verify whether creating a symbolic link fails if " \
+ "the target file already exists"
}
target_exists_symbolic_body()
{
- set_umask
- atf_check touch A B
- atf_check -s exit:1 -e inline:'ln: B: File exists\n' \
- ln -s A B
+ set_umask
+ atf_check touch A B
+ atf_check -s exit:1 -e inline:'ln: B: File exists\n' \
+ ln -s A B
}
atf_test_case shf_flag_dir
shf_flag_dir_head() {
- atf_set "descr" "Verify that if the target directory is a symbolic " \
- "link, '-shf' option prevents following the link"
+ atf_set "descr" "Verify that if the target directory is a symbolic " \
+ "link, '-shf' option prevents following the link"
}
shf_flag_dir_body()
{
- atf_check mkdir -m 0777 A B
- atf_check ln -s A C
- atf_check ln -shf B C
- atf_check -o inline:'C: symbolic link to B\n' file C
+ atf_check mkdir -m 0777 A B
+ atf_check ln -s A C
+ atf_check ln -shf B C
+ atf_check -o inline:'Symbolic Link\n' stat -f %SHT C
+ atf_check -o inline:'B\n' readlink C
}
atf_test_case snf_flag_dir
snf_flag_dir_head() {
- atf_set "descr" "Verify that if the target directory is a symbolic " \
- "link, '-snf' option prevents following the link"
+ atf_set "descr" "Verify that if the target directory is a symbolic " \
+ "link, '-snf' option prevents following the link"
}
snf_flag_dir_body()
{
- atf_check mkdir -m 0777 A B
- atf_check ln -s A C
- atf_check ln -snf B C
- atf_check -o inline:'C: symbolic link to B\n' file C
+ atf_check mkdir -m 0777 A B
+ atf_check ln -s A C
+ atf_check ln -snf B C
+ atf_check -o inline:'Symbolic Link\n' stat -f %SHT C
+ atf_check -o inline:'B\n' readlink C
+}
+
+atf_test_case sF_flag
+sF_flag_head()
+{
+ atf_set "descr" "Verify that if the target file already exists " \
+ "and is a directory, then '-sF' option removes " \
+ "it so that the link may occur"
+}
+
+sF_flag_body()
+{
+ atf_expect_fail "B isn't being unlinked (bug 219943)"
+ atf_check mkdir A B
+ atf_check ln -sF A B
+ atf_check -o inline:'Symbolic Link\n' stat -f %SHT B
}
atf_test_case sf_flag
sf_flag_head()
{
- atf_set "descr" "Verify that if the target file already exists, " \
- "'-sf' option unlinks it and creates a symbolic link " \
- "to the source file"
+ atf_set "descr" "Verify that if the target file already exists, " \
+ "'-sf' option unlinks it and creates a symbolic link " \
+ "to the source file"
}
sf_flag_body()
{
- set_umask
- atf_check touch A B
- atf_check ln -sf A B
- atf_check -o inline:'B: symbolic link to A\n' file B
+ set_umask
+ atf_check touch A B
+ atf_check ln -sf A B
+ atf_check -o inline:'Symbolic Link\n' stat -f %SHT B
+ atf_check -o inline:'A\n' readlink B
}
atf_test_case s_flag
s_flag_head()
{
- atf_set "descr" "Verify that '-s' option creates a symbolic link"
+ atf_set "descr" "Verify that '-s' option creates a symbolic link"
}
s_flag_body()
{
- set_umask
- atf_check touch A
- atf_check ln -s A B
- atf_check -o inline:'B: symbolic link to A\n' file B
+ set_umask
+ atf_check touch A
+ atf_check ln -s A B
+ atf_check -o inline:'Symbolic Link\n' stat -f %SHT B
+ atf_check -o inline:'A\n' readlink B
}
atf_test_case s_flag_broken
s_flag_broken_head()
{
- atf_set "descr" "Verify that if the source file does not exists, '-s' " \
- "option creates a broken symbolic link to the source file"
+ atf_set "descr" "Verify that if the source file does not exists, '-s' " \
+ "option creates a broken symbolic link to the source file"
}
s_flag_broken_body()
{
- atf_check ln -s A B
- atf_check -o inline:'B: broken symbolic link to A\n' file B
+ atf_check ln -s A B
+ atf_check -o inline:'Symbolic Link\n' stat -f %SHT B
+ atf_check -o inline:'A\n' readlink B
}
atf_test_case sw_flag
sw_flag_head()
{
- atf_set "descr" "Verify that '-sw' option produces a warning if the " \
- "source of a symbolic link does not currently exist"
+ atf_set "descr" "Verify that '-sw' option produces a warning if the " \
+ "source of a symbolic link does not currently exist"
}
sw_flag_body()
{
- atf_check -s exit:0 -e inline:'ln: warning: A: No such file or directory\n' \
- ln -sw A B
- atf_check -o inline:'B: broken symbolic link to A\n' file B
+ atf_check -s exit:0 -e inline:'ln: warning: A: No such file or directory\n' \
+ ln -sw A B
+ atf_check -o inline:'Symbolic Link\n' stat -f %SHT B
+ atf_check -o inline:'A\n' readlink B
}
atf_init_test_cases()
{
- atf_add_test_case L_flag
- atf_add_test_case P_flag
- atf_add_test_case f_flag
- atf_add_test_case target_exists_hard
- atf_add_test_case target_exists_symbolic
- atf_add_test_case shf_flag_dir
- atf_add_test_case snf_flag_dir
- atf_add_test_case sf_flag
- atf_add_test_case s_flag
- atf_add_test_case s_flag_broken
- atf_add_test_case sw_flag
+ atf_add_test_case L_flag
+ atf_add_test_case P_flag
+ atf_add_test_case f_flag
+ atf_add_test_case target_exists_hard
+ atf_add_test_case target_exists_symbolic
+ atf_add_test_case shf_flag_dir
+ atf_add_test_case snf_flag_dir
+ atf_add_test_case sF_flag
+ atf_add_test_case sf_flag
+ atf_add_test_case s_flag
+ atf_add_test_case s_flag_broken
+ atf_add_test_case sw_flag
}
OpenPOWER on IntegriCloud