File: test-pull-after-rebase.t

package info (click to toggle)
hg-git 1.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 1,244 kB
  • sloc: python: 8,702; sh: 185; makefile: 23
file content (312 lines) | stat: -rw-r--r-- 9,211 bytes parent folder | download
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
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
Load commonly used test logic
  $ . "$TESTDIR/testutil"

  $ cat >> $HGRCPATH <<EOF
  > [extensions]
  > rebase =
  > [experimental]
  > evolution = createmarkers
  > evolution.createmarkers = yes
  > [templates]
  > state = {bookmarks} {tags} {rev}:{node}\\n{desc}\\n
  > [alias]
  > state = log --graph --template state
  > EOF

  $ git init -q --bare repo.git
  $ git clone repo.git gitrepo > /dev/null 2>&1
  $ cd gitrepo
  $ echo alpha > alpha
  $ git add alpha
  $ fn_git_commit -m 'add alpha'

  $ echo beta > beta
  $ git add beta
  $ fn_git_commit -m 'add beta'

  $ git checkout --quiet -b branch master~1
  $ echo gamma > gamma
  $ git add gamma
  $ fn_git_commit -m 'add gamma'

  $ git push --all
  To $TESTTMP/repo.git
   * [new branch]      branch -> branch
   * [new branch]      master -> master
  $ cd ..

Clone it and rebase the branch

  $ hg clone -U repo.git hgrepo
  importing 3 git commits
  new changesets ff7a2f2d8d70:205a004356ef (3 drafts)
  $ cd hgrepo
  $ hg state
  o  branch default/branch tip 2:205a004356ef32b8da782afb89d9179d12ca31e9
  |  add gamma
  | o  master default/master 1:7fe02317c63d9ee324d4b5df7c9296085162da1b
  |/   add beta
  o    0:ff7a2f2d8d7099694ae1e8b03838d40575bebb63
     add alpha
  $ hg up branch
  2 files updated, 0 files merged, 0 files removed, 0 files unresolved
  (activating bookmark branch)
  $ hg rebase --quiet -d master
  $ hg state
  @  branch tip 3:52def9937d74e43b83dfded6ce0e5adf731b9d22
  |  add gamma
  | x   default/branch 2:205a004356ef32b8da782afb89d9179d12ca31e9
  | |  add gamma
  o |  master default/master 1:7fe02317c63d9ee324d4b5df7c9296085162da1b
  |/   add beta
  o    0:ff7a2f2d8d7099694ae1e8b03838d40575bebb63
     add alpha

  $ hg push -fr tip
  pushing to $TESTTMP/repo.git
  searching for changes
  adding objects
  remote: found 0 deltas to reuse
  added 1 commits with 1 trees and 1 blobs
  updating reference refs/heads/branch
  $ cd ..

Now switch back to git and create a new commit based on what we just rebased

  $ cd gitrepo
  $ git checkout --quiet -b otherbranch branch
  $ git log --oneline --graph --all --decorate
  * e5023f9 (HEAD -> otherbranch, origin/branch, branch) add gamma
  | * 9497a4e (origin/master, master) add beta
  |/  
  * 7eeab2e add alpha
  $ echo delta > delta
  $ git add delta
  $ fn_git_commit -m 'add delta'
  $ git push --quiet --set-upstream origin otherbranch
  Branch 'otherbranch' set up to track remote branch 'otherbranch' from 'origin'. (?)
  $ git log --oneline --graph --all --decorate
  * bba0011 (HEAD -> otherbranch, origin/otherbranch) add delta
  * e5023f9 (origin/branch, branch) add gamma
  | * 9497a4e (origin/master, master) add beta
  |/  
  * 7eeab2e add alpha
  $ cd ..

