| #!/bin/sh |
| # |
| # Copyright (c) 2006 Junio C Hamano |
| # |
| |
| test_description='Try various core-level commands in subdirectory. |
| ' |
| |
| . ./test-lib.sh |
| . "$TEST_DIRECTORY"/lib-read-tree.sh |
| |
| test_expect_success setup ' |
| long="a b c d e f g h i j k l m n o p q r s t u v w x y z" && |
| for c in $long; do echo $c; done >one && |
| mkdir dir && |
| for c in x y z $long a b c; do echo $c; done >dir/two && |
| cp one original.one && |
| cp dir/two original.two |
| ' |
| |
| test_expect_success 'update-index and ls-files' ' |
| git update-index --add one && |
| case "`git ls-files`" in |
| one) echo pass one ;; |
| *) echo bad one; exit 1 ;; |
| esac && |
| ( |
| cd dir && |
| git update-index --add two && |
| case "`git ls-files`" in |
| two) echo pass two ;; |
| *) echo bad two; exit 1 ;; |
| esac |
| ) && |
| case "`git ls-files`" in |
| dir/two"$LF"one) echo pass both ;; |
| *) echo bad; exit 1 ;; |
| esac |
| ' |
| |
| test_expect_success 'cat-file' ' |
| two=`git ls-files -s dir/two` && |
| two=`expr "$two" : "[0-7]* \\([0-9a-f]*\\)"` && |
| echo "$two" && |
| git cat-file -p "$two" >actual && |
| cmp dir/two actual && |
| ( |
| cd dir && |
| git cat-file -p "$two" >actual && |
| cmp two actual |
| ) |
| ' |
| rm -f actual dir/actual |
| |
| test_expect_success 'diff-files' ' |
| echo a >>one && |
| echo d >>dir/two && |
| case "`git diff-files --name-only`" in |
| dir/two"$LF"one) echo pass top ;; |
| *) echo bad top; exit 1 ;; |
| esac && |
| # diff should not omit leading paths |
| ( |
| cd dir && |
| case "`git diff-files --name-only`" in |
| dir/two"$LF"one) echo pass subdir ;; |
| *) echo bad subdir; exit 1 ;; |
| esac && |
| case "`git diff-files --name-only .`" in |
| dir/two) echo pass subdir limited ;; |
| *) echo bad subdir limited; exit 1 ;; |
| esac |
| ) |
| ' |
| |
| test_expect_success 'write-tree' ' |
| top=`git write-tree` && |
| echo $top && |
| ( |
| cd dir && |
| sub=`git write-tree` && |
| echo $sub && |
| test "z$top" = "z$sub" |
| ) |
| ' |
| |
| test_expect_success 'checkout-index' ' |
| git checkout-index -f -u one && |
| cmp one original.one && |
| ( |
| cd dir && |
| git checkout-index -f -u two && |
| cmp two ../original.two |
| ) |
| ' |
| |
| test_expect_success 'read-tree' ' |
| rm -f one dir/two && |
| tree=`git write-tree` && |
| read_tree_u_must_succeed --reset -u "$tree" && |
| cmp one original.one && |
| cmp dir/two original.two && |
| ( |
| cd dir && |
| rm -f two && |
| read_tree_u_must_succeed --reset -u "$tree" && |
| cmp two ../original.two && |
| cmp ../one ../original.one |
| ) |
| ' |
| |
| test_expect_success 'alias expansion' ' |
| ( |
| git config alias.ss status && |
| cd dir && |
| git status && |
| git ss |
| ) |
| ' |
| |
| test_expect_success '!alias expansion' ' |
| pwd >expect && |
| ( |
| git config alias.test !pwd && |
| cd dir && |
| git test >../actual |
| ) && |
| test_cmp expect actual |
| ' |
| |
| test_expect_success 'GIT_PREFIX for !alias' ' |
| printf "dir/" >expect && |
| ( |
| git config alias.test "!sh -c \"printf \$GIT_PREFIX\"" && |
| cd dir && |
| git test >../actual |
| ) && |
| test_cmp expect actual |
| ' |
| |
| test_expect_success 'GIT_PREFIX for built-ins' ' |
| # Use GIT_EXTERNAL_DIFF to test that the "diff" built-in |
| # receives the GIT_PREFIX variable. |
| printf "dir/" >expect && |
| printf "#!/bin/sh\n" >diff && |
| printf "printf \"\$GIT_PREFIX\"" >>diff && |
| chmod +x diff && |
| ( |
| cd dir && |
| printf "change" >two && |
| env GIT_EXTERNAL_DIFF=./diff git diff >../actual |
| git checkout -- two |
| ) && |
| test_cmp expect actual |
| ' |
| |
| test_expect_success 'no file/rev ambiguity check inside .git' ' |
| git commit -a -m 1 && |
| ( |
| cd .git && |
| git show -s HEAD |
| ) |
| ' |
| |
| test_expect_success 'no file/rev ambiguity check inside a bare repo' ' |
| git clone -s --bare .git foo.git && |
| ( |
| cd foo.git && |
| GIT_DIR=. git show -s HEAD |
| ) |
| ' |
| |
| # This still does not work as it should... |
| : test_expect_success 'no file/rev ambiguity check inside a bare repo' ' |
| git clone -s --bare .git foo.git && |
| ( |
| cd foo.git && |
| git show -s HEAD |
| ) |
| ' |
| |
| test_expect_success SYMLINKS 'detection should not be fooled by a symlink' ' |
| rm -fr foo.git && |
| git clone -s .git another && |
| ln -s another yetanother && |
| ( |
| cd yetanother/.git && |
| git show -s HEAD |
| ) |
| ' |
| |
| test_done |