2016-12-16 20:03:20 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='Test grep recurse-submodules feature
|
|
|
|
|
|
|
|
This test verifies the recurse-submodules feature correctly greps across
|
|
|
|
submodules.
|
|
|
|
'
|
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
|
|
|
test_expect_success 'setup directory structure and submodule' '
|
|
|
|
echo "foobar" >a &&
|
|
|
|
mkdir b &&
|
|
|
|
echo "bar" >b/b &&
|
|
|
|
git add a b &&
|
|
|
|
git commit -m "add a and b" &&
|
|
|
|
git init submodule &&
|
|
|
|
echo "foobar" >submodule/a &&
|
|
|
|
git -C submodule add a &&
|
|
|
|
git -C submodule commit -m "add a" &&
|
|
|
|
git submodule add ./submodule &&
|
|
|
|
git commit -m "added submodule"
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep correctly finds patterns in a submodule' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
a:foobar
|
|
|
|
b/b:bar
|
|
|
|
submodule/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep and basic pathspecs' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
submodule/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e. --recurse-submodules -- submodule >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep and nested submodules' '
|
|
|
|
git init submodule/sub &&
|
|
|
|
echo "foobar" >submodule/sub/a &&
|
|
|
|
git -C submodule/sub add a &&
|
|
|
|
git -C submodule/sub commit -m "add a" &&
|
|
|
|
git -C submodule submodule add ./sub &&
|
|
|
|
git -C submodule add sub &&
|
|
|
|
git -C submodule commit -m "added sub" &&
|
|
|
|
git add submodule &&
|
|
|
|
git commit -m "updated submodule" &&
|
|
|
|
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
a:foobar
|
|
|
|
b/b:bar
|
|
|
|
submodule/a:foobar
|
|
|
|
submodule/sub/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep and multiple patterns' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
a:foobar
|
|
|
|
submodule/a:foobar
|
|
|
|
submodule/sub/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --and -e "foo" --recurse-submodules >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep and multiple patterns' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
b/b:bar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --and --not -e "foo" --recurse-submodules >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2016-12-16 20:03:21 +01:00
|
|
|
test_expect_success 'basic grep tree' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD:a:foobar
|
|
|
|
HEAD:b/b:bar
|
|
|
|
HEAD:submodule/a:foobar
|
|
|
|
HEAD:submodule/sub/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep tree HEAD^' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD^:a:foobar
|
|
|
|
HEAD^:b/b:bar
|
|
|
|
HEAD^:submodule/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules HEAD^ >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep tree HEAD^^' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD^^:a:foobar
|
|
|
|
HEAD^^:b/b:bar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules HEAD^^ >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep tree and pathspecs' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD:submodule/a:foobar
|
|
|
|
HEAD:submodule/sub/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules HEAD -- submodule >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep tree and pathspecs' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD:submodule/a:foobar
|
|
|
|
HEAD:submodule/sub/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules HEAD -- "submodule*a" >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep tree and more pathspecs' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD:submodule/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules HEAD -- "submodul?/a" >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep tree and more pathspecs' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD:submodule/sub/a:foobar
|
|
|
|
EOF
|
|
|
|
|
|
|
|
git grep -e "bar" --recurse-submodules HEAD -- "submodul*/sub/a" >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success !MINGW 'grep recurse submodule colon in name' '
|
|
|
|
git init parent &&
|
|
|
|
test_when_finished "rm -rf parent" &&
|
|
|
|
echo "foobar" >"parent/fi:le" &&
|
|
|
|
git -C parent add "fi:le" &&
|
|
|
|
git -C parent commit -m "add fi:le" &&
|
|
|
|
|
|
|
|
git init "su:b" &&
|
|
|
|
test_when_finished "rm -rf su:b" &&
|
|
|
|
echo "foobar" >"su:b/fi:le" &&
|
|
|
|
git -C "su:b" add "fi:le" &&
|
|
|
|
git -C "su:b" commit -m "add fi:le" &&
|
|
|
|
|
|
|
|
git -C parent submodule add "../su:b" "su:b" &&
|
|
|
|
git -C parent commit -m "add submodule" &&
|
|
|
|
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
fi:le:foobar
|
|
|
|
su:b/fi:le:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent grep -e "foobar" --recurse-submodules >actual &&
|
|
|
|
test_cmp expect actual &&
|
|
|
|
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD:fi:le:foobar
|
|
|
|
HEAD:su:b/fi:le:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent grep -e "foobar" --recurse-submodules HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2016-12-16 20:03:22 +01:00
|
|
|
test_expect_success 'grep history with moved submoules' '
|
|
|
|
git init parent &&
|
|
|
|
test_when_finished "rm -rf parent" &&
|
|
|
|
echo "foobar" >parent/file &&
|
|
|
|
git -C parent add file &&
|
|
|
|
git -C parent commit -m "add file" &&
|
|
|
|
|
|
|
|
git init sub &&
|
|
|
|
test_when_finished "rm -rf sub" &&
|
|
|
|
echo "foobar" >sub/file &&
|
|
|
|
git -C sub add file &&
|
|
|
|
git -C sub commit -m "add file" &&
|
|
|
|
|
|
|
|
git -C parent submodule add ../sub dir/sub &&
|
|
|
|
git -C parent commit -m "add submodule" &&
|
|
|
|
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
dir/sub/file:foobar
|
|
|
|
file:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent grep -e "foobar" --recurse-submodules >actual &&
|
|
|
|
test_cmp expect actual &&
|
|
|
|
|
|
|
|
git -C parent mv dir/sub sub-moved &&
|
|
|
|
git -C parent commit -m "moved submodule" &&
|
|
|
|
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
file:foobar
|
|
|
|
sub-moved/file:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent grep -e "foobar" --recurse-submodules >actual &&
|
|
|
|
test_cmp expect actual &&
|
|
|
|
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
HEAD^:dir/sub/file:foobar
|
|
|
|
HEAD^:file:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent grep -e "foobar" --recurse-submodules HEAD^ >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2017-03-17 18:22:55 +01:00
|
|
|
test_expect_success 'grep using relative path' '
|
|
|
|
test_when_finished "rm -rf parent sub" &&
|
|
|
|
git init sub &&
|
|
|
|
echo "foobar" >sub/file &&
|
|
|
|
git -C sub add file &&
|
|
|
|
git -C sub commit -m "add file" &&
|
|
|
|
|
|
|
|
git init parent &&
|
|
|
|
echo "foobar" >parent/file &&
|
|
|
|
git -C parent add file &&
|
|
|
|
mkdir parent/src &&
|
|
|
|
echo "foobar" >parent/src/file2 &&
|
|
|
|
git -C parent add src/file2 &&
|
|
|
|
git -C parent submodule add ../sub &&
|
|
|
|
git -C parent commit -m "add files and submodule" &&
|
|
|
|
|
|
|
|
# From top works
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
file:foobar
|
|
|
|
src/file2:foobar
|
|
|
|
sub/file:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent grep --recurse-submodules -e "foobar" >actual &&
|
|
|
|
test_cmp expect actual &&
|
|
|
|
|
|
|
|
# Relative path to top
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
../file:foobar
|
|
|
|
file2:foobar
|
|
|
|
../sub/file:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent/src grep --recurse-submodules -e "foobar" -- .. >actual &&
|
|
|
|
test_cmp expect actual &&
|
|
|
|
|
|
|
|
# Relative path to submodule
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
../sub/file:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent/src grep --recurse-submodules -e "foobar" -- ../sub >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'grep from a subdir' '
|
|
|
|
test_when_finished "rm -rf parent sub" &&
|
|
|
|
git init sub &&
|
|
|
|
echo "foobar" >sub/file &&
|
|
|
|
git -C sub add file &&
|
|
|
|
git -C sub commit -m "add file" &&
|
|
|
|
|
|
|
|
git init parent &&
|
|
|
|
mkdir parent/src &&
|
|
|
|
echo "foobar" >parent/src/file &&
|
|
|
|
git -C parent add src/file &&
|
|
|
|
git -C parent submodule add ../sub src/sub &&
|
|
|
|
git -C parent submodule add ../sub sub &&
|
|
|
|
git -C parent commit -m "add files and submodules" &&
|
|
|
|
|
|
|
|
# Verify grep from root works
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
src/file:foobar
|
|
|
|
src/sub/file:foobar
|
|
|
|
sub/file:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent grep --recurse-submodules -e "foobar" >actual &&
|
|
|
|
test_cmp expect actual &&
|
|
|
|
|
|
|
|
# Verify grep from a subdir works
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
file:foobar
|
|
|
|
sub/file:foobar
|
|
|
|
EOF
|
|
|
|
git -C parent/src grep --recurse-submodules -e "foobar" >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2016-12-16 20:03:20 +01:00
|
|
|
test_incompatible_with_recurse_submodules ()
|
|
|
|
{
|
|
|
|
test_expect_success "--recurse-submodules and $1 are incompatible" "
|
|
|
|
test_must_fail git grep -e. --recurse-submodules $1 2>actual &&
|
|
|
|
test_i18ngrep 'not supported with --recurse-submodules' actual
|
|
|
|
"
|
|
|
|
}
|
|
|
|
|
|
|
|
test_incompatible_with_recurse_submodules --untracked
|
|
|
|
test_incompatible_with_recurse_submodules --no-index
|
|
|
|
|
|
|
|
test_done
|