Pull that

  $ cd hgrepo
  $ hg pull
  pulling from $TESTTMP/repo.git
  importing 1 git commits
  adding bookmark otherbranch
  1 new orphan changesets
  new changesets 075302705298 (1 drafts)
  (run 'hg heads' to see heads, 'hg merge' to merge)
  $ hg state
  *  otherbranch default/otherbranch tip 4:0753027052980aef9c9c37adb7d76d5719e8d818
  |  add delta
  | @  branch default/branch 3:52def9937d74e43b83dfded6ce0e5adf731b9d22
  | |  add gamma
  x |    2:205a004356ef32b8da782afb89d9179d12ca31e9
  | |  add gamma
  | o  master default/master 1:7fe02317c63d9ee324d4b5df7c9296085162da1b
  |/   add beta
  o    0:ff7a2f2d8d7099694ae1e8b03838d40575bebb63
     add alpha

  $ cd ..

To reproduce bug #386, do like github and save the old commit in a
ref, and create a clone containing just the converted git commits:

  $ cd repo.git
  $ git update-ref refs/pr/1 otherbranch
  $ cd ..
  $ hg clone -U repo.git hgrepo-issue386
  importing 5 git commits
  new changesets ff7a2f2d8d70:075302705298 (5 drafts)

Now try rebasing that branch, from the Git side of things

  $ cd gitrepo
  $ git checkout -q otherbranch
  $ git log --oneline --graph --all --decorate
  * bba0011 (HEAD -> otherbranch, origin/otherbranch) add delta
  * e5023f9 (origin/branch, branch) add gamma
  | * 9497a4e (origin/master, master) add beta
  |/  
  * 7eeab2e add alpha
  $ fn_git_rebase --onto master branch otherbranch
  $ git log --oneline --graph --all --decorate
  * 9c58139 (HEAD -> otherbranch) add delta
  * 9497a4e (origin/master, master) add beta
  | * bba0011 (origin/otherbranch) add delta
  | * e5023f9 (origin/branch, branch) add gamma
  |/  
  * 7eeab2e add alpha
  $ git push -f
  To $TESTTMP/repo.git
   + bba0011...9c58139 otherbranch -> otherbranch (forced update)
  $ git log --oneline --graph --all --decorate
  * 9c58139 (HEAD -> otherbranch, origin/otherbranch) add delta
  * 9497a4e (origin/master, master) add beta
  | * e5023f9 (origin/branch, branch) add gamma
  |/  
  * 7eeab2e add alpha
  $ cd ..

Now strip the old commit

  $ cd hgrepo-issue386
  $ hg up null
  0 files updated, 0 files merged, 0 files removed, 0 files unresolved
  $ hg id -qr otherbranch
  075302705298
  $ hg pull
  pulling from $TESTTMP/repo.git
  importing 1 git commits
  not updating diverged bookmark otherbranch
  new changesets d64bf0521af6 (1 drafts)
  (run 'hg heads .' to see heads, 'hg merge' to merge)
  $ hg debugstrip --hidden --no-backup otherbranch
  $ hg book -d otherbranch
  $ hg git-cleanup
  git commit map cleaned
  $ hg pull
  pulling from $TESTTMP/repo.git
  no changes found
  adding bookmark otherbranch
  $ cd ..

And check that pulling something else doesn't delete that branch.

  $ cd hgrepo
  $ hg pull -r master
  pulling from $TESTTMP/repo.git
  no changes found
  $ cd ..

A special case, is that we can pull into a repository, where a commit
corresponding to the new branch exists, but that commit is obsolete.
In order to avoid “pinning” the obsolete commit, and thereby making it
visible, we first pull from Git as an unnamed remote.

  $ hg clone --config phases.publish=no hgrepo hgrepo-clone
  updating to branch default
  3 files updated, 0 files merged, 0 files removed, 0 files unresolved
  $ cd hgrepo-clone
  $ hg pull ../repo.git
  pulling from ../repo.git
  importing 4 git commits
  not updating diverged bookmark otherbranch
  new changesets d64bf0521af6 (1 drafts)
  (run 'hg heads .' to see heads, 'hg merge' to merge)
  $ hg debugobsolete d64bf0521af68fe2160791a1b4ab9baf282a3879
  1 new obsolescence markers
  obsoleted 1 changesets
  $ cp ../hgrepo/.hg/hgrc .hg
  $ hg pull
  pulling from $TESTTMP/repo.git
  no changes found
  not updating diverged bookmark otherbranch
  $ cd ..
  $ rm -rf hgrepo-clone

