|  | #!/bin/sh | 
|  | # | 
|  | # Copyright (c) 2005 Junio C Hamano | 
|  | # | 
|  |  | 
|  | test_description='Pathspec restrictions | 
|  |  | 
|  | Prepare: | 
|  | file0 | 
|  | path1/file1 | 
|  | ' | 
|  | . ./test-lib.sh | 
|  | . "$TEST_DIRECTORY"/diff-lib.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 |