summaryrefslogtreecommitdiff
path: root/t/t3200-branch.sh
blob: f1793d0b9ab6cf6e5c24abaf3aaa0892ea4f9631 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
#!/bin/sh
#
# Copyright (c) 2005 Amos Waterland
#

test_description='git branch --foo should not create bogus branch

This test runs git branch --help and checks that the argument is properly
handled.  Specifically, that a bogus branch is not created.
'
. ./test-lib.sh

test_expect_success \
    'prepare a trivial repository' \
    'echo Hello > A &&
     git-update-index --add A &&
     git-commit -m "Initial commit." &&
     HEAD=$(git-rev-parse --verify HEAD)'

test_expect_failure \
    'git branch --help should not have created a bogus branch' \
    'git-branch --help </dev/null >/dev/null 2>/dev/null || :
     test -f .git/refs/heads/--help'

test_expect_success \
    'git branch abc should create a branch' \
    'git-branch abc && test -f .git/refs/heads/abc'

test_expect_success \
    'git branch a/b/c should create a branch' \
    'git-branch a/b/c && test -f .git/refs/heads/a/b/c'

cat >expect <<EOF
0000000000000000000000000000000000000000 $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-branch -l d/e/f &&
	 test -f .git/refs/heads/d/e/f &&
	 test -f .git/logs/refs/heads/d/e/f &&
	 diff 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 ! -f .git/refs/heads/d/e/f &&
	 test ! -f .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 &&
        git-branch -d j &&
        git-branch j/k'

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'

test_expect_success \
    'git branch -m m m/m should work' \
       'git-branch -l m &&
        git-branch -m m m/m &&
        test -f .git/logs/refs/heads/m/m'

test_expect_success \
    'git branch -m n/n n should work' \
       'git-branch -l n/n &&
        git-branch -m n/n n
        test -f .git/logs/refs/heads/n'

test_expect_failure \
    'git branch -m o/o o should fail when o/p exists' \
       'git-branch o/o &&
        git-branch o/p &&
        git-branch -m o/o o'

test_expect_failure \
    'git branch -m q r/q should fail when r exists' \
       'git-branch q &&
         git-branch r &&
         git-branch -m q r/q'

mv .git/config .git/config-saved

test_expect_success 'git branch -m q q2 without config should succeed' '
	git-branch -m q q2 &&
	git-branch -m q2 q
'

mv .git/config-saved .git/config

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 &&
        test -f .git/logs/refs/heads/s/s &&
        git-branch -l s/t &&
        test -f .git/logs/refs/heads/s/t &&
        git-branch -d s/t &&
        git-branch -m s/s s &&
        test -f .git/logs/refs/heads/s'

test_expect_success 'config information was renamed, too' \
	"test $(git-config branch.s.dummy) = Hello &&
	 ! git-config branch.s/s/dummy"

test_expect_failure \
    '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 &&
     git-branch -m u v'

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_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_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_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_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_expect_success 'test local tracking setup' \
    'git branch --track my6 s &&
     test $(git-config branch.my6.remote) = . &&
     test $(git-config branch.my6.merge) = refs/heads/s'

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_expect_success 'test deleting branch deletes branch config' \
    'git-branch -d my7 &&
     test "$(git-config branch.my7.remote)" = "" &&
     test "$(git-config branch.my7.merge)" = ""'

test_expect_success 'test deleting branch without config' \
    'git-branch my7 s &&
     test "$(git-branch -d my7 2>&1)" = "Deleted branch my7."'

# Keep this test last, as it changes the current branch
cat >expect <<EOF
0000000000000000000000000000000000000000 $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-checkout -b g/h/i -l master &&
	 test -f .git/refs/heads/g/h/i &&
	 test -f .git/logs/refs/heads/g/h/i &&
	 diff expect .git/logs/refs/heads/g/h/i'

test_done