(CommandList children: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:test_description) op: Equal rhs: {(SQ <"check various push.default settings">)} spids: [4] ) ] spids: [4] ) (C {(.)} {(./test-lib.sh)}) (C {(test_expect_success)} {(SQ <"setup bare remotes">)} { (SQ <"\n"> <"\tgit init --bare repo1 &&\n"> <"\tgit remote add parent1 repo1 &&\n"> <"\tgit init --bare repo2 &&\n"> <"\tgit remote add parent2 repo2 &&\n"> <"\ttest_commit one &&\n"> <"\tgit push parent1 HEAD &&\n"> <"\tgit push parent2 HEAD\n"> ) } ) (FuncDef name: check_pushed_commit body: (BraceGroup children: [ (AndOr children: [ (SimpleCommand words: [ {(git)} {(log)} {(-1)} {(--format) (Lit_Other "=") (SQ <"%h %s">)} {(DQ ($ VSub_Number "$1"))} ] redirects: [(Redir op_id:Redir_Great fd:-1 arg_word:{(expect)} spids:[65])] ) (AndOr children: [ (SimpleCommand words: [ {(git)} {(--git-dir) (Lit_Other "=") (DQ (BracedVarSub token: <VSub_Number 3> suffix_op: (StringUnary op_id:VTest_ColonHyphen arg_word:{(repo1)}) spids: [76 80] ) ) } {(log)} {(-1)} {(--format) (Lit_Other "=") (SQ <"%h %s">)} {(DQ ($ VSub_Number "$2"))} ] redirects: [(Redir op_id:Redir_Great fd:-1 arg_word:{(actual)} spids:[97])] ) (C {(test_cmp)} {(expect)} {(actual)}) ] op_id: Op_DAmp ) ] op_id: Op_DAmp ) ] spids: [46] ) spids: [41 45] ) (FuncDef name: test_push_success body: (BraceGroup children: [ (AndOr children: [ (C {(git)} { (BracedVarSub token: <VSub_Number 1> suffix_op: (StringUnary op_id:VTest_ColonPlus arg_word:{(-c)}) spids: [131 135] ) } { (BracedVarSub token: <VSub_Number 1> suffix_op: (StringUnary op_id: VTest_ColonPlus arg_word: {("push.default=") (DQ ($ VSub_Number "$1"))} ) spids: [137 144] ) } {(push)} ) (C {(check_pushed_commit)} {(HEAD)} {(DQ ($ VSub_Number "$2"))} {(DQ ($ VSub_Number "$3"))} ) ] op_id: Op_DAmp ) ] spids: [126] ) spids: [121 125] ) (FuncDef name: test_push_failure body: (BraceGroup children: [ (AndOr children: [ (SimpleCommand words: [ {(git)} {(--git-dir) (Lit_Other "=") (repo1)} {(log)} {(--no-walk)} {(--format) (Lit_Other "=") (SQ <"%h %s">)} {(--all)} ] redirects: [(Redir op_id:Redir_Great fd:-1 arg_word:{(expect)} spids:[198])] ) (AndOr children: [ (C {(test_must_fail)} {(git)} { (BracedVarSub token: <VSub_Number 1> suffix_op: (StringUnary op_id:VTest_ColonPlus arg_word:{(-c)}) spids: [208 212] ) } { (BracedVarSub token: <VSub_Number 1> suffix_op: (StringUnary op_id: VTest_ColonPlus arg_word: {("push.default=") (DQ ($ VSub_Number "$1"))} ) spids: [214 221] ) } {(push)} ) (AndOr children: [ (SimpleCommand words: [ {(git)} {(--git-dir) (Lit_Other "=") (repo1)} {(log)} {(--no-walk)} {(--format) (Lit_Other "=") (SQ <"%h %s">)} {(--all)} ] redirects: [(Redir op_id:Redir_Great fd:-1 arg_word:{(actual)} spids:[246])] ) (C {(test_cmp)} {(expect)} {(actual)}) ] op_id: Op_DAmp ) ] op_id: Op_DAmp ) ] op_id: Op_DAmp ) ] spids: [177] ) spids: [172 176] ) (FuncDef name: test_pushdefault_workflow body: (BraceGroup children: [ (Assignment keyword: Assign_None pairs: [(assign_pair lhs:(LhsName name:workflow) op:Equal rhs:{(central)} spids:[281])] spids: [281] ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:pushdefault) op: Equal rhs: {(parent1)} spids: [285] ) ] spids: [285] ) (If arms: [ (if_arm cond: [ (Sentence child: (C {(test)} {(-n)} { (DQ (BracedVarSub token: <VSub_Number 4> suffix_op: (StringUnary op_id:VTest_Hyphen arg_word:{(SQ )}) spids: [296 299] ) ) } ) terminator: <Op_Semi ";"> ) ] action: [ (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:workflow) op: Equal rhs: {(triangular)} spids: [306] ) ] spids: [306] ) (Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (LhsName name:pushdefault) op: Equal rhs: {(parent2)} spids: [310] ) ] spids: [310] ) ] spids: [-1 303] ) ] spids: [-1 314] ) (C {(test_expect_success)} { (DQ ("push.default = ") ($ VSub_Number "$2") (" ") ($ VSub_Number "$1") (" in ") ($ VSub_Name "$workflow") (" workflows") ) } { (DQ ("\n") ("\t\ttest_config branch.master.remote parent1 &&\n") ("\t\ttest_config branch.master.merge refs/heads/foo &&\n") ("\t\ttest_config remote.pushdefault ") ($ VSub_Name "$pushdefault") (" &&\n") ("\t\ttest_commit commit-for-") ($ VSub_Number "$2") (BracedVarSub token: <VSub_Number 4> suffix_op: (StringUnary op_id:VTest_Plus arg_word:{(-triangular)}) spids: [338 342] ) (" &&\n") ("\t\ttest_push_") ($ VSub_Number "$1") (" ") ($ VSub_Number "$2") (" ") ($ VSub_Number "$3") (" ") (BracedVarSub token: <VSub_Number 4> suffix_op: (StringUnary op_id:VTest_Plus arg_word:{(repo2)}) spids: [351 355] ) ("\n") ("\t") ) } ) ] spids: [278] ) spids: [273 277] ) (C {(test_expect_success)} {(SQ <"\"upstream\" pushes to configured upstream">)} { (SQ <"\n"> <"\tgit checkout master &&\n"> <"\ttest_config branch.master.remote parent1 &&\n"> <"\ttest_config branch.master.merge refs/heads/foo &&\n"> <"\ttest_commit two &&\n"> <"\ttest_push_success upstream foo\n"> ) } ) (C {(test_expect_success)} {(SQ <"\"upstream\" does not push on unconfigured remote">)} { (SQ <"\n"> <"\tgit checkout master &&\n"> <"\ttest_unconfig branch.master.remote &&\n"> <"\ttest_commit three &&\n"> <"\ttest_push_failure upstream\n"> ) } ) (C {(test_expect_success)} {(SQ <"\"upstream\" does not push on unconfigured branch">)} { (SQ <"\n"> <"\tgit checkout master &&\n"> <"\ttest_config branch.master.remote parent1 &&\n"> <"\ttest_unconfig branch.master.merge &&\n"> <"\ttest_commit four &&\n"> <"\ttest_push_failure upstream\n"> ) } ) (C {(test_expect_success)} {(SQ <"\"upstream\" does not push when remotes do not match">)} { (SQ <"\n"> <"\tgit checkout master &&\n"> <"\ttest_config branch.master.remote parent1 &&\n"> <"\ttest_config branch.master.merge refs/heads/foo &&\n"> <"\ttest_config push.default upstream &&\n"> <"\ttest_commit five &&\n"> <"\ttest_must_fail git push parent2\n"> ) } ) (C {(test_expect_success)} {(SQ <"push from/to new branch with upstream, matching and simple">)} { (SQ <"\n"> <"\tgit checkout -b new-branch &&\n"> <"\ttest_push_failure simple &&\n"> <"\ttest_push_failure matching &&\n"> <"\ttest_push_failure upstream\n"> ) } ) (C {(test_expect_success)} {(SQ <"push from/to new branch with current creates remote branch">)} { (SQ <"\n"> <"\ttest_config branch.new-branch.remote repo1 &&\n"> <"\tgit checkout new-branch &&\n"> <"\ttest_push_success current new-branch\n"> ) } ) (C {(test_expect_success)} {(SQ <"push to existing branch, with no upstream configured">)} { (SQ <"\n"> <"\ttest_config branch.master.remote repo1 &&\n"> <"\tgit checkout master &&\n"> <"\ttest_push_failure simple &&\n"> <"\ttest_push_failure upstream\n"> ) } ) (C {(test_expect_success)} {(SQ <"push to existing branch, upstream configured with same name">)} { (SQ <"\n"> <"\ttest_config branch.master.remote repo1 &&\n"> <"\ttest_config branch.master.merge refs/heads/master &&\n"> <"\tgit checkout master &&\n"> <"\ttest_commit six &&\n"> <"\ttest_push_success upstream master &&\n"> <"\ttest_commit seven &&\n"> <"\ttest_push_success simple master\n"> ) } ) (C {(test_expect_success)} {(SQ <"push to existing branch, upstream configured with different name">)} { (SQ <"\n"> <"\ttest_config branch.master.remote repo1 &&\n"> <"\ttest_config branch.master.merge refs/heads/other-name &&\n"> <"\tgit checkout master &&\n"> <"\ttest_commit eight &&\n"> <"\ttest_push_success upstream other-name &&\n"> <"\ttest_commit nine &&\n"> <"\ttest_push_failure simple &&\n"> < "\tgit --git-dir=repo1 log -1 --format=\"%h %s\" \"other-name\" >expect-other-name &&\n" > <"\ttest_push_success current master &&\n"> < "\tgit --git-dir=repo1 log -1 --format=\"%h %s\" \"other-name\" >actual-other-name &&\n" > <"\ttest_cmp expect-other-name actual-other-name\n"> ) } ) (C {(test_pushdefault_workflow)} {(success)} {(current)} {(master)}) (C {(test_pushdefault_workflow)} {(success)} {(upstream)} {(foo)}) (C {(test_pushdefault_workflow)} {(failure)} {(simple)} {(master)}) (C {(test_pushdefault_workflow)} {(success)} {(matching)} {(master)}) (C {(test_pushdefault_workflow)} {(success)} {(current)} {(master)} {(triangular)}) (C {(test_pushdefault_workflow)} {(failure)} {(upstream)} {(foo)} {(triangular)}) (C {(test_pushdefault_workflow)} {(success)} {(simple)} {(master)} {(triangular)}) (C {(test_pushdefault_workflow)} {(success)} {(matching)} {(master)} {(triangular)}) (C {(test_expect_success)} {(SQ <"default behavior allows \"simple\" push">)} { (SQ <"\n"> <"\ttest_config branch.master.remote parent1 &&\n"> <"\ttest_config branch.master.merge refs/heads/master &&\n"> <"\ttest_config remote.pushdefault parent1 &&\n"> <"\ttest_commit default-master-master &&\n"> <"\ttest_push_success \"\" master\n"> ) } ) (C {(test_expect_success)} {(SQ <"default behavior rejects non-simple push">)} { (SQ <"\n"> <"\ttest_config branch.master.remote parent1 &&\n"> <"\ttest_config branch.master.merge refs/heads/foo &&\n"> <"\ttest_config remote.pushdefault parent1 &&\n"> <"\ttest_commit default-master-foo &&\n"> <"\ttest_push_failure \"\"\n"> ) } ) (C {(test_expect_success)} {(SQ <"default triangular behavior acts like \"current\"">)} { (SQ <"\n"> <"\ttest_config branch.master.remote parent1 &&\n"> <"\ttest_config branch.master.merge refs/heads/foo &&\n"> <"\ttest_config remote.pushdefault parent2 &&\n"> <"\ttest_commit default-triangular &&\n"> <"\ttest_push_success \"\" master repo2\n"> ) } ) (C {(test_done)}) ] )