#!/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_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*) ;; *) test_set_prereq POSIX ;; esac 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 "" /foo/a/b relative_path /foo/a/b "" /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 "" foo/a/b relative_path foo/a/b "" foo/a/b relative_path "" /foo/a/b ./ relative_path "" "" ./ relative_path "" "" ./ relative_path "" "" ./ relative_path "" "" ./ relative_path "" /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 test_done