3 test_description
='remote tracking stats'
14 test_expect_success setup
'
22 git checkout -b b1 origin &&
23 git reset --hard HEAD^ &&
25 git checkout -b b2 origin &&
26 git reset --hard b1 &&
27 git checkout -b b3 origin &&
28 git reset --hard HEAD^ &&
29 git checkout -b b4 origin &&
33 git checkout -b follower --track master &&
37 script='s/^..\(b.\)[ 0-9a-f]*\[\([^]]*\)\].*/\1 \2/p'
45 test_expect_success
'branch -v' '
50 sed -n -e "$script" >actual &&
51 test_cmp expect actual
54 test_expect_success
'checkout' '
56 cd test && git checkout b1
58 grep "have 1 and 1 different" actual
61 test_expect_success
'checkout with local tracked branch' '
62 git checkout master &&
63 git checkout follower >actual
64 grep "is ahead of" actual
67 test_expect_success
'status' '
70 git checkout b1 >/dev/null &&
71 # reports nothing to commit
72 test_must_fail git commit --dry-run
74 grep "have 1 and 1 different" actual
77 test_expect_success
'status when tracking lightweight tags' '
78 git checkout master &&
80 git branch --track lighttrack light >actual &&
81 grep "set up to track" actual &&
82 git checkout lighttrack
85 test_expect_success
'status when tracking annotated tags' '
86 git checkout master &&
87 git tag -m heavy heavy &&
88 git branch --track heavytrack heavy >actual &&
89 grep "set up to track" actual &&
90 git checkout heavytrack
93 test_expect_success
'setup tracking with branch --set-upstream on existing branch' '
94 git branch from-master master &&
95 test_must_fail git config branch.from-master.merge > actual &&
96 git branch --set-upstream from-master master &&
97 git config branch.from-master.merge > actual &&
98 grep -q "^refs/heads/master$" actual
101 test_expect_success
'--set-upstream does not change branch' '
102 git branch from-master2 master &&
103 test_must_fail git config branch.from-master2.merge > actual &&
104 git rev-list from-master2 &&
105 git update-ref refs/heads/from-master2 from-master2^ &&
106 git rev-parse from-master2 >expect2 &&
107 git branch --set-upstream from-master2 master &&
108 git config branch.from-master.merge > actual &&
109 git rev-parse from-master2 >actual2 &&
110 grep -q "^refs/heads/master$" actual &&