Another special case, is that we should update commits over obsolete boundaries:

  $ hg clone --config phases.publish=no hgrepo hgrepo-clone
  updating to branch default
  3 files updated, 0 files merged, 0 files removed, 0 files unresolved
  $ cd hgrepo-clone
  $ hg pull ../repo.git
  pulling from ../repo.git
  importing 4 git commits
  not updating diverged bookmark otherbranch
  new changesets d64bf0521af6 (1 drafts)
  (run 'hg heads .' to see heads, 'hg merge' to merge)
  $ hg debugobsolete 0753027052980aef9c9c37adb7d76d5719e8d818 d64bf0521af68fe2160791a1b4ab9baf282a3879
  1 new obsolescence markers
  obsoleted 1 changesets
  $ hg book -r 075302705298 otherbranch
  $ cp ../hgrepo/.hg/hgrc .hg
  $ hg pull
  pulling from $TESTTMP/repo.git
  no changes found
  updating bookmark otherbranch
  $ cd ..
  $ rm -rf hgrepo-clone

Now just pull it:

  $ cd hgrepo
  $ hg pull
  pulling from $TESTTMP/repo.git
  importing 1 git commits
  not updating diverged bookmark otherbranch
  new changesets d64bf0521af6 (1 drafts)
  (run 'hg heads .' to see heads, 'hg merge' to merge)
  $ hg state
  o   default/otherbranch tip 5:d64bf0521af68fe2160791a1b4ab9baf282a3879
  |  add delta
  | *  otherbranch  4:0753027052980aef9c9c37adb7d76d5719e8d818
  | |  add delta
  +---@  branch default/branch 3:52def9937d74e43b83dfded6ce0e5adf731b9d22
  | |    add gamma
  | x    2:205a004356ef32b8da782afb89d9179d12ca31e9
  | |  add gamma
  o |  master default/master 1:7fe02317c63d9ee324d4b5df7c9296085162da1b
  |/   add beta
  o    0:ff7a2f2d8d7099694ae1e8b03838d40575bebb63
     add alpha
  $ cd ..

And finally, delete it:

  $ cd gitrepo
  $ git push origin :otherbranch
  To $TESTTMP/repo.git
   - [deleted]         otherbranch
  $ cd ..

And pull that:

  $ cd hgrepo
  $ hg pull
  pulling from $TESTTMP/repo.git
  no changes found
  not deleting diverged bookmark otherbranch
  $ hg state
  o   tip 5:d64bf0521af68fe2160791a1b4ab9baf282a3879
  |  add delta
  | *  otherbranch  4:0753027052980aef9c9c37adb7d76d5719e8d818
  | |  add delta
  +---@  branch default/branch 3:52def9937d74e43b83dfded6ce0e5adf731b9d22
  | |    add gamma
  | x    2:205a004356ef32b8da782afb89d9179d12ca31e9
  | |  add gamma
  o |  master default/master 1:7fe02317c63d9ee324d4b5df7c9296085162da1b
  |/   add beta
  o    0:ff7a2f2d8d7099694ae1e8b03838d40575bebb63
     add alpha
  $ cd ..

We only get that message once:

  $ hg -R hgrepo pull
  pulling from $TESTTMP/repo.git
  no changes found

Now try deleting one already gone locally, which shouldn't output
anything:

  $ cd gitrepo
  $ git push origin :branch
  To $TESTTMP/repo.git
   - [deleted]         branch
  $ cd ../hgrepo
  $ hg book -d branch
  $ hg pull
  pulling from $TESTTMP/repo.git
  no changes found
  $ cd ..