mirror of
https://github.com/git/git.git
synced 2025-01-06 15:43:47 +08:00
a4d4e32a70
Avoid using pipes downstream of Git commands since the exit codes of commands upstream of pipes get swallowed, thus potentially hiding failure of those commands. Instead, capture Git command output to a file and apply the downstream command(s) to that file. Signed-off-by: Pratik Karki <predatoramigo@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
168 lines
5.7 KiB
Bash
Executable File
168 lines
5.7 KiB
Bash
Executable File
#!/bin/sh
|
|
# Copyright (c) 2007 Eric Wong
|
|
test_description='git svn globbing refspecs'
|
|
. ./lib-git-svn.sh
|
|
|
|
cat > expect.end <<EOF
|
|
the end
|
|
hi
|
|
start a new branch
|
|
initial
|
|
EOF
|
|
|
|
test_expect_success 'test refspec globbing' '
|
|
mkdir -p trunk/src/a trunk/src/b trunk/doc &&
|
|
echo "hello world" > trunk/src/a/readme &&
|
|
echo "goodbye world" > trunk/src/b/readme &&
|
|
svn_cmd import -m "initial" trunk "$svnrepo"/trunk &&
|
|
svn_cmd co "$svnrepo" tmp &&
|
|
(
|
|
cd tmp &&
|
|
mkdir branches branches/v1 tags &&
|
|
svn_cmd add branches tags &&
|
|
svn_cmd cp trunk branches/v1/start &&
|
|
svn_cmd commit -m "start a new branch" &&
|
|
svn_cmd up &&
|
|
echo "hi" >> branches/v1/start/src/b/readme &&
|
|
poke branches/v1/start/src/b/readme &&
|
|
echo "hey" >> branches/v1/start/src/a/readme &&
|
|
poke branches/v1/start/src/a/readme &&
|
|
svn_cmd commit -m "hi" &&
|
|
svn_cmd up &&
|
|
svn_cmd cp branches/v1/start tags/end &&
|
|
echo "bye" >> tags/end/src/b/readme &&
|
|
poke tags/end/src/b/readme &&
|
|
echo "aye" >> tags/end/src/a/readme &&
|
|
poke tags/end/src/a/readme &&
|
|
svn_cmd commit -m "the end" &&
|
|
echo "byebye" >> tags/end/src/b/readme &&
|
|
poke tags/end/src/b/readme &&
|
|
svn_cmd commit -m "nothing to see here"
|
|
) &&
|
|
git config --add svn-remote.svn.url "$svnrepo" &&
|
|
git config --add svn-remote.svn.fetch \
|
|
"trunk/src/a:refs/remotes/trunk" &&
|
|
git config --add svn-remote.svn.branches \
|
|
"branches/*/*/src/a:refs/remotes/branches/*/*" &&
|
|
git config --add svn-remote.svn.tags\
|
|
"tags/*/src/a:refs/remotes/tags/*" &&
|
|
git svn multi-fetch &&
|
|
git log --pretty=oneline refs/remotes/tags/end >actual &&
|
|
sed -e "s/^.\{41\}//" actual >output.end &&
|
|
test_cmp expect.end output.end &&
|
|
test "$(git rev-parse refs/remotes/tags/end~1)" = \
|
|
"$(git rev-parse refs/remotes/branches/v1/start)" &&
|
|
test "$(git rev-parse refs/remotes/branches/v1/start~2)" = \
|
|
"$(git rev-parse refs/remotes/trunk)" &&
|
|
test_must_fail git rev-parse refs/remotes/tags/end@3
|
|
'
|
|
|
|
echo try to try > expect.two
|
|
echo nothing to see here >> expect.two
|
|
cat expect.end >> expect.two
|
|
|
|
test_expect_success 'test left-hand-side only globbing' '
|
|
git config --add svn-remote.two.url "$svnrepo" &&
|
|
git config --add svn-remote.two.fetch trunk:refs/remotes/two/trunk &&
|
|
git config --add svn-remote.two.branches \
|
|
"branches/*/*:refs/remotes/two/branches/*/*" &&
|
|
git config --add svn-remote.two.tags \
|
|
"tags/*:refs/remotes/two/tags/*" &&
|
|
(
|
|
cd tmp &&
|
|
echo "try try" >> tags/end/src/b/readme &&
|
|
poke tags/end/src/b/readme &&
|
|
svn_cmd commit -m "try to try"
|
|
) &&
|
|
git svn fetch two &&
|
|
git rev-list refs/remotes/two/tags/end >actual &&
|
|
test_line_count = 6 actual &&
|
|
git rev-list refs/remotes/two/branches/v1/start >actual &&
|
|
test_line_count = 3 actual &&
|
|
test $(git rev-parse refs/remotes/two/branches/v1/start~2) = \
|
|
$(git rev-parse refs/remotes/two/trunk) &&
|
|
test $(git rev-parse refs/remotes/two/tags/end~3) = \
|
|
$(git rev-parse refs/remotes/two/branches/v1/start) &&
|
|
git log --pretty=oneline refs/remotes/two/tags/end >actual &&
|
|
sed -e "s/^.\{41\}//" actual >output.two &&
|
|
test_cmp expect.two output.two
|
|
'
|
|
cat > expect.four <<EOF
|
|
adios
|
|
adding more
|
|
Changed 2 in v2/start
|
|
Another versioned branch
|
|
initial
|
|
EOF
|
|
|
|
test_expect_success 'test another branch' '
|
|
(
|
|
cd tmp &&
|
|
mkdir branches/v2 &&
|
|
svn_cmd add branches/v2 &&
|
|
svn_cmd cp trunk branches/v2/start &&
|
|
svn_cmd commit -m "Another versioned branch" &&
|
|
svn_cmd up &&
|
|
echo "hello" >> branches/v2/start/src/b/readme &&
|
|
poke branches/v2/start/src/b/readme &&
|
|
echo "howdy" >> branches/v2/start/src/a/readme &&
|
|
poke branches/v2/start/src/a/readme &&
|
|
svn_cmd commit -m "Changed 2 in v2/start" &&
|
|
svn_cmd up &&
|
|
svn_cmd cp branches/v2/start tags/next &&
|
|
echo "bye" >> tags/next/src/b/readme &&
|
|
poke tags/next/src/b/readme &&
|
|
echo "aye" >> tags/next/src/a/readme &&
|
|
poke tags/next/src/a/readme &&
|
|
svn_cmd commit -m "adding more" &&
|
|
echo "byebye" >> tags/next/src/b/readme &&
|
|
poke tags/next/src/b/readme &&
|
|
svn_cmd commit -m "adios"
|
|
) &&
|
|
git config --add svn-remote.four.url "$svnrepo" &&
|
|
git config --add svn-remote.four.fetch trunk:refs/remotes/four/trunk &&
|
|
git config --add svn-remote.four.branches \
|
|
"branches/*/*:refs/remotes/four/branches/*/*" &&
|
|
git config --add svn-remote.four.tags \
|
|
"tags/*:refs/remotes/four/tags/*" &&
|
|
git svn fetch four &&
|
|
git rev-list refs/remotes/four/tags/next >actual &&
|
|
test_line_count = 5 actual &&
|
|
git rev-list refs/remotes/four/branches/v2/start >actual &&
|
|
test_line_count = 3 actual &&
|
|
test $(git rev-parse refs/remotes/four/branches/v2/start~2) = \
|
|
$(git rev-parse refs/remotes/four/trunk) &&
|
|
test $(git rev-parse refs/remotes/four/tags/next~2) = \
|
|
$(git rev-parse refs/remotes/four/branches/v2/start) &&
|
|
git log --pretty=oneline refs/remotes/four/tags/next >actual &&
|
|
sed -e "s/^.\{41\}//" actual >output.four &&
|
|
test_cmp expect.four output.four
|
|
'
|
|
|
|
test_expect_success 'prepare test disallow multiple globs' "
|
|
cat >expect.three <<EOF
|
|
Only one set of wildcards (e.g. '*' or '*/*/*') is supported: branches/*/t/*
|
|
|
|
EOF
|
|
"
|
|
|
|
test_expect_success 'test disallow multiple globs' '
|
|
git config --add svn-remote.three.url "$svnrepo" &&
|
|
git config --add svn-remote.three.fetch \
|
|
trunk:refs/remotes/three/trunk &&
|
|
git config --add svn-remote.three.branches \
|
|
"branches/*/t/*:refs/remotes/three/branches/*/*" &&
|
|
git config --add svn-remote.three.tags \
|
|
"tags/*:refs/remotes/three/tags/*" &&
|
|
(
|
|
cd tmp &&
|
|
echo "try try" >> tags/end/src/b/readme &&
|
|
poke tags/end/src/b/readme &&
|
|
svn_cmd commit -m "try to try"
|
|
) &&
|
|
test_must_fail git svn fetch three 2> stderr.three &&
|
|
test_cmp expect.three stderr.three
|
|
'
|
|
|
|
test_done
|