aboutsummaryrefslogtreecommitdiff
path: root/t/t0060-path-utils.sh
diff options
context:
space:
mode:
authorJiang Xin <worldhello.net@gmail.com>2013-06-25 23:53:42 +0800
committerJunio C Hamano <gitster@pobox.com>2013-06-26 09:30:26 -0700
commit203439b2840c4c384060df2fa192994e4b6740ed (patch)
tree3617313dba1f89f6aac6f96394446459fecb49f0 /t/t0060-path-utils.sh
parent0c2b1cf812be6e7e35bed0844b37e412cd232b6b (diff)
downloadgit-203439b2840c4c384060df2fa192994e4b6740ed.tar.gz
git-203439b2840c4c384060df2fa192994e4b6740ed.tar.xz
test: add test cases for relative_path
Add subcommand "relative_path" in test-path-utils, and add test cases in t0060. Johannes tested an earlier version of this patch on Windows, and found that some relative_path tests should be skipped on Windows. This is because the bash on Windows rewrites arguments of regular Windows programs, such as git and the test helpers, if the arguments look like absolute POSIX paths. As a consequence, the actual tests performed are not what the tests scripts expect. The tests that need *not* be skipped are those where the two paths passed to 'test-path-utils relative_path' have the same prefix and the result is expected to be a relative path. This is because the rewriting changes "/a/b" to "D:/Src/MSysGit/a/b", and when both inputs are extended the same way, this just cancels out in the relative path computation. Signed-off-by: Jiang Xin <worldhello.net@gmail.com> Helped-by: Johannes Sixt <j6t@kdbg.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t0060-path-utils.sh')
-rwxr-xr-xt/t0060-path-utils.sh37
1 files changed, 37 insertions, 0 deletions
diff --git a/t/t0060-path-utils.sh b/t/t0060-path-utils.sh
index 09a42a428..72e89ce71 100755
--- a/t/t0060-path-utils.sh
+++ b/t/t0060-path-utils.sh
@@ -12,6 +12,11 @@ norm_path() {
"test \"\$(test-path-utils normalize_path_copy '$1')\" = '$2'"
}
+relative_path() {
+ test_expect_success $4 "relative path: $1 $2 => $3" \
+ "test \"\$(test-path-utils relative_path '$1' '$2')\" = '$3'"
+}
+
# On Windows, we are using MSYS's bash, which mangles the paths.
# Absolute paths are anchored at the MSYS installation directory,
# which means that the path / accounts for this many characters:
@@ -183,4 +188,36 @@ test_expect_success SYMLINKS 'real path works on symlinks' '
test "$sym" = "$(test-path-utils real_path "$dir2/syml")"
'
+relative_path /a/b/c/ /a/b/ c/
+relative_path /a/b/c/ /a/b c/
+relative_path /a//b//c/ //a/b// c/ POSIX
+relative_path /a/b /a/b .
+relative_path /a/b/ /a/b .
+relative_path /a /a/b /a POSIX
+relative_path / /a/b/ / POSIX
+relative_path /a/c /a/b/ /a/c POSIX
+relative_path /a/c /a/b /a/c POSIX
+relative_path /x/y /a/b/ /x/y POSIX
+relative_path /a/b "<empty>" /a/b POSIX
+relative_path /a/b "<null>" /a/b POSIX
+relative_path a/b/c/ a/b/ c/
+relative_path a/b/c/ a/b c/
+relative_path a/b//c a//b c
+relative_path a/b/ a/b/ .
+relative_path a/b/ a/b .
+relative_path a a/b a # TODO: should be: ..
+relative_path x/y a/b x/y # TODO: should be: ../../x/y
+relative_path a/c a/b a/c # TODO: should be: ../c
+relative_path a/b "<empty>" a/b
+relative_path a/b "<null>" a/b
+relative_path "<empty>" /a/b "(empty)"
+relative_path "<empty>" "<empty>" "(empty)"
+relative_path "<empty>" "<null>" "(empty)"
+relative_path "<null>" "<empty>" "(null)"
+relative_path "<null>" "<null>" "(null)"
+
+test_expect_failure 'relative path: <null> /a/b => segfault' '
+ test-path-utils relative_path "<null>" "/a/b"
+'
+
test_done