1#!/bin/sh
   2test_description='check various push.default settings'
   4. ./test-lib.sh
   5test_expect_success 'setup bare remotes' '
   7        git init --bare repo1 &&
   8        git remote add parent1 repo1 &&
   9        git init --bare repo2 &&
  10        git remote add parent2 repo2 &&
  11        test_commit one &&
  12        git push parent1 HEAD &&
  13        git push parent2 HEAD
  14'
  15# $1 = local revision
  17# $2 = remote revision (tested to be equal to the local one)
  18check_pushed_commit () {
  19        git log -1 --format='%h %s' "$1" >expect &&
  20        git --git-dir=repo1 log -1 --format='%h %s' "$2" >actual &&
  21        test_cmp expect actual
  22}
  23# $1 = push.default value
  25# $2 = expected target branch for the push
  26test_push_success () {
  27        git -c push.default="$1" push &&
  28        check_pushed_commit HEAD "$2"
  29}
  30# $1 = push.default value
  32# check that push fails and does not modify any remote branch
  33test_push_failure () {
  34        git --git-dir=repo1 log --no-walk --format='%h %s' --all >expect &&
  35        test_must_fail git -c push.default="$1" push &&
  36        git --git-dir=repo1 log --no-walk --format='%h %s' --all >actual &&
  37        test_cmp expect actual
  38}
  39test_expect_success '"upstream" pushes to configured upstream' '
  41        git checkout master &&
  42        test_config branch.master.remote parent1 &&
  43        test_config branch.master.merge refs/heads/foo &&
  44        test_commit two &&
  45        test_push_success upstream foo
  46'
  47test_expect_success '"upstream" does not push on unconfigured remote' '
  49        git checkout master &&
  50        test_unconfig branch.master.remote &&
  51        test_config push.default upstream &&
  52        test_commit three &&
  53        test_push_failure upstream
  54'
  55test_expect_success '"upstream" does not push on unconfigured branch' '
  57        git checkout master &&
  58        test_config branch.master.remote parent1 &&
  59        test_unconfig branch.master.merge &&
  60        test_config push.default upstream
  61        test_commit four &&
  62        test_push_failure upstream
  63'
  64test_expect_success '"upstream" does not push when remotes do not match' '
  66        git checkout master &&
  67        test_config branch.master.remote parent1 &&
  68        test_config branch.master.merge refs/heads/foo &&
  69        test_config push.default upstream &&
  70        test_commit five &&
  71        test_must_fail git push parent2
  72'
  73test_expect_success 'push from/to new branch with upstream, matching and simple' '
  75        git checkout -b new-branch &&
  76        test_push_failure simple &&
  77        test_push_failure matching &&
  78        test_push_failure upstream
  79'
  80test_expect_success 'push from/to new branch with current creates remote branch' '
  82        test_config branch.new-branch.remote repo1 &&
  83        git checkout new-branch &&
  84        test_push_success current new-branch
  85'
  86test_expect_success 'push to existing branch, with no upstream configured' '
  88        test_config branch.master.remote repo1 &&
  89        git checkout master &&
  90        test_push_failure simple &&
  91        test_push_failure upstream
  92'
  93test_expect_success 'push to existing branch, upstream configured with same name' '
  95        test_config branch.master.remote repo1 &&
  96        test_config branch.master.merge refs/heads/master &&
  97        git checkout master &&
  98        test_commit six &&
  99        test_push_success upstream master &&
 100        test_commit seven &&
 101        test_push_success simple master
 102'
 103test_expect_success 'push to existing branch, upstream configured with different name' '
 105        test_config branch.master.remote repo1 &&
 106        test_config branch.master.merge refs/heads/other-name &&
 107        git checkout master &&
 108        test_commit eight &&
 109        test_push_success upstream other-name &&
 110        test_commit nine &&
 111        test_push_failure simple &&
 112        git --git-dir=repo1 log -1 --format="%h %s" "other-name" >expect-other-name &&
 113        test_push_success current master &&
 114        git --git-dir=repo1 log -1 --format="%h %s" "other-name" >actual-other-name &&
 115        test_cmp expect-other-name actual-other-name
 116'
 117test_done