test-generaldelta.t
105 lines
| 3.1 KiB
| text/troff
|
Tads3Lexer
/ tests / test-generaldelta.t
Wojciech Lopata
|
r19764 | Check whether size of generaldelta revlog is not bigger than its | ||
regular equivalent. Test would fail if generaldelta was naive | ||||
implementation of parentdelta: third manifest revision would be fully | ||||
inserted due to big distance from its paren revision (zero). | ||||
$ hg init repo | ||||
$ cd repo | ||||
$ echo foo > foo | ||||
$ echo bar > bar | ||||
$ hg commit -q -Am boo | ||||
$ hg clone --pull . ../gdrepo -q --config format.generaldelta=yes | ||||
$ for r in 1 2 3; do | ||||
> echo $r > foo | ||||
> hg commit -q -m $r | ||||
> hg up -q -r 0 | ||||
> hg pull . -q -r $r -R ../gdrepo | ||||
> done | ||||
Matt Mackall
|
r19942 | |||
Wojciech Lopata
|
r19764 | $ cd .. | ||
Matt Mackall
|
r19942 | >>> import os | ||
>>> regsize = os.stat("repo/.hg/store/00manifest.i").st_size | ||||
>>> gdsize = os.stat("gdrepo/.hg/store/00manifest.i").st_size | ||||
>>> if regsize < gdsize: | ||||
... print 'generaldata increased size of manifest' | ||||
Durham Goode
|
r23381 | |||
Verify rev reordering doesnt create invalid bundles (issue4462) | ||||
This requires a commit tree that when pulled will reorder manifest revs such | ||||
that the second manifest to create a file rev will be ordered before the first | ||||
manifest to create that file rev. We also need to do a partial pull to ensure | ||||
reordering happens. At the end we verify the linkrev points at the earliest | ||||
commit. | ||||
$ hg init server --config format.generaldelta=True | ||||
$ cd server | ||||
$ touch a | ||||
$ hg commit -Aqm a | ||||
$ echo x > x | ||||
$ echo y > y | ||||
$ hg commit -Aqm xy | ||||
$ hg up -q '.^' | ||||
$ echo x > x | ||||
$ echo z > z | ||||
$ hg commit -Aqm xz | ||||
$ hg up -q 1 | ||||
$ echo b > b | ||||
$ hg commit -Aqm b | ||||
$ hg merge -q 2 | ||||
$ hg commit -Aqm merge | ||||
$ echo c > c | ||||
$ hg commit -Aqm c | ||||
$ hg log -G -T '{rev} {shortest(node)} {desc}' | ||||
@ 5 ebb8 c | ||||
| | ||||
o 4 baf7 merge | ||||
|\ | ||||
| o 3 a129 b | ||||
| | | ||||
o | 2 958c xz | ||||
| | | ||||
| o 1 f00c xy | ||||
|/ | ||||
o 0 3903 a | ||||
$ cd .. | ||||
$ hg init client | ||||
$ cd client | ||||
$ hg pull -q ../server -r 4 | ||||
$ hg debugindex x | ||||
rev offset length base linkrev nodeid p1 p2 | ||||
0 0 3 0 1 1406e7411862 000000000000 000000000000 | ||||
Durham Goode
|
r26118 | $ cd .. | ||
Test format.aggressivemergedeltas | ||||
$ hg init --config format.generaldelta=1 aggressive | ||||
$ cd aggressive | ||||
$ touch a b c d e | ||||
$ hg commit -Aqm side1 | ||||
$ hg up -q null | ||||
$ touch x y | ||||
$ hg commit -Aqm side2 | ||||
- Verify non-aggressive merge uses p1 (commit 1) as delta parent | ||||
$ hg merge -q 0 | ||||
$ hg commit -q -m merge | ||||
$ hg debugindex -m | ||||
rev offset length delta linkrev nodeid p1 p2 | ||||
0 0 59 -1 0 8dde941edb6e 000000000000 000000000000 | ||||
1 59 59 -1 1 315c023f341d 000000000000 000000000000 | ||||
2 118 65 1 2 2ab389a983eb 315c023f341d 8dde941edb6e | ||||
$ hg strip -q -r . --config extensions.strip= | ||||
- Verify aggressive merge uses p2 (commit 0) as delta parent | ||||
$ hg up -q -C 1 | ||||
$ hg merge -q 0 | ||||
$ hg commit -q -m merge --config format.aggressivemergedeltas=True | ||||
$ hg debugindex -m | ||||
rev offset length delta linkrev nodeid p1 p2 | ||||
0 0 59 -1 0 8dde941edb6e 000000000000 000000000000 | ||||
1 59 59 -1 1 315c023f341d 000000000000 000000000000 | ||||
2 118 62 0 2 2ab389a983eb 315c023f341d 8dde941edb6e | ||||
$ cd .. | ||||