| #!/bin/sh |
| # |
| # Copyright (c) 2005 Junio C Hamano |
| # |
| |
| test_description='Pathspec restrictions |
| |
| Prepare: |
| file0 |
| path1/file1 |
| ' |
| |
| TEST_PASSES_SANITIZE_LEAK=true |
| . ./test-lib.sh |
| . "$TEST_DIRECTORY"/lib-diff.sh ;# test-lib chdir's into trash |
| |
| test_expect_success \ |
| setup \ |
| 'echo frotz >file0 && |
| mkdir path1 && |
| echo rezrov >path1/file1 && |
| before0=$(git hash-object file0) && |
| before1=$(git hash-object path1/file1) && |
| git update-index --add file0 path1/file1 && |
| tree=$(git write-tree) && |
| echo "$tree" && |
| echo nitfol >file0 && |
| echo yomin >path1/file1 && |
| after0=$(git hash-object file0) && |
| after1=$(git hash-object path1/file1) && |
| git update-index file0 path1/file1' |
| |
| cat >expected <<\EOF |
| EOF |
| test_expect_success \ |
| 'limit to path should show nothing' \ |
| 'git diff-index --cached $tree -- path >current && |
| compare_diff_raw current expected' |
| |
| cat >expected <<EOF |
| :100644 100644 $before1 $after1 M path1/file1 |
| EOF |
| test_expect_success \ |
| 'limit to path1 should show path1/file1' \ |
| 'git diff-index --cached $tree -- path1 >current && |
| compare_diff_raw current expected' |
| |
| cat >expected <<EOF |
| :100644 100644 $before1 $after1 M path1/file1 |
| EOF |
| test_expect_success \ |
| 'limit to path1/ should show path1/file1' \ |
| 'git diff-index --cached $tree -- path1/ >current && |
| compare_diff_raw current expected' |
| |
| cat >expected <<EOF |
| :100644 100644 $before1 $after1 M path1/file1 |
| EOF |
| test_expect_success \ |
| '"*file1" should show path1/file1' \ |
| 'git diff-index --cached $tree -- "*file1" >current && |
| compare_diff_raw current expected' |
| |
| cat >expected <<EOF |
| :100644 100644 $before0 $after0 M file0 |
| EOF |
| test_expect_success \ |
| 'limit to file0 should show file0' \ |
| 'git diff-index --cached $tree -- file0 >current && |
| compare_diff_raw current expected' |
| |
| cat >expected <<\EOF |
| EOF |
| test_expect_success \ |
| 'limit to file0/ should emit nothing.' \ |
| 'git diff-index --cached $tree -- file0/ >current && |
| compare_diff_raw current expected' |
| |
| test_expect_success 'diff-tree pathspec' ' |
| tree2=$(git write-tree) && |
| echo "$tree2" && |
| git diff-tree -r --name-only $tree $tree2 -- pa path1/a >current && |
| test_must_be_empty current |
| ' |
| |
| test_expect_success 'diff-tree with wildcard shows dir also matches' ' |
| git diff-tree --name-only $EMPTY_TREE $tree -- "f*" >result && |
| echo file0 >expected && |
| test_cmp expected result |
| ' |
| |
| test_expect_success 'diff-tree -r with wildcard' ' |
| git diff-tree -r --name-only $EMPTY_TREE $tree -- "*file1" >result && |
| echo path1/file1 >expected && |
| test_cmp expected result |
| ' |
| |
| test_expect_success 'diff-tree with wildcard shows dir also matches' ' |
| git diff-tree --name-only $tree $tree2 -- "path1/f*" >result && |
| echo path1 >expected && |
| test_cmp expected result |
| ' |
| |
| test_expect_success 'diff-tree -r with wildcard from beginning' ' |
| git diff-tree -r --name-only $tree $tree2 -- "path1/*file1" >result && |
| echo path1/file1 >expected && |
| test_cmp expected result |
| ' |
| |
| test_expect_success 'diff-tree -r with wildcard' ' |
| git diff-tree -r --name-only $tree $tree2 -- "path1/f*" >result && |
| echo path1/file1 >expected && |
| test_cmp expected result |
| ' |
| |
| test_expect_success 'setup submodules' ' |
| test_tick && |
| git init submod && |
| ( cd submod && test_commit first ) && |
| git add submod && |
| git commit -m first && |
| ( cd submod && test_commit second ) && |
| git add submod && |
| git commit -m second |
| ' |
| |
| test_expect_success 'diff-tree ignores trailing slash on submodule path' ' |
| git diff --name-only HEAD^ HEAD submod >expect && |
| git diff --name-only HEAD^ HEAD submod/ >actual && |
| test_cmp expect actual && |
| git diff --name-only HEAD^ HEAD -- submod/whatever >actual && |
| test_must_be_empty actual |
| ' |
| |
| test_expect_success 'diff multiple wildcard pathspecs' ' |
| mkdir path2 && |
| echo rezrov >path2/file1 && |
| git update-index --add path2/file1 && |
| tree3=$(git write-tree) && |
| git diff --name-only $tree $tree3 -- "path2*1" "path1*1" >actual && |
| cat <<-\EOF >expect && |
| path1/file1 |
| path2/file1 |
| EOF |
| test_cmp expect actual |
| ' |
| |
| test_expect_success 'diff-cache ignores trailing slash on submodule path' ' |
| git diff --name-only HEAD^ submod >expect && |
| git diff --name-only HEAD^ submod/ >actual && |
| test_cmp expect actual |
| ' |
| |
| test_done |