mirror of
https://github.com/facebook/sapling.git
synced 2024-10-09 16:31:02 +03:00
667d10975b
Revlog can now be configured to store full snapshot only. This is used on the changelog. However, the changegroup packing was still recomputing deltas to be sent over the wire. We now just reuse the full snapshot directly in this case, skipping delta computation. This provides use with a large speed up(-30%): # perfchangegroupchangelog on mercurial ! wall 2.010326 comb 2.020000 user 2.000000 sys 0.020000 (best of 5) ! wall 1.382039 comb 1.380000 user 1.370000 sys 0.010000 (best of 8) # perfchangegroupchangelog on pypy ! wall 5.792589 comb 5.780000 user 5.780000 sys 0.000000 (best of 3) ! wall 3.911158 comb 3.920000 user 3.900000 sys 0.020000 (best of 3) # perfchangegroupchangelog on mozilla central ! wall 20.683727 comb 20.680000 user 20.630000 sys 0.050000 (best of 3) ! wall 14.190204 comb 14.190000 user 14.150000 sys 0.040000 (best of 3) Many tests have to be updated because of the change in bundle content. All theses update have been verified. Because diffing changelog was not very valuable, the resulting bundle have similar size (often a bit smaller): # full bundle of mozilla central with delta: 1142740533B without delta: 1142173300B So this is a win all over the board.
1222 lines
25 KiB
Raku
1222 lines
25 KiB
Raku
#require killdaemons
|
|
|
|
$ hgph() { hg log -G --template "{rev} {phase} {desc} - {node|short}\n" $*; }
|
|
|
|
$ mkcommit() {
|
|
> echo "$1" > "$1"
|
|
> hg add "$1"
|
|
> message="$1"
|
|
> shift
|
|
> hg ci -m "$message" $*
|
|
> }
|
|
|
|
$ hg init alpha
|
|
$ cd alpha
|
|
$ mkcommit a-A
|
|
$ mkcommit a-B
|
|
$ mkcommit a-C
|
|
$ mkcommit a-D
|
|
$ hgph
|
|
@ 3 draft a-D - b555f63b6063
|
|
|
|
|
o 2 draft a-C - 54acac6f23ab
|
|
|
|
|
o 1 draft a-B - 548a3d25dbf0
|
|
|
|
|
o 0 draft a-A - 054250a37db4
|
|
|
|
|
|
$ hg init ../beta
|
|
$ hg push -r 1 ../beta
|
|
pushing to ../beta
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 2 changesets with 2 changes to 2 files
|
|
$ hgph
|
|
@ 3 draft a-D - b555f63b6063
|
|
|
|
|
o 2 draft a-C - 54acac6f23ab
|
|
|
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
$ cd ../beta
|
|
$ hgph
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hg up -q
|
|
$ mkcommit b-A
|
|
$ hgph
|
|
@ 2 draft b-A - f54f1bb90ff3
|
|
|
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hg pull ../alpha
|
|
pulling from ../alpha
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 2 changesets with 2 changes to 2 files (+1 heads)
|
|
(run 'hg heads' to see heads, 'hg merge' to merge)
|
|
$ hgph
|
|
o 4 public a-D - b555f63b6063
|
|
|
|
|
o 3 public a-C - 54acac6f23ab
|
|
|
|
|
| @ 2 draft b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
pull did not updated ../alpha state.
|
|
push from alpha to beta should update phase even if nothing is transferred
|
|
|
|
$ cd ../alpha
|
|
$ hgph # not updated by remote pull
|
|
@ 3 draft a-D - b555f63b6063
|
|
|
|
|
o 2 draft a-C - 54acac6f23ab
|
|
|
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hg push -r 2 ../beta
|
|
pushing to ../beta
|
|
searching for changes
|
|
no changes found
|
|
[1]
|
|
$ hgph
|
|
@ 3 draft a-D - b555f63b6063
|
|
|
|
|
o 2 public a-C - 54acac6f23ab
|
|
|
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hg push ../beta
|
|
pushing to ../beta
|
|
searching for changes
|
|
no changes found
|
|
[1]
|
|
$ hgph
|
|
@ 3 public a-D - b555f63b6063
|
|
|
|
|
o 2 public a-C - 54acac6f23ab
|
|
|
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
update must update phase of common changeset too
|
|
|
|
$ hg pull ../beta # getting b-A
|
|
pulling from ../beta
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files (+1 heads)
|
|
(run 'hg heads' to see heads, 'hg merge' to merge)
|
|
|
|
$ cd ../beta
|
|
$ hgph # not updated by remote pull
|
|
o 4 public a-D - b555f63b6063
|
|
|
|
|
o 3 public a-C - 54acac6f23ab
|
|
|
|
|
| @ 2 draft b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hg pull ../alpha
|
|
pulling from ../alpha
|
|
searching for changes
|
|
no changes found
|
|
$ hgph
|
|
o 4 public a-D - b555f63b6063
|
|
|
|
|
o 3 public a-C - 54acac6f23ab
|
|
|
|
|
| @ 2 public b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Publish configuration option
|
|
----------------------------
|
|
|
|
Pull
|
|
````
|
|
|
|
changegroup are added without phase movement
|
|
|
|
$ hg bundle -a ../base.bundle
|
|
5 changesets found
|
|
$ cd ..
|
|
$ hg init mu
|
|
$ cd mu
|
|
$ cat > .hg/hgrc << EOF
|
|
> [phases]
|
|
> publish=0
|
|
> EOF
|
|
$ hg unbundle ../base.bundle
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 5 changesets with 5 changes to 5 files (+1 heads)
|
|
(run 'hg heads' to see heads, 'hg merge' to merge)
|
|
$ hgph
|
|
o 4 draft a-D - b555f63b6063
|
|
|
|
|
o 3 draft a-C - 54acac6f23ab
|
|
|
|
|
| o 2 draft b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 draft a-B - 548a3d25dbf0
|
|
|
|
|
o 0 draft a-A - 054250a37db4
|
|
|
|
$ cd ..
|
|
|
|
Pulling from publish=False to publish=False does not move boundary.
|
|
|
|
$ hg init nu
|
|
$ cd nu
|
|
$ cat > .hg/hgrc << EOF
|
|
> [phases]
|
|
> publish=0
|
|
> EOF
|
|
$ hg pull ../mu -r 54acac6f23ab
|
|
pulling from ../mu
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 3 changesets with 3 changes to 3 files
|
|
(run 'hg update' to get a working copy)
|
|
$ hgph
|
|
o 2 draft a-C - 54acac6f23ab
|
|
|
|
|
o 1 draft a-B - 548a3d25dbf0
|
|
|
|
|
o 0 draft a-A - 054250a37db4
|
|
|
|
|
|
Even for common
|
|
|
|
$ hg pull ../mu -r f54f1bb90ff3
|
|
pulling from ../mu
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files (+1 heads)
|
|
(run 'hg heads' to see heads, 'hg merge' to merge)
|
|
$ hgph
|
|
o 3 draft b-A - f54f1bb90ff3
|
|
|
|
|
| o 2 draft a-C - 54acac6f23ab
|
|
|/
|
|
o 1 draft a-B - 548a3d25dbf0
|
|
|
|
|
o 0 draft a-A - 054250a37db4
|
|
|
|
|
|
|
|
Pulling from Publish=True to Publish=False move boundary in common set.
|
|
we are in nu
|
|
|
|
$ hg pull ../alpha -r b555f63b6063
|
|
pulling from ../alpha
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files
|
|
(run 'hg update' to get a working copy)
|
|
$ hgph # f54f1bb90ff3 stay draft, not ancestor of -r
|
|
o 4 public a-D - b555f63b6063
|
|
|
|
|
| o 3 draft b-A - f54f1bb90ff3
|
|
| |
|
|
o | 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
pulling from Publish=False to publish=False with some public
|
|
|
|
$ hg up -q f54f1bb90ff3
|
|
$ mkcommit n-A
|
|
$ mkcommit n-B
|
|
$ hgph
|
|
@ 6 draft n-B - 145e75495359
|
|
|
|
|
o 5 draft n-A - d6bcb4f74035
|
|
|
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
o | 3 draft b-A - f54f1bb90ff3
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ cd ../mu
|
|
$ hg pull ../nu
|
|
pulling from ../nu
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 2 changesets with 2 changes to 2 files
|
|
(run 'hg update' to get a working copy)
|
|
$ hgph
|
|
o 6 draft n-B - 145e75495359
|
|
|
|
|
o 5 draft n-A - d6bcb4f74035
|
|
|
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
| o 3 public a-C - 54acac6f23ab
|
|
| |
|
|
o | 2 draft b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ cd ..
|
|
|
|
pulling into publish=True
|
|
|
|
$ cd alpha
|
|
$ hgph
|
|
o 4 public b-A - f54f1bb90ff3
|
|
|
|
|
| @ 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hg pull ../mu
|
|
pulling from ../mu
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 2 changesets with 2 changes to 2 files
|
|
(run 'hg update' to get a working copy)
|
|
$ hgph
|
|
o 6 draft n-B - 145e75495359
|
|
|
|
|
o 5 draft n-A - d6bcb4f74035
|
|
|
|
|
o 4 public b-A - f54f1bb90ff3
|
|
|
|
|
| @ 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ cd ..
|
|
|
|
pulling back into original repo
|
|
|
|
$ cd nu
|
|
$ hg pull ../alpha
|
|
pulling from ../alpha
|
|
searching for changes
|
|
no changes found
|
|
$ hgph
|
|
@ 6 public n-B - 145e75495359
|
|
|
|
|
o 5 public n-A - d6bcb4f74035
|
|
|
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
o | 3 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Push
|
|
````
|
|
|
|
(inserted)
|
|
|
|
Test that phase are pushed even when they are nothing to pus
|
|
(this might be tested later bu are very convenient to not alter too much test)
|
|
|
|
Push back to alpha
|
|
|
|
$ hg push ../alpha # from nu
|
|
pushing to ../alpha
|
|
searching for changes
|
|
no changes found
|
|
[1]
|
|
$ cd ..
|
|
$ cd alpha
|
|
$ hgph
|
|
o 6 public n-B - 145e75495359
|
|
|
|
|
o 5 public n-A - d6bcb4f74035
|
|
|
|
|
o 4 public b-A - f54f1bb90ff3
|
|
|
|
|
| @ 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
(end insertion)
|
|
|
|
|
|
initial setup
|
|
|
|
$ hg log -G # of alpha
|
|
o changeset: 6:145e75495359
|
|
| tag: tip
|
|
| user: test
|
|
| date: Thu Jan 01 00:00:00 1970 +0000
|
|
| summary: n-B
|
|
|
|
|
o changeset: 5:d6bcb4f74035
|
|
| user: test
|
|
| date: Thu Jan 01 00:00:00 1970 +0000
|
|
| summary: n-A
|
|
|
|
|
o changeset: 4:f54f1bb90ff3
|
|
| parent: 1:548a3d25dbf0
|
|
| user: test
|
|
| date: Thu Jan 01 00:00:00 1970 +0000
|
|
| summary: b-A
|
|
|
|
|
| @ changeset: 3:b555f63b6063
|
|
| | user: test
|
|
| | date: Thu Jan 01 00:00:00 1970 +0000
|
|
| | summary: a-D
|
|
| |
|
|
| o changeset: 2:54acac6f23ab
|
|
|/ user: test
|
|
| date: Thu Jan 01 00:00:00 1970 +0000
|
|
| summary: a-C
|
|
|
|
|
o changeset: 1:548a3d25dbf0
|
|
| user: test
|
|
| date: Thu Jan 01 00:00:00 1970 +0000
|
|
| summary: a-B
|
|
|
|
|
o changeset: 0:054250a37db4
|
|
user: test
|
|
date: Thu Jan 01 00:00:00 1970 +0000
|
|
summary: a-A
|
|
|
|
$ mkcommit a-E
|
|
$ mkcommit a-F
|
|
$ mkcommit a-G
|
|
$ hg up d6bcb4f74035 -q
|
|
$ mkcommit a-H
|
|
created new head
|
|
$ hgph
|
|
@ 10 draft a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 draft a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 draft a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Pulling from bundle does not alter phases of changeset not present in the bundle
|
|
|
|
$ hg bundle --base 1 -r 6 -r 3 ../partial-bundle.hg
|
|
5 changesets found
|
|
$ hg pull ../partial-bundle.hg
|
|
pulling from ../partial-bundle.hg
|
|
searching for changes
|
|
no changes found
|
|
$ hgph
|
|
@ 10 draft a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 draft a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 draft a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Pushing to Publish=False (unknown changeset)
|
|
|
|
$ hg push ../mu -r b740e3e5c05d # a-F
|
|
pushing to ../mu
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 2 changesets with 2 changes to 2 files
|
|
$ hgph
|
|
@ 10 draft a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 draft a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 draft a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
$ cd ../mu
|
|
$ hgph # again f54f1bb90ff3, d6bcb4f74035 and 145e75495359 stay draft,
|
|
> # not ancestor of -r
|
|
o 8 draft a-F - b740e3e5c05d
|
|
|
|
|
o 7 draft a-E - e9f537e46dea
|
|
|
|
|
| o 6 draft n-B - 145e75495359
|
|
| |
|
|
| o 5 draft n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public a-D - b555f63b6063
|
|
| |
|
|
o | 3 public a-C - 54acac6f23ab
|
|
| |
|
|
| o 2 draft b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Pushing to Publish=True (unknown changeset)
|
|
|
|
$ hg push ../beta -r b740e3e5c05d
|
|
pushing to ../beta
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 2 changesets with 2 changes to 2 files
|
|
$ hgph # again f54f1bb90ff3, d6bcb4f74035 and 145e75495359 stay draft,
|
|
> # not ancestor of -r
|
|
o 8 public a-F - b740e3e5c05d
|
|
|
|
|
o 7 public a-E - e9f537e46dea
|
|
|
|
|
| o 6 draft n-B - 145e75495359
|
|
| |
|
|
| o 5 draft n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public a-D - b555f63b6063
|
|
| |
|
|
o | 3 public a-C - 54acac6f23ab
|
|
| |
|
|
| o 2 draft b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Pushing to Publish=True (common changeset)
|
|
|
|
$ cd ../beta
|
|
$ hg push ../alpha
|
|
pushing to ../alpha
|
|
searching for changes
|
|
no changes found
|
|
[1]
|
|
$ hgph
|
|
o 6 public a-F - b740e3e5c05d
|
|
|
|
|
o 5 public a-E - e9f537e46dea
|
|
|
|
|
o 4 public a-D - b555f63b6063
|
|
|
|
|
o 3 public a-C - 54acac6f23ab
|
|
|
|
|
| @ 2 public b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ cd ../alpha
|
|
$ hgph
|
|
@ 10 draft a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Pushing to Publish=False (common changeset that change phase + unknown one)
|
|
|
|
$ hg push ../mu -r 967b449fbc94 -f
|
|
pushing to ../mu
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files (+1 heads)
|
|
$ hgph
|
|
@ 10 draft a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ cd ../mu
|
|
$ hgph # d6bcb4f74035 should have changed phase
|
|
> # 145e75495359 is still draft. not ancestor of -r
|
|
o 9 draft a-H - 967b449fbc94
|
|
|
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 draft n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
| o 3 public a-C - 54acac6f23ab
|
|
| |
|
|
o | 2 public b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
|
|
Pushing to Publish=True (common changeset from publish=False)
|
|
|
|
(in mu)
|
|
$ hg push ../alpha
|
|
pushing to ../alpha
|
|
searching for changes
|
|
no changes found
|
|
[1]
|
|
$ hgph
|
|
o 9 public a-H - 967b449fbc94
|
|
|
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
| o 3 public a-C - 54acac6f23ab
|
|
| |
|
|
o | 2 public b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hgph -R ../alpha # a-H should have been synced to 0
|
|
@ 10 public a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
|
|
Bare push with next changeset and common changeset needing sync (issue3575)
|
|
|
|
(reset some stat on remote repo to avoid confusing other tests)
|
|
|
|
$ hg -R ../alpha --config extensions.strip= strip --no-backup 967b449fbc94
|
|
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
|
|
$ hg phase --force --draft b740e3e5c05d 967b449fbc94
|
|
$ hg push -fv ../alpha
|
|
pushing to ../alpha
|
|
searching for changes
|
|
1 changesets found
|
|
uncompressed size of bundle content:
|
|
178 (changelog)
|
|
165 (manifests)
|
|
131 a-H
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files (+1 heads)
|
|
$ hgph
|
|
o 9 public a-H - 967b449fbc94
|
|
|
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
| o 3 public a-C - 54acac6f23ab
|
|
| |
|
|
o | 2 public b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
$ hg -R ../alpha update 967b449fbc94 #for latter test consistency
|
|
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
$ hgph -R ../alpha
|
|
@ 10 public a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Discovery locally secret changeset on a remote repository:
|
|
|
|
- should make it non-secret
|
|
|
|
$ cd ../alpha
|
|
$ mkcommit A-secret --config phases.new-commit=2
|
|
$ hgph
|
|
@ 11 secret A-secret - 435b5d83910c
|
|
|
|
|
o 10 public a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hg bundle --base 'parents(.)' -r . ../secret-bundle.hg
|
|
1 changesets found
|
|
$ hg -R ../mu unbundle ../secret-bundle.hg
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files
|
|
(run 'hg update' to get a working copy)
|
|
$ hgph -R ../mu
|
|
o 10 draft A-secret - 435b5d83910c
|
|
|
|
|
o 9 public a-H - 967b449fbc94
|
|
|
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
| o 3 public a-C - 54acac6f23ab
|
|
| |
|
|
o | 2 public b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
$ hg pull ../mu
|
|
pulling from ../mu
|
|
searching for changes
|
|
no changes found
|
|
$ hgph
|
|
@ 11 draft A-secret - 435b5d83910c
|
|
|
|
|
o 10 public a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
pushing a locally public and draft changesets remotely secret should make them
|
|
appear on the remote side.
|
|
|
|
$ hg -R ../mu phase --secret --force 967b449fbc94
|
|
$ hg push -r 435b5d83910c ../mu
|
|
pushing to ../mu
|
|
searching for changes
|
|
abort: push creates new remote head 435b5d83910c!
|
|
(merge or see 'hg help push' for details about pushing new heads)
|
|
[255]
|
|
$ hg push -fr 435b5d83910c ../mu # because the push will create new visible head
|
|
pushing to ../mu
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 0 changesets with 0 changes to 2 files
|
|
$ hgph -R ../mu
|
|
o 10 draft A-secret - 435b5d83910c
|
|
|
|
|
o 9 public a-H - 967b449fbc94
|
|
|
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
| o 3 public a-C - 54acac6f23ab
|
|
| |
|
|
o | 2 public b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
pull new changeset with common draft locally
|
|
|
|
$ hg up -q 967b449fbc94 # create a new root for draft
|
|
$ mkcommit 'alpha-more'
|
|
created new head
|
|
$ hg push -fr . ../mu
|
|
pushing to ../mu
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files (+1 heads)
|
|
$ cd ../mu
|
|
$ hg phase --secret --force 1c5cfd894796
|
|
$ hg up -q 435b5d83910c
|
|
$ mkcommit 'mu-more'
|
|
$ cd ../alpha
|
|
$ hg pull ../mu
|
|
pulling from ../mu
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files
|
|
(run 'hg update' to get a working copy)
|
|
$ hgph
|
|
o 13 draft mu-more - 5237fb433fc8
|
|
|
|
|
| @ 12 draft alpha-more - 1c5cfd894796
|
|
| |
|
|
o | 11 draft A-secret - 435b5d83910c
|
|
|/
|
|
o 10 public a-H - 967b449fbc94
|
|
|
|
|
| o 9 draft a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
Test that test are properly ignored on remote event when existing locally
|
|
|
|
$ cd ..
|
|
$ hg clone -qU -r b555f63b6063 -r f54f1bb90ff3 beta gamma
|
|
|
|
# pathological case are
|
|
#
|
|
# * secret remotely
|
|
# * known locally
|
|
# * repo have uncommon changeset
|
|
|
|
$ hg -R beta phase --secret --force f54f1bb90ff3
|
|
$ hg -R gamma phase --draft --force f54f1bb90ff3
|
|
|
|
$ cd gamma
|
|
$ hg pull ../beta
|
|
pulling from ../beta
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 2 changesets with 2 changes to 2 files
|
|
(run 'hg update' to get a working copy)
|
|
$ hg phase f54f1bb90ff3
|
|
2: draft
|
|
|
|
same over the wire
|
|
|
|
$ cd ../beta
|
|
$ hg serve -p $HGPORT -d --pid-file=../beta.pid -E ../beta-error.log
|
|
$ cat ../beta.pid >> $DAEMON_PIDS
|
|
$ cd ../gamma
|
|
|
|
$ hg pull http://localhost:$HGPORT/ # bundle2+
|
|
pulling from http://localhost:$HGPORT/
|
|
searching for changes
|
|
no changes found
|
|
$ hg phase f54f1bb90ff3
|
|
2: draft
|
|
|
|
enforce bundle1
|
|
|
|
$ hg pull http://localhost:$HGPORT/ --config devel.legacy.exchange=bundle1
|
|
pulling from http://localhost:$HGPORT/
|
|
searching for changes
|
|
no changes found
|
|
$ hg phase f54f1bb90ff3
|
|
2: draft
|
|
|
|
check that secret local on both side are not synced to public
|
|
|
|
$ hg push -r b555f63b6063 http://localhost:$HGPORT/
|
|
pushing to http://localhost:$HGPORT/
|
|
searching for changes
|
|
no changes found
|
|
[1]
|
|
$ hg phase f54f1bb90ff3
|
|
2: draft
|
|
|
|
put the changeset in the draft state again
|
|
(first test after this one expect to be able to copy)
|
|
|
|
$ cd ..
|
|
|
|
|
|
Test Clone behavior
|
|
|
|
A. Clone without secret changeset
|
|
|
|
1. cloning non-publishing repository
|
|
(Phase should be preserved)
|
|
|
|
# make sure there is no secret so we can use a copy clone
|
|
|
|
$ hg -R mu phase --draft 'secret()'
|
|
|
|
$ hg clone -U mu Tau
|
|
$ hgph -R Tau
|
|
o 12 draft mu-more - 5237fb433fc8
|
|
|
|
|
| o 11 draft alpha-more - 1c5cfd894796
|
|
| |
|
|
o | 10 draft A-secret - 435b5d83910c
|
|
|/
|
|
o 9 public a-H - 967b449fbc94
|
|
|
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
| o 4 public a-D - b555f63b6063
|
|
| |
|
|
| o 3 public a-C - 54acac6f23ab
|
|
| |
|
|
o | 2 public b-A - f54f1bb90ff3
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
|
|
2. cloning publishing repository
|
|
|
|
(everything should be public)
|
|
|
|
$ hg clone -U alpha Upsilon
|
|
$ hgph -R Upsilon
|
|
o 13 public mu-more - 5237fb433fc8
|
|
|
|
|
| o 12 public alpha-more - 1c5cfd894796
|
|
| |
|
|
o | 11 public A-secret - 435b5d83910c
|
|
|/
|
|
o 10 public a-H - 967b449fbc94
|
|
|
|
|
| o 9 public a-G - 3e27b6f1eee1
|
|
| |
|
|
| o 8 public a-F - b740e3e5c05d
|
|
| |
|
|
| o 7 public a-E - e9f537e46dea
|
|
| |
|
|
+---o 6 public n-B - 145e75495359
|
|
| |
|
|
o | 5 public n-A - d6bcb4f74035
|
|
| |
|
|
o | 4 public b-A - f54f1bb90ff3
|
|
| |
|
|
| o 3 public a-D - b555f63b6063
|
|
| |
|
|
| o 2 public a-C - 54acac6f23ab
|
|
|/
|
|
o 1 public a-B - 548a3d25dbf0
|
|
|
|
|
o 0 public a-A - 054250a37db4
|
|
|
|
#if unix-permissions no-root
|
|
|
|
Pushing From an unlockable repo
|
|
--------------------------------
|
|
(issue3684)
|
|
|
|
Unability to lock the source repo should not prevent the push. It will prevent
|
|
the retrieval of remote phase during push. For example, pushing to a publishing
|
|
server won't turn changeset public.
|
|
|
|
1. Test that push is not prevented
|
|
|
|
$ hg init Phi
|
|
$ cd Upsilon
|
|
$ chmod -R -w .hg
|
|
$ hg push ../Phi
|
|
pushing to ../Phi
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 14 changesets with 14 changes to 14 files (+3 heads)
|
|
$ chmod -R +w .hg
|
|
|
|
2. Test that failed phases movement are reported
|
|
|
|
$ hg phase --force --draft 3
|
|
$ chmod -R -w .hg
|
|
$ hg push ../Phi
|
|
pushing to ../Phi
|
|
searching for changes
|
|
no changes found
|
|
cannot lock source repo, skipping local public phase update
|
|
[1]
|
|
$ chmod -R +w .hg
|
|
|
|
$ cd ..
|
|
|
|
#endif
|
|
|
|
Test that clone behaves like pull and doesn't
|
|
publish changesets as plain push does
|
|
|
|
$ hg -R Upsilon phase -q --force --draft 2
|
|
$ hg clone -q Upsilon Pi -r 7
|
|
$ hgph Upsilon -r 'min(draft())'
|
|
o 2 draft a-C - 54acac6f23ab
|
|
|
|
|
~
|
|
|
|
$ hg -R Upsilon push Pi -r 7
|
|
pushing to Pi
|
|
searching for changes
|
|
no changes found
|
|
[1]
|
|
$ hgph Upsilon -r 'min(draft())'
|
|
o 8 draft a-F - b740e3e5c05d
|
|
|
|
|
~
|
|
|
|
$ hg -R Upsilon push Pi -r 8
|
|
pushing to Pi
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files
|
|
|
|
$ hgph Upsilon -r 'min(draft())'
|
|
o 9 draft a-G - 3e27b6f1eee1
|
|
|
|
|
~
|