You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
352 lines
14 KiB
352 lines
14 KiB
#!/bin/sh |
|
# |
|
# Copyright (c) 2008 David Reiss |
|
# |
|
|
|
test_description='Test various path utilities' |
|
|
|
. ./test-lib.sh |
|
|
|
norm_path() { |
|
expected=$(test-path-utils print_path "$2") |
|
test_expect_success $3 "normalize path: $1 => $2" \ |
|
"test \"\$(test-path-utils normalize_path_copy '$1')\" = '$expected'" |
|
} |
|
|
|
relative_path() { |
|
expected=$(test-path-utils print_path "$3") |
|
test_expect_success $4 "relative path: $1 $2 => $3" \ |
|
"test \"\$(test-path-utils relative_path '$1' '$2')\" = '$expected'" |
|
} |
|
|
|
test_submodule_relative_url() { |
|
test_expect_success "test_submodule_relative_url: $1 $2 $3 => $4" " |
|
actual=\$(git submodule--helper resolve-relative-url-test '$1' '$2' '$3') && |
|
test \"\$actual\" = '$4' |
|
" |
|
} |
|
|
|
test_git_path() { |
|
test_expect_success "git-path $1 $2 => $3" " |
|
$1 git rev-parse --git-path $2 >actual && |
|
echo $3 >expect && |
|
test_cmp expect actual |
|
" |
|
} |
|
|
|
# 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: |
|
rootoff=$(test-path-utils normalize_path_copy / | wc -c) |
|
# Account for the trailing LF: |
|
if test $rootoff = 2; then |
|
rootoff= # we are on Unix |
|
else |
|
rootoff=$(($rootoff-1)) |
|
# In MSYS2, the root directory "/" is translated into a Windows |
|
# directory *with* trailing slash. Let's test for that and adjust |
|
# our expected longest ancestor length accordingly. |
|
case "$(test-path-utils print_path /)" in |
|
*/) rootslash=1;; |
|
*) rootslash=0;; |
|
esac |
|
fi |
|
|
|
ancestor() { |
|
# We do some math with the expected ancestor length. |
|
expected=$3 |
|
if test -n "$rootoff" && test "x$expected" != x-1; then |
|
expected=$(($expected-$rootslash)) |
|
test $expected -lt 0 || |
|
expected=$(($expected+$rootoff)) |
|
fi |
|
test_expect_success "longest ancestor: $1 $2 => $expected" \ |
|
"actual=\$(test-path-utils longest_ancestor_length '$1' '$2') && |
|
test \"\$actual\" = '$expected'" |
|
} |
|
|
|
# Some absolute path tests should be skipped on Windows due to path mangling |
|
# on POSIX-style absolute paths |
|
case $(uname -s) in |
|
*MINGW*) |
|
;; |
|
*CYGWIN*) |
|
;; |
|
*) |
|
test_set_prereq POSIX |
|
;; |
|
esac |
|
|
|
test_expect_success basename 'test-path-utils basename' |
|
test_expect_success dirname 'test-path-utils dirname' |
|
|
|
norm_path "" "" |
|
norm_path . "" |
|
norm_path ./ "" |
|
norm_path ./. "" |
|
norm_path ./.. ++failed++ |
|
norm_path ../. ++failed++ |
|
norm_path ./../.// ++failed++ |
|
norm_path dir/.. "" |
|
norm_path dir/sub/../.. "" |
|
norm_path dir/sub/../../.. ++failed++ |
|
norm_path dir dir |
|
norm_path dir// dir/ |
|
norm_path ./dir dir |
|
norm_path dir/. dir/ |
|
norm_path dir///./ dir/ |
|
norm_path dir//sub/.. dir/ |
|
norm_path dir/sub/../ dir/ |
|
norm_path dir/sub/../. dir/ |
|
norm_path dir/s1/../s2/ dir/s2/ |
|
norm_path d1/s1///s2/..//../s3/ d1/s3/ |
|
norm_path d1/s1//../s2/../../d2 d2 |
|
norm_path d1/.../d2 d1/.../d2 |
|
norm_path d1/..././../d2 d1/d2 |
|
|
|
norm_path / / |
|
norm_path // / POSIX |
|
norm_path /// / POSIX |
|
norm_path /. / |
|
norm_path /./ / POSIX |
|
norm_path /./.. ++failed++ POSIX |
|
norm_path /../. ++failed++ |
|
norm_path /./../.// ++failed++ POSIX |
|
norm_path /dir/.. / POSIX |
|
norm_path /dir/sub/../.. / POSIX |
|
norm_path /dir/sub/../../.. ++failed++ POSIX |
|
norm_path /dir /dir |
|
norm_path /dir// /dir/ |
|
norm_path /./dir /dir |
|
norm_path /dir/. /dir/ |
|
norm_path /dir///./ /dir/ |
|
norm_path /dir//sub/.. /dir/ |
|
norm_path /dir/sub/../ /dir/ |
|
norm_path //dir/sub/../. /dir/ POSIX |
|
norm_path /dir/s1/../s2/ /dir/s2/ |
|
norm_path /d1/s1///s2/..//../s3/ /d1/s3/ |
|
norm_path /d1/s1//../s2/../../d2 /d2 |
|
norm_path /d1/.../d2 /d1/.../d2 |
|
norm_path /d1/..././../d2 /d1/d2 |
|
|
|
ancestor / / -1 |
|
ancestor /foo / 0 |
|
ancestor /foo /fo -1 |
|
ancestor /foo /foo -1 |
|
ancestor /foo /bar -1 |
|
ancestor /foo /foo/bar -1 |
|
ancestor /foo /foo:/bar -1 |
|
ancestor /foo /:/foo:/bar 0 |
|
ancestor /foo /foo:/:/bar 0 |
|
ancestor /foo /:/bar:/foo 0 |
|
ancestor /foo/bar / 0 |
|
ancestor /foo/bar /fo -1 |
|
ancestor /foo/bar /foo 4 |
|
ancestor /foo/bar /foo/ba -1 |
|
ancestor /foo/bar /:/fo 0 |
|
ancestor /foo/bar /foo:/foo/ba 4 |
|
ancestor /foo/bar /bar -1 |
|
ancestor /foo/bar /fo -1 |
|
ancestor /foo/bar /foo:/bar 4 |
|
ancestor /foo/bar /:/foo:/bar 4 |
|
ancestor /foo/bar /foo:/:/bar 4 |
|
ancestor /foo/bar /:/bar:/fo 0 |
|
ancestor /foo/bar /:/bar 0 |
|
ancestor /foo/bar /foo 4 |
|
ancestor /foo/bar /foo:/bar 4 |
|
ancestor /foo/bar /bar -1 |
|
|
|
test_expect_success 'strip_path_suffix' ' |
|
test c:/msysgit = $(test-path-utils strip_path_suffix \ |
|
c:/msysgit/libexec//git-core libexec/git-core) |
|
' |
|
|
|
test_expect_success 'absolute path rejects the empty string' ' |
|
test_must_fail test-path-utils absolute_path "" |
|
' |
|
|
|
test_expect_success 'real path rejects the empty string' ' |
|
test_must_fail test-path-utils real_path "" |
|
' |
|
|
|
test_expect_success POSIX 'real path works on absolute paths 1' ' |
|
nopath="hopefully-absent-path" && |
|
test "/" = "$(test-path-utils real_path "/")" && |
|
test "/$nopath" = "$(test-path-utils real_path "/$nopath")" |
|
' |
|
|
|
test_expect_success 'real path works on absolute paths 2' ' |
|
nopath="hopefully-absent-path" && |
|
# Find an existing top-level directory for the remaining tests: |
|
d=$(pwd -P | sed -e "s|^\([^/]*/[^/]*\)/.*|\1|") && |
|
test "$d" = "$(test-path-utils real_path "$d")" && |
|
test "$d/$nopath" = "$(test-path-utils real_path "$d/$nopath")" |
|
' |
|
|
|
test_expect_success POSIX 'real path removes extra leading slashes' ' |
|
nopath="hopefully-absent-path" && |
|
test "/" = "$(test-path-utils real_path "///")" && |
|
test "/$nopath" = "$(test-path-utils real_path "///$nopath")" && |
|
# Find an existing top-level directory for the remaining tests: |
|
d=$(pwd -P | sed -e "s|^\([^/]*/[^/]*\)/.*|\1|") && |
|
test "$d" = "$(test-path-utils real_path "//$d")" && |
|
test "$d/$nopath" = "$(test-path-utils real_path "//$d/$nopath")" |
|
' |
|
|
|
test_expect_success 'real path removes other extra slashes' ' |
|
nopath="hopefully-absent-path" && |
|
# Find an existing top-level directory for the remaining tests: |
|
d=$(pwd -P | sed -e "s|^\([^/]*/[^/]*\)/.*|\1|") && |
|
test "$d" = "$(test-path-utils real_path "$d///")" && |
|
test "$d/$nopath" = "$(test-path-utils real_path "$d///$nopath")" |
|
' |
|
|
|
test_expect_success SYMLINKS 'real path works on symlinks' ' |
|
mkdir first && |
|
ln -s ../.git first/.git && |
|
mkdir second && |
|
ln -s ../first second/other && |
|
mkdir third && |
|
dir="$(cd .git; pwd -P)" && |
|
dir2=third/../second/other/.git && |
|
test "$dir" = "$(test-path-utils real_path $dir2)" && |
|
file="$dir"/index && |
|
test "$file" = "$(test-path-utils real_path $dir2/index)" && |
|
basename=blub && |
|
test "$dir/$basename" = "$(cd .git && test-path-utils real_path "$basename")" && |
|
ln -s ../first/file .git/syml && |
|
sym="$(cd first; pwd -P)"/file && |
|
test "$sym" = "$(test-path-utils real_path "$dir2/syml")" |
|
' |
|
|
|
test_expect_success SYMLINKS 'prefix_path works with absolute paths to work tree symlinks' ' |
|
ln -s target symlink && |
|
test "$(test-path-utils prefix_path prefix "$(pwd)/symlink")" = "symlink" |
|
' |
|
|
|
test_expect_success 'prefix_path works with only absolute path to work tree' ' |
|
echo "" >expected && |
|
test-path-utils prefix_path prefix "$(pwd)" >actual && |
|
test_cmp expected actual |
|
' |
|
|
|
test_expect_success 'prefix_path rejects absolute path to dir with same beginning as work tree' ' |
|
test_must_fail test-path-utils prefix_path prefix "$(pwd)a" |
|
' |
|
|
|
test_expect_success SYMLINKS 'prefix_path works with absolute path to a symlink to work tree having same beginning as work tree' ' |
|
git init repo && |
|
ln -s repo repolink && |
|
test "a" = "$(cd repo && test-path-utils prefix_path prefix "$(pwd)/../repolink/a")" |
|
' |
|
|
|
relative_path /foo/a/b/c/ /foo/a/b/ c/ |
|
relative_path /foo/a/b/c/ /foo/a/b c/ |
|
relative_path /foo/a//b//c/ ///foo/a/b// c/ POSIX |
|
relative_path /foo/a/b /foo/a/b ./ |
|
relative_path /foo/a/b/ /foo/a/b ./ |
|
relative_path /foo/a /foo/a/b ../ |
|
relative_path / /foo/a/b/ ../../../ |
|
relative_path /foo/a/c /foo/a/b/ ../c |
|
relative_path /foo/a/c /foo/a/b ../c |
|
relative_path /foo/x/y /foo/a/b/ ../../x/y |
|
relative_path /foo/a/b "<empty>" /foo/a/b |
|
relative_path /foo/a/b "<null>" /foo/a/b |
|
relative_path foo/a/b/c/ foo/a/b/ c/ |
|
relative_path foo/a/b/c/ foo/a/b c/ |
|
relative_path foo/a/b//c foo/a//b c |
|
relative_path foo/a/b/ foo/a/b/ ./ |
|
relative_path foo/a/b/ foo/a/b ./ |
|
relative_path foo/a foo/a/b ../ |
|
relative_path foo/x/y foo/a/b ../../x/y |
|
relative_path foo/a/c foo/a/b ../c |
|
relative_path foo/a/b /foo/x/y foo/a/b |
|
relative_path /foo/a/b foo/x/y /foo/a/b |
|
relative_path d:/a/b D:/a/c ../b MINGW |
|
relative_path C:/a/b D:/a/c C:/a/b MINGW |
|
relative_path foo/a/b "<empty>" foo/a/b |
|
relative_path foo/a/b "<null>" foo/a/b |
|
relative_path "<empty>" /foo/a/b ./ |
|
relative_path "<empty>" "<empty>" ./ |
|
relative_path "<empty>" "<null>" ./ |
|
relative_path "<null>" "<empty>" ./ |
|
relative_path "<null>" "<null>" ./ |
|
relative_path "<null>" /foo/a/b ./ |
|
|
|
test_git_path A=B info/grafts .git/info/grafts |
|
test_git_path GIT_GRAFT_FILE=foo info/grafts foo |
|
test_git_path GIT_GRAFT_FILE=foo info/////grafts foo |
|
test_git_path GIT_INDEX_FILE=foo index foo |
|
test_git_path GIT_INDEX_FILE=foo index/foo .git/index/foo |
|
test_git_path GIT_INDEX_FILE=foo index2 .git/index2 |
|
test_expect_success 'setup fake objects directory foo' 'mkdir foo' |
|
test_git_path GIT_OBJECT_DIRECTORY=foo objects foo |
|
test_git_path GIT_OBJECT_DIRECTORY=foo objects/foo foo/foo |
|
test_git_path GIT_OBJECT_DIRECTORY=foo objects2 .git/objects2 |
|
test_expect_success 'setup common repository' 'git --git-dir=bar init' |
|
test_git_path GIT_COMMON_DIR=bar index .git/index |
|
test_git_path GIT_COMMON_DIR=bar HEAD .git/HEAD |
|
test_git_path GIT_COMMON_DIR=bar logs/HEAD .git/logs/HEAD |
|
test_git_path GIT_COMMON_DIR=bar logs/refs/bisect/foo .git/logs/refs/bisect/foo |
|
test_git_path GIT_COMMON_DIR=bar logs/refs/bisec/foo bar/logs/refs/bisec/foo |
|
test_git_path GIT_COMMON_DIR=bar logs/refs/bisec bar/logs/refs/bisec |
|
test_git_path GIT_COMMON_DIR=bar logs/refs/bisectfoo bar/logs/refs/bisectfoo |
|
test_git_path GIT_COMMON_DIR=bar objects bar/objects |
|
test_git_path GIT_COMMON_DIR=bar objects/bar bar/objects/bar |
|
test_git_path GIT_COMMON_DIR=bar info/exclude bar/info/exclude |
|
test_git_path GIT_COMMON_DIR=bar info/grafts bar/info/grafts |
|
test_git_path GIT_COMMON_DIR=bar info/sparse-checkout .git/info/sparse-checkout |
|
test_git_path GIT_COMMON_DIR=bar info//sparse-checkout .git/info//sparse-checkout |
|
test_git_path GIT_COMMON_DIR=bar remotes/bar bar/remotes/bar |
|
test_git_path GIT_COMMON_DIR=bar branches/bar bar/branches/bar |
|
test_git_path GIT_COMMON_DIR=bar logs/refs/heads/master bar/logs/refs/heads/master |
|
test_git_path GIT_COMMON_DIR=bar refs/heads/master bar/refs/heads/master |
|
test_git_path GIT_COMMON_DIR=bar refs/bisect/foo .git/refs/bisect/foo |
|
test_git_path GIT_COMMON_DIR=bar hooks/me bar/hooks/me |
|
test_git_path GIT_COMMON_DIR=bar config bar/config |
|
test_git_path GIT_COMMON_DIR=bar packed-refs bar/packed-refs |
|
test_git_path GIT_COMMON_DIR=bar shallow bar/shallow |
|
|
|
# In the tests below, $(pwd) must be used because it is a native path on |
|
# Windows and avoids MSYS's path mangling (which simplifies "foo/../bar" and |
|
# strips the dot from trailing "/."). |
|
|
|
test_submodule_relative_url "../" "../foo" "../submodule" "../../submodule" |
|
test_submodule_relative_url "../" "../foo/bar" "../submodule" "../../foo/submodule" |
|
test_submodule_relative_url "../" "../foo/submodule" "../submodule" "../../foo/submodule" |
|
test_submodule_relative_url "../" "./foo" "../submodule" "../submodule" |
|
test_submodule_relative_url "../" "./foo/bar" "../submodule" "../foo/submodule" |
|
test_submodule_relative_url "../../../" "../foo/bar" "../sub/a/b/c" "../../../../foo/sub/a/b/c" |
|
test_submodule_relative_url "../" "$(pwd)/addtest" "../repo" "$(pwd)/repo" |
|
test_submodule_relative_url "../" "foo/bar" "../submodule" "../foo/submodule" |
|
test_submodule_relative_url "../" "foo" "../submodule" "../submodule" |
|
|
|
test_submodule_relative_url "(null)" "../foo/bar" "../sub/a/b/c" "../foo/sub/a/b/c" |
|
test_submodule_relative_url "(null)" "../foo/bar" "../sub/a/b/c/" "../foo/sub/a/b/c" |
|
test_submodule_relative_url "(null)" "../foo/bar/" "../sub/a/b/c" "../foo/sub/a/b/c" |
|
test_submodule_relative_url "(null)" "../foo/bar" "../submodule" "../foo/submodule" |
|
test_submodule_relative_url "(null)" "../foo/submodule" "../submodule" "../foo/submodule" |
|
test_submodule_relative_url "(null)" "../foo" "../submodule" "../submodule" |
|
test_submodule_relative_url "(null)" "./foo/bar" "../submodule" "foo/submodule" |
|
test_submodule_relative_url "(null)" "./foo" "../submodule" "submodule" |
|
test_submodule_relative_url "(null)" "//somewhere else/repo" "../subrepo" "//somewhere else/subrepo" |
|
test_submodule_relative_url "(null)" "$(pwd)/subsuper_update_r" "../subsubsuper_update_r" "$(pwd)/subsubsuper_update_r" |
|
test_submodule_relative_url "(null)" "$(pwd)/super_update_r2" "../subsuper_update_r" "$(pwd)/subsuper_update_r" |
|
test_submodule_relative_url "(null)" "$(pwd)/." "../." "$(pwd)/." |
|
test_submodule_relative_url "(null)" "$(pwd)" "./." "$(pwd)/." |
|
test_submodule_relative_url "(null)" "$(pwd)/addtest" "../repo" "$(pwd)/repo" |
|
test_submodule_relative_url "(null)" "$(pwd)" "./å äö" "$(pwd)/å äö" |
|
test_submodule_relative_url "(null)" "$(pwd)/." "../submodule" "$(pwd)/submodule" |
|
test_submodule_relative_url "(null)" "$(pwd)/submodule" "../submodule" "$(pwd)/submodule" |
|
test_submodule_relative_url "(null)" "$(pwd)/home2/../remote" "../bundle1" "$(pwd)/home2/../bundle1" |
|
test_submodule_relative_url "(null)" "$(pwd)/submodule_update_repo" "./." "$(pwd)/submodule_update_repo/." |
|
test_submodule_relative_url "(null)" "file:///tmp/repo" "../subrepo" "file:///tmp/subrepo" |
|
test_submodule_relative_url "(null)" "foo/bar" "../submodule" "foo/submodule" |
|
test_submodule_relative_url "(null)" "foo" "../submodule" "submodule" |
|
test_submodule_relative_url "(null)" "helper:://hostname/repo" "../subrepo" "helper:://hostname/subrepo" |
|
test_submodule_relative_url "(null)" "ssh://hostname/repo" "../subrepo" "ssh://hostname/subrepo" |
|
test_submodule_relative_url "(null)" "ssh://hostname:22/repo" "../subrepo" "ssh://hostname:22/subrepo" |
|
test_submodule_relative_url "(null)" "user@host:path/to/repo" "../subrepo" "user@host:path/to/subrepo" |
|
test_submodule_relative_url "(null)" "user@host:repo" "../subrepo" "user@host:subrepo" |
|
|
|
test_done
|
|
|