- Guard setup with test_expect_success - Single-quoted, tab prefaced test blocks Signed-off-by: Tom Grennan <tmgrennan@xxxxxxxxx> --- t/t3200-branch.sh | 211 +++++++++++++++++++++++++++-------------------------- 1 files changed, 109 insertions(+), 102 deletions(-) diff --git a/t/t3200-branch.sh b/t/t3200-branch.sh index dd1aceb..7191b89 100755 --- a/t/t3200-branch.sh +++ b/t/t3200-branch.sh @@ -7,15 +7,15 @@ test_description='git branch assorted tests' . ./test-lib.sh -test_expect_success \ - 'prepare a trivial repository' \ - 'echo Hello > A && +test_expect_success 'prepare a trivial repository' ' + echo Hello >A && git update-index --add A && git commit -m "Initial commit." && echo World >> A && git update-index --add A && git commit -m "Second commit." && - HEAD=$(git rev-parse --verify HEAD)' + HEAD=$(git rev-parse --verify HEAD) +' test_expect_success \ 'git branch --help should not have created a bogus branch' ' @@ -34,59 +34,59 @@ test_expect_success 'branch -h in broken repository' ' grep "[Uu]sage" broken/usage ' -test_expect_success \ - 'git branch abc should create a branch' \ - 'git branch abc && test_path_is_file .git/refs/heads/abc' +test_expect_success 'git branch abc should create a branch' ' + git branch abc && test_path_is_file .git/refs/heads/abc +' -test_expect_success \ - 'git branch a/b/c should create a branch' \ - 'git branch a/b/c && test_path_is_file .git/refs/heads/a/b/c' +test_expect_success 'git branch a/b/c should create a branch' ' + git branch a/b/c && test_path_is_file .git/refs/heads/a/b/c +' -cat >expect <<EOF +test_expect_success 'git branch -l d/e/f should create a branch and a log' ' + cat >expect <<-EOF $_z40 $HEAD $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> 1117150200 +0000 branch: Created from master EOF -test_expect_success \ - 'git branch -l d/e/f should create a branch and a log' \ - 'GIT_COMMITTER_DATE="2005-05-26 23:30" \ + GIT_COMMITTER_DATE="2005-05-26 23:30" \ git branch -l d/e/f && test_path_is_file .git/refs/heads/d/e/f && test_path_is_file .git/logs/refs/heads/d/e/f && - test_cmp expect .git/logs/refs/heads/d/e/f' + test_cmp expect .git/logs/refs/heads/d/e/f +' -test_expect_success \ - 'git branch -d d/e/f should delete a branch and a log' \ - 'git branch -d d/e/f && +test_expect_success 'git branch -d d/e/f should delete a branch and a log' ' + git branch -d d/e/f && test_path_is_missing .git/refs/heads/d/e/f && - test_path_is_missing .git/logs/refs/heads/d/e/f' + test_path_is_missing .git/logs/refs/heads/d/e/f +' -test_expect_success \ - 'git branch j/k should work after branch j has been deleted' \ - 'git branch j && +test_expect_success 'git branch j/k should work after branch j has been deleted' ' + git branch j && git branch -d j && - git branch j/k' + git branch j/k +' -test_expect_success \ - 'git branch l should work after branch l/m has been deleted' \ - 'git branch l/m && +test_expect_success 'git branch l should work after branch l/m has been deleted' ' + git branch l/m && git branch -d l/m && - git branch l' + git branch l +' -test_expect_success \ - 'git branch -m dumps usage' \ - 'test_expect_code 129 git branch -m 2>err && - grep "[Uu]sage: git branch" err' +test_expect_success 'git branch -m dumps usage' ' + test_expect_code 129 git branch -m 2>err && + grep "[Uu]sage: git branch" err +' -test_expect_success \ - 'git branch -m m m/m should work' \ - 'git branch -l m && +test_expect_success 'git branch -m m m/m should work' ' + git branch -l m && git branch -m m m/m && - test_path_is_file .git/logs/refs/heads/m/m' + test_path_is_file .git/logs/refs/heads/m/m +' -test_expect_success \ - 'git branch -m n/n n should work' \ - 'git branch -l n/n && +test_expect_success 'git branch -m n/n n should work' ' + git branch -l n/n && git branch -m n/n n && - test_path_is_file .git/logs/refs/heads/n' + test_path_is_file .git/logs/refs/heads/n +' test_expect_success 'git branch -m o/o o should fail when o/p exists' ' git branch o/o && @@ -160,33 +160,30 @@ test_expect_success 'git branch --list -d t should fail' ' test_path_is_missing .git/refs/heads/t ' -mv .git/config .git/config-saved - test_expect_success 'git branch -m q q2 without config should succeed' ' + mv .git/config .git/config-saved && + test_when_finished mv .git/config-saved .git/config && git branch -m q q2 && git branch -m q2 q ' -mv .git/config-saved .git/config - +test_expect_success 'git branch -m s/s s should work when s/t is deleted' ' git config branch.s/s.dummy Hello - -test_expect_success \ - 'git branch -m s/s s should work when s/t is deleted' \ - 'git branch -l s/s && + git branch -l s/s && test_path_is_file .git/logs/refs/heads/s/s && git branch -l s/t && test_path_is_file .git/logs/refs/heads/s/t && git branch -d s/t && git branch -m s/s s && - test_path_is_file .git/logs/refs/heads/s' - -test_expect_success 'config information was renamed, too' \ - "test $(git config branch.s.dummy) = Hello && - test_must_fail git config branch.s/s/dummy" + test_path_is_file .git/logs/refs/heads/s +' -test_expect_success 'renaming a symref is not allowed' \ +test_expect_success 'config information was renamed, too' ' + test $(git config branch.s.dummy) = Hello && + test_must_fail git config branch.s/s/dummy ' + +test_expect_success 'renaming a symref is not allowed' ' git symbolic-ref refs/heads/master2 refs/heads/master && test_must_fail git branch -m master2 master3 && git symbolic-ref refs/heads/master2 && @@ -194,115 +191,125 @@ test_expect_success 'renaming a symref is not allowed' \ test_path_is_missing .git/refs/heads/master3 ' -test_expect_success SYMLINKS \ - 'git branch -m u v should fail when the reflog for u is a symlink' ' +test_expect_success SYMLINKS 'git branch -m u v should fail when the reflog for u is a symlink' ' git branch -l u && mv .git/logs/refs/heads/u real-u && ln -s real-u .git/logs/refs/heads/u && test_must_fail git branch -m u v ' -test_expect_success 'test tracking setup via --track' \ - 'git config remote.local.url . && +test_expect_success 'test tracking setup via --track' ' + git config remote.local.url . && git config remote.local.fetch refs/heads/*:refs/remotes/local/* && (git show-ref -q refs/remotes/local/master || git fetch local) && git branch --track my1 local/master && test $(git config branch.my1.remote) = local && - test $(git config branch.my1.merge) = refs/heads/master' + test $(git config branch.my1.merge) = refs/heads/master +' -test_expect_success 'test tracking setup (non-wildcard, matching)' \ - 'git config remote.local.url . && - git config remote.local.fetch refs/heads/master:refs/remotes/local/master && +test_expect_success 'test tracking setup (non-wildcard, matching)' ' + git config remote.local.url . && + git config remote.local.fetch \ + refs/heads/master:refs/remotes/local/master && (git show-ref -q refs/remotes/local/master || git fetch local) && git branch --track my4 local/master && test $(git config branch.my4.remote) = local && - test $(git config branch.my4.merge) = refs/heads/master' + test $(git config branch.my4.merge) = refs/heads/master +' -test_expect_success 'test tracking setup (non-wildcard, not matching)' \ - 'git config remote.local.url . && +test_expect_success 'test tracking setup (non-wildcard, not matching)' ' + git config remote.local.url . && git config remote.local.fetch refs/heads/s:refs/remotes/local/s && (git show-ref -q refs/remotes/local/master || git fetch local) && git branch --track my5 local/master && ! test "$(git config branch.my5.remote)" = local && - ! test "$(git config branch.my5.merge)" = refs/heads/master' + ! test "$(git config branch.my5.merge)" = refs/heads/master +' -test_expect_success 'test tracking setup via config' \ - 'git config branch.autosetupmerge true && +test_expect_success 'test tracking setup via config' ' + git config branch.autosetupmerge true && git config remote.local.url . && git config remote.local.fetch refs/heads/*:refs/remotes/local/* && (git show-ref -q refs/remotes/local/master || git fetch local) && git branch my3 local/master && test $(git config branch.my3.remote) = local && - test $(git config branch.my3.merge) = refs/heads/master' + test $(git config branch.my3.merge) = refs/heads/master +' -test_expect_success 'test overriding tracking setup via --no-track' \ - 'git config branch.autosetupmerge true && +test_expect_success 'test overriding tracking setup via --no-track' ' + git config branch.autosetupmerge true && git config remote.local.url . && git config remote.local.fetch refs/heads/*:refs/remotes/local/* && (git show-ref -q refs/remotes/local/master || git fetch local) && git branch --no-track my2 local/master && git config branch.autosetupmerge false && ! test "$(git config branch.my2.remote)" = local && - ! test "$(git config branch.my2.merge)" = refs/heads/master' + ! test "$(git config branch.my2.merge)" = refs/heads/master +' -test_expect_success 'no tracking without .fetch entries' \ - 'git config branch.autosetupmerge true && +test_expect_success 'no tracking without .fetch entries' ' + git config branch.autosetupmerge true && git branch my6 s && git config branch.automsetupmerge false && test -z "$(git config branch.my6.remote)" && - test -z "$(git config branch.my6.merge)"' + test -z "$(git config branch.my6.merge)" +' -test_expect_success 'test tracking setup via --track but deeper' \ - 'git config remote.local.url . && +test_expect_success 'test tracking setup via --track but deeper' ' + git config remote.local.url . && git config remote.local.fetch refs/heads/*:refs/remotes/local/* && (git show-ref -q refs/remotes/local/o/o || git fetch local) && git branch --track my7 local/o/o && test "$(git config branch.my7.remote)" = local && - test "$(git config branch.my7.merge)" = refs/heads/o/o' + test "$(git config branch.my7.merge)" = refs/heads/o/o +' -test_expect_success 'test deleting branch deletes branch config' \ - 'git branch -d my7 && +test_expect_success 'test deleting branch deletes branch config' ' + git branch -d my7 && test -z "$(git config branch.my7.remote)" && - test -z "$(git config branch.my7.merge)"' + test -z "$(git config branch.my7.merge)" +' -test_expect_success 'test deleting branch without config' \ - 'git branch my7 s && +test_expect_success 'test deleting branch without config' ' + git branch my7 s && sha1=$(git rev-parse my7 | cut -c 1-7) && echo "Deleted branch my7 (was $sha1)." >expect && git branch -d my7 >actual 2>&1 && - test_i18ncmp expect actual' + test_i18ncmp expect actual +' -test_expect_success 'test --track without .fetch entries' \ - 'git branch --track my8 && +test_expect_success 'test --track without .fetch entries' ' + git branch --track my8 && test "$(git config branch.my8.remote)" && - test "$(git config branch.my8.merge)"' + test "$(git config branch.my8.merge)" +' -test_expect_success \ - 'branch from non-branch HEAD w/autosetupmerge=always' \ - 'git config branch.autosetupmerge always && +test_expect_success 'branch from non-branch HEAD w/autosetupmerge=always' ' + git config branch.autosetupmerge always && git branch my9 HEAD^ && - git config branch.autosetupmerge false' + git config branch.autosetupmerge false +' -test_expect_success \ - 'branch from non-branch HEAD w/--track causes failure' \ - 'test_must_fail git branch --track my10 HEAD^' +test_expect_success 'branch from non-branch HEAD w/--track causes failure' ' + test_must_fail git branch --track my10 HEAD^ +' -test_expect_success \ - 'branch from tag w/--track causes failure' \ - 'git tag foobar && - test_must_fail git branch --track my11 foobar' +test_expect_success 'branch from tag w/--track causes failure' ' + git tag foobar && + test_must_fail git branch --track my11 foobar +' # Keep this test last, as it changes the current branch -cat >expect <<EOF +test_expect_success 'git checkout -b g/h/i -l should create a branch and a log' ' + cat >expect <<-EOF $_z40 $HEAD $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> 1117150200 +0000 branch: Created from master EOF -test_expect_success \ - 'git checkout -b g/h/i -l should create a branch and a log' \ - 'GIT_COMMITTER_DATE="2005-05-26 23:30" \ + GIT_COMMITTER_DATE="2005-05-26 23:30" \ git checkout -b g/h/i -l master && test_path_is_file .git/refs/heads/g/h/i && test_path_is_file .git/logs/refs/heads/g/h/i && - test_cmp expect .git/logs/refs/heads/g/h/i' + test_cmp expect .git/logs/refs/heads/g/h/i +' test_expect_success 'checkout -b makes reflog by default' ' git checkout master && -- 1.7.8 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html