2016-12-03 01:37:55 +03:00
|
|
|
$ . "$TESTDIR/library.sh"
|
|
|
|
|
|
|
|
$ PYTHONPATH=$TESTDIR/..:$PYTHONPATH
|
|
|
|
$ export PYTHONPATH
|
|
|
|
|
2017-04-20 07:14:03 +03:00
|
|
|
$ hg init master
|
|
|
|
$ hg clone -q ssh://user@dummy/master client
|
|
|
|
|
|
|
|
$ cd master
|
|
|
|
$ echo a > a && hg commit -Aqm 'add a'
|
|
|
|
$ mkdir dir && echo b > dir/b && hg commit -Aqm 'add dir/b'
|
|
|
|
|
|
|
|
$ cd ../client
|
|
|
|
$ cat >> .hg/hgrc <<EOF
|
2016-12-03 01:37:55 +03:00
|
|
|
> [extensions]
|
2017-06-19 18:02:38 +03:00
|
|
|
> fastmanifest=$TESTDIR/../fastmanifest
|
|
|
|
> treemanifest=$TESTDIR/../treemanifest
|
2016-12-03 01:37:55 +03:00
|
|
|
>
|
|
|
|
> [remotefilelog]
|
|
|
|
> usefastdatapack=True
|
|
|
|
> reponame=master
|
|
|
|
>
|
|
|
|
> [fastmanifest]
|
|
|
|
> usetree=True
|
|
|
|
> usecache=False
|
2017-04-20 07:14:03 +03:00
|
|
|
>
|
2016-12-03 01:37:55 +03:00
|
|
|
> [treemanifest]
|
|
|
|
> autocreatetrees=True
|
|
|
|
> EOF
|
|
|
|
|
2016-12-03 01:37:57 +03:00
|
|
|
# Test repacking shared manifest packs
|
2016-12-03 01:37:55 +03:00
|
|
|
$ hg pull -q -r 0
|
|
|
|
$ hg pull -q -r 1
|
2017-04-27 05:50:36 +03:00
|
|
|
$ ls_l $CACHEDIR/master/packs/manifests | grep pack
|
2017-05-03 20:19:45 +03:00
|
|
|
-r--r--r-- 89 4301ce26f4c07686220c7f57d80b466cfba9899e.histpack
|
2017-04-27 05:50:36 +03:00
|
|
|
-r--r--r-- 100 65df85879cdd898607ee3f323a0b61edc7de25b8.datapack
|
2017-05-03 20:19:45 +03:00
|
|
|
-r--r--r-- 180 7da383a74e4ff5333b3733b9a52eb05c40b1df3d.histpack
|
2017-04-27 05:50:36 +03:00
|
|
|
-r--r--r-- 248 bb55d9105672c45d4f82df15bd091a555ef02c79.datapack
|
2016-12-03 01:37:55 +03:00
|
|
|
|
2017-03-07 22:15:26 +03:00
|
|
|
- Verify datapack contents
|
2017-04-27 05:50:36 +03:00
|
|
|
$ for i in $CACHEDIR/master/packs/manifests/*.datapack; do
|
|
|
|
> echo $i
|
|
|
|
> hg debugdatapack "$i"
|
|
|
|
> done
|
|
|
|
$TESTTMP/hgcache/master/packs/manifests/65df85879cdd898607ee3f323a0b61edc7de25b8.datapack
|
2017-11-07 06:09:15 +03:00
|
|
|
$TESTTMP/hgcache/master/packs/manifests/65df85879cdd898607ee3f323a0b61edc7de25b8:
|
2017-11-06 08:45:40 +03:00
|
|
|
(empty name):
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
|
|
|
a0c8bcbbb45c 000000000000 43 (missing)
|
2016-12-03 01:37:55 +03:00
|
|
|
|
2017-11-07 06:09:15 +03:00
|
|
|
$TESTTMP/hgcache/master/packs/manifests/bb55d9105672c45d4f82df15bd091a555ef02c79.datapack
|
|
|
|
$TESTTMP/hgcache/master/packs/manifests/bb55d9105672c45d4f82df15bd091a555ef02c79:
|
2017-11-06 08:45:40 +03:00
|
|
|
dir:
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
|
|
|
23226e7a252c 000000000000 43 (missing)
|
2016-12-03 01:37:55 +03:00
|
|
|
|
2017-11-06 08:45:40 +03:00
|
|
|
(empty name):
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
|
|
|
1832e0765de9 000000000000 89 (missing)
|
2017-11-07 06:09:15 +03:00
|
|
|
|
2017-03-07 22:15:26 +03:00
|
|
|
|
2017-04-27 05:50:36 +03:00
|
|
|
- Verify histpack contents
|
|
|
|
$ for i in $CACHEDIR/master/packs/manifests/*.histpack; do
|
|
|
|
> echo $i
|
|
|
|
> hg debughistorypack "$i"
|
|
|
|
> done
|
2017-05-03 20:19:45 +03:00
|
|
|
$TESTTMP/hgcache/master/packs/manifests/4301ce26f4c07686220c7f57d80b466cfba9899e.histpack
|
|
|
|
|
|
|
|
|
|
|
|
Node P1 Node P2 Node Link Node Copy From
|
|
|
|
a0c8bcbbb45c 000000000000 000000000000 1f0dee641bb7
|
|
|
|
$TESTTMP/hgcache/master/packs/manifests/7da383a74e4ff5333b3733b9a52eb05c40b1df3d.histpack
|
2017-03-07 22:15:26 +03:00
|
|
|
|
|
|
|
|
|
|
|
Node P1 Node P2 Node Link Node Copy From
|
|
|
|
1832e0765de9 a0c8bcbbb45c 000000000000 8e83608cbe60
|
|
|
|
|
2017-04-20 07:14:04 +03:00
|
|
|
dir
|
2017-03-07 22:15:26 +03:00
|
|
|
Node P1 Node P2 Node Link Node Copy From
|
|
|
|
23226e7a252c 000000000000 000000000000 8e83608cbe60
|
|
|
|
|
|
|
|
- Repack and reverify
|
2016-12-03 01:37:55 +03:00
|
|
|
$ hg repack
|
|
|
|
|
2017-04-27 05:50:36 +03:00
|
|
|
$ ls_l $CACHEDIR/master/packs/manifests | grep pack
|
2017-11-06 05:49:10 +03:00
|
|
|
-r--r--r-- 339 56e8c6f0ca2a324b8b5ca1a2730323a1b4d0793a.datapack
|
2017-05-03 20:19:45 +03:00
|
|
|
-r--r--r-- 262 7535b6084226436bbdff33043969e7fa963e8428.histpack
|
2016-12-03 01:37:55 +03:00
|
|
|
|
2017-04-27 05:50:36 +03:00
|
|
|
$ hg debugdatapack $CACHEDIR/master/packs/manifests/*.datapack
|
2017-11-07 06:09:15 +03:00
|
|
|
$TESTTMP/hgcache/master/packs/manifests/56e8c6f0ca2a324b8b5ca1a2730323a1b4d0793a:
|
2017-11-06 08:45:40 +03:00
|
|
|
(empty name):
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
2017-11-06 05:49:10 +03:00
|
|
|
1832e0765de9 000000000000 89 89
|
|
|
|
a0c8bcbbb45c 1832e0765de9 12 43
|
2016-12-03 01:37:55 +03:00
|
|
|
|
2017-11-07 06:09:15 +03:00
|
|
|
Total: 101 132 (23.5% smaller)
|
2017-11-06 08:45:40 +03:00
|
|
|
dir:
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
2017-11-06 05:49:10 +03:00
|
|
|
23226e7a252c 000000000000 43 43
|
2017-11-07 06:09:15 +03:00
|
|
|
|
2017-11-06 08:45:40 +03:00
|
|
|
Total: 43 43 (0.0% bigger)
|
2016-12-03 01:37:57 +03:00
|
|
|
|
2017-04-27 05:50:36 +03:00
|
|
|
$ hg debughistorypack $CACHEDIR/master/packs/manifests/*.histpack
|
2017-03-07 22:15:26 +03:00
|
|
|
|
|
|
|
|
|
|
|
Node P1 Node P2 Node Link Node Copy From
|
|
|
|
1832e0765de9 a0c8bcbbb45c 000000000000 8e83608cbe60
|
|
|
|
a0c8bcbbb45c 000000000000 000000000000 1f0dee641bb7
|
|
|
|
|
2017-04-20 07:14:04 +03:00
|
|
|
dir
|
2017-03-07 22:15:26 +03:00
|
|
|
Node P1 Node P2 Node Link Node Copy From
|
|
|
|
23226e7a252c 000000000000 000000000000 8e83608cbe60
|
|
|
|
|
2016-12-03 01:37:57 +03:00
|
|
|
# Test repacking local manifest packs
|
|
|
|
$ hg up -q 1
|
|
|
|
$ echo a >> a && hg commit -Aqm 'modify a'
|
|
|
|
$ echo b >> dir/b && hg commit -Aqm 'modify dir/b'
|
2017-04-27 05:50:36 +03:00
|
|
|
$ ls_l .hg/store/packs/manifests | grep datapack
|
|
|
|
-r--r--r-- 248 5d1716bbef6e7200192de6509055d1ee31a4172c.datapack
|
|
|
|
-r--r--r-- 146 cffef142da32f3e52c1779490e5d0ddac5f9b82b.datapack
|
2016-12-03 01:37:57 +03:00
|
|
|
$ hg repack
|
2017-07-12 03:02:15 +03:00
|
|
|
$ ls_l .hg/store/packs/manifests | grep datapack
|
2017-11-06 05:49:10 +03:00
|
|
|
-r--r--r-- 386 d15c09a9a5a13bb689bd9764455a415a20dc885e.datapack
|
2016-12-03 01:38:00 +03:00
|
|
|
|
|
|
|
# Test incremental repacking of trees
|
|
|
|
$ echo b >> dir/b && hg commit -Aqm 'modify dir/b'
|
|
|
|
$ echo b >> dir/b && hg commit -Aqm 'modify dir/b'
|
2017-07-12 03:02:15 +03:00
|
|
|
$ ls_l .hg/store/packs/manifests | grep datapack
|
|
|
|
-r--r--r-- 248 21501384df03b8489b366c5218be639fa08830e4.datapack
|
2017-11-06 05:49:10 +03:00
|
|
|
-r--r--r-- 386 d15c09a9a5a13bb689bd9764455a415a20dc885e.datapack
|
2017-07-12 03:02:15 +03:00
|
|
|
-r--r--r-- 248 d7e689a91ac63385be120a118af9ce8663748f28.datapack
|
2016-12-03 01:38:00 +03:00
|
|
|
|
|
|
|
- repack incremental does nothing here because there are so few packs
|
|
|
|
$ hg repack --incremental --config remotefilelog.data.generations=300,200 --config remotefilelog.data.repacksizelimit=300
|
2017-07-12 03:02:15 +03:00
|
|
|
$ ls_l .hg/store/packs/manifests | grep datapack
|
|
|
|
-r--r--r-- 248 21501384df03b8489b366c5218be639fa08830e4.datapack
|
2017-11-06 05:49:10 +03:00
|
|
|
-r--r--r-- 386 d15c09a9a5a13bb689bd9764455a415a20dc885e.datapack
|
2017-07-12 03:02:15 +03:00
|
|
|
-r--r--r-- 248 d7e689a91ac63385be120a118af9ce8663748f28.datapack
|
2016-12-03 01:38:00 +03:00
|
|
|
|
|
|
|
$ echo b >> dir/b && hg commit -Aqm 'modify dir/b'
|
|
|
|
$ echo b >> dir/b && hg commit -Aqm 'modify dir/b'
|
|
|
|
$ echo b >> dir/b && hg commit -Aqm 'modify dir/b'
|
2017-07-12 03:02:15 +03:00
|
|
|
$ ls_l .hg/store/packs/manifests | grep datapack
|
|
|
|
-r--r--r-- 248 21501384df03b8489b366c5218be639fa08830e4.datapack
|
|
|
|
-r--r--r-- 248 347263bf1efbdb5bf7e1d1565b6b504073fb9093.datapack
|
|
|
|
-r--r--r-- 248 544a3b46a61732209116ae50847ec333b75e3765.datapack
|
|
|
|
-r--r--r-- 248 863908ef8149261ab0d891c2344d8e8766c39441.datapack
|
2017-11-06 05:49:10 +03:00
|
|
|
-r--r--r-- 386 d15c09a9a5a13bb689bd9764455a415a20dc885e.datapack
|
2017-07-12 03:02:15 +03:00
|
|
|
-r--r--r-- 248 d7e689a91ac63385be120a118af9ce8663748f28.datapack
|
2017-08-24 19:31:10 +03:00
|
|
|
$ cd .hg/store/packs/manifests
|
|
|
|
$ cp d7e689a91ac63385be120a118af9ce8663748f28.datapack x7e689a91ac63385be120a118af9ce8663748f28.datapack
|
|
|
|
$ cp d7e689a91ac63385be120a118af9ce8663748f28.dataidx x7e689a91ac63385be120a118af9ce8663748f28.dataidx
|
|
|
|
$ cp 21501384df03b8489b366c5218be639fa08830e4.datapack x1501384df03b8489b366c5218be639fa08830e4.datapack
|
|
|
|
$ cp 21501384df03b8489b366c5218be639fa08830e4.dataidx x1501384df03b8489b366c5218be639fa08830e4.dataidx
|
|
|
|
$ cp 347263bf1efbdb5bf7e1d1565b6b504073fb9093.datapack x47263bf1efbdb5bf7e1d1565b6b504073fb9093.datapack
|
|
|
|
$ cp 347263bf1efbdb5bf7e1d1565b6b504073fb9093.dataidx x47263bf1efbdb5bf7e1d1565b6b504073fb9093.dataidx
|
|
|
|
$ cd ../../../../
|
2016-12-03 01:38:00 +03:00
|
|
|
|
|
|
|
- repack incremental kicks in once there are a number of packs
|
2017-08-24 19:31:10 +03:00
|
|
|
- (set the repacksizelimit so that we test that we only repack up to 1500 bytes,
|
2017-08-25 19:23:34 +03:00
|
|
|
- and it leaves one datapack behind)
|
2017-08-24 19:31:10 +03:00
|
|
|
$ hg repack --incremental --config remotefilelog.data.generations=300,200 --config remotefilelog.data.repacksizelimit=1500B
|
2017-08-25 19:23:34 +03:00
|
|
|
$ ls_l .hg/store/packs/manifests | grep datapack | wc -l
|
|
|
|
.*3 (re)
|
|
|
|
$ ls_l .hg/store/packs/manifests | grep datapack | grep 248
|
|
|
|
-r--r--r-- 248 *.datapack (glob)
|
|
|
|
- Clean up the pile of packs we made
|
|
|
|
$ hg repack
|
2017-04-20 07:14:04 +03:00
|
|
|
|
|
|
|
Test repacking from revlogs to pack files on the server
|
|
|
|
$ cd ../master
|
2017-05-17 01:28:13 +03:00
|
|
|
|
2017-04-20 07:14:04 +03:00
|
|
|
$ cat >> .hg/hgrc <<EOF
|
|
|
|
> [extensions]
|
2017-06-19 18:02:38 +03:00
|
|
|
> treemanifest=$TESTDIR/../treemanifest
|
|
|
|
> remotefilelog=$TESTDIR/../remotefilelog
|
2017-04-20 07:14:04 +03:00
|
|
|
> [remotefilelog]
|
|
|
|
> server=True
|
|
|
|
> [treemanifest]
|
|
|
|
> server=True
|
|
|
|
> EOF
|
|
|
|
$ hg backfilltree
|
|
|
|
$ cat .hg/store/fncache | sort
|
|
|
|
data/a.i
|
|
|
|
data/dir/b.i
|
|
|
|
meta/dir/00manifest.i
|
2017-04-20 07:14:04 +03:00
|
|
|
|
|
|
|
$ hg repack
|
|
|
|
$ ls .hg/cache/packs/manifests
|
2017-07-12 03:02:15 +03:00
|
|
|
56e8c6f0ca2a324b8b5ca1a2730323a1b4d0793a.dataidx
|
|
|
|
56e8c6f0ca2a324b8b5ca1a2730323a1b4d0793a.datapack
|
2017-05-03 20:19:45 +03:00
|
|
|
7535b6084226436bbdff33043969e7fa963e8428.histidx
|
|
|
|
7535b6084226436bbdff33043969e7fa963e8428.histpack
|
2017-04-20 07:14:04 +03:00
|
|
|
$ hg debugdatapack .hg/cache/packs/manifests/*.datapack
|
2017-11-07 06:09:15 +03:00
|
|
|
.hg/cache/packs/manifests/56e8c6f0ca2a324b8b5ca1a2730323a1b4d0793a:
|
2017-11-06 08:45:40 +03:00
|
|
|
(empty name):
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
|
|
|
1832e0765de9 000000000000 89 89
|
|
|
|
a0c8bcbbb45c 1832e0765de9 12 43
|
2017-04-20 07:14:04 +03:00
|
|
|
|
2017-11-07 06:09:15 +03:00
|
|
|
Total: 101 132 (23.5% smaller)
|
2017-11-06 08:45:40 +03:00
|
|
|
dir:
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
|
|
|
23226e7a252c 000000000000 43 43
|
2017-11-07 06:09:15 +03:00
|
|
|
|
2017-11-06 08:45:40 +03:00
|
|
|
Total: 43 43 (0.0% bigger)
|
2017-05-17 01:28:13 +03:00
|
|
|
|
|
|
|
Test incremental revlog repacking
|
2017-06-20 21:08:15 +03:00
|
|
|
# 1. Make commit that we'll need to repack
|
2017-05-17 01:28:13 +03:00
|
|
|
$ echo >> a
|
|
|
|
$ hg commit -Aqm 'modify a'
|
|
|
|
$ hg debugindex .hg/store/00manifesttree.i
|
|
|
|
rev offset length delta linkrev nodeid p1 p2
|
|
|
|
0 0 44 -1 0 a0c8bcbbb45c 000000000000 000000000000
|
|
|
|
1 44 58 0 1 1832e0765de9 a0c8bcbbb45c 000000000000
|
|
|
|
2 102 55 1 2 1618a54c483e 1832e0765de9 000000000000
|
|
|
|
|
|
|
|
# 2. Corrupt an early rev of the manifesttree, to prove we don't read it
|
|
|
|
$ cp .hg/store/00manifesttree.i .hg/store/00manifesttree.i.bak
|
|
|
|
$ printf xxxx | dd conv=notrunc of=.hg/store/00manifesttree.i bs=1 seek=32 >/dev/null 2>&1
|
|
|
|
$ hg debugindex .hg/store/00manifesttree.i
|
|
|
|
rev offset length delta linkrev nodeid p1 p2
|
|
|
|
0 0 44 -1 0 78787878b45c 000000000000 000000000000
|
|
|
|
1 44 58 0 1 1832e0765de9 78787878b45c 000000000000
|
|
|
|
2 102 55 1 2 1618a54c483e 1832e0765de9 000000000000
|
|
|
|
|
|
|
|
# 3. Check that the corrupt '78787878...' node is not in the pack
|
|
|
|
$ hg repack --incremental
|
2017-05-19 01:08:24 +03:00
|
|
|
$ hg debugdatapack .hg/cache/packs/manifests/*.datapack | grep 7878
|
|
|
|
[1]
|
2017-05-17 01:28:13 +03:00
|
|
|
$ mv .hg/store/00manifesttree.i.bak .hg/store/00manifesttree.i
|
2017-06-20 21:08:15 +03:00
|
|
|
|
|
|
|
Test incremental repack with limited revs only repacks those revs
|
|
|
|
$ rm -rf .hg/cache/packs/manifests
|
|
|
|
$ hg repack --incremental --config treemanifest.repackstartrev=1 --config treemanifest.repackendrev=1
|
|
|
|
$ hg debugdatapack .hg/cache/packs/manifests/*.datapack
|
2017-11-07 06:09:15 +03:00
|
|
|
.hg/cache/packs/manifests/e9093d2d887ff14457d43338fcb3994e92051853:
|
2017-11-06 08:45:40 +03:00
|
|
|
(empty name):
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
|
|
|
1832e0765de9 000000000000 89 89
|
2017-06-20 21:08:15 +03:00
|
|
|
|
2017-11-07 06:09:15 +03:00
|
|
|
Total: 89 89 (0.0% bigger)
|
2017-11-06 08:45:40 +03:00
|
|
|
dir:
|
2017-11-06 05:45:21 +03:00
|
|
|
Node Delta Base Delta Length Blob Size
|
|
|
|
23226e7a252c 000000000000 43 43
|
2017-11-07 06:09:15 +03:00
|
|
|
|
2017-11-06 08:45:40 +03:00
|
|
|
Total: 43 43 (0.0% bigger)
|