##// END OF EJS Templates
merge default into stable for 5.4 release
merge default into stable for 5.4 release

File last commit:

r45126:c70bcaf7 default
r45223:26ce8e75 merge 5.4rc0 stable
Show More
test-persistent-nodemap.t
413 lines | 14.3 KiB | text/troff | Tads3Lexer
/ tests / test-persistent-nodemap.t
nodemap: have some python code writing a nodemap in persistent binary form...
r44788 ===================================
Test the persistent on-disk nodemap
===================================
$ hg init test-repo
$ cd test-repo
nodemap: write nodemap data on disk...
r44789 $ cat << EOF >> .hg/hgrc
> [experimental]
> exp-persistent-nodemap=yes
nodemap: add a (python) index class for persistent nodemap testing...
r44794 > [devel]
> persistent-nodemap=yes
nodemap: write nodemap data on disk...
r44789 > EOF
nodemap: have some python code writing a nodemap in persistent binary form...
r44788 $ hg debugbuilddag .+5000
nodemap: add a flag to dump the details of the docket...
r44806 $ hg debugnodemap --metadata
uid: ???????????????? (glob)
nodemap: track the maximum revision tracked in the nodemap...
r44807 tip-rev: 5000
nodemap: track the tip_node for validation...
r45002 tip-node: 06ddac466af534d365326c13c3879f97caca3cb1
nodemap: track the total and unused amount of data in the rawdata file...
r44808 data-length: 122880
data-unused: 0
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.000%
nodemap: use an intermediate "docket" file to carry small metadata...
r44792 $ f --size .hg/store/00changelog.n
nodemap: track the tip_node for validation...
r45002 .hg/store/00changelog.n: size=70
nodemap: check that a simple lookup works fine...
r44954
Simple lookup works
$ ANYNODE=`hg log --template '{node|short}\n' --rev tip`
$ hg log -r "$ANYNODE" --template '{rev}\n'
5000
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000
#if rust
$ f --sha256 .hg/store/00changelog-*.nd
.hg/store/00changelog-????????????????.nd: sha256=1e38e9ffaa45cad13f15c1a9880ad606f4241e8beea2f61b4d5365abadfb55f6 (glob)
$ hg debugnodemap --dump-new | f --sha256 --size
size=122880, sha256=1e38e9ffaa45cad13f15c1a9880ad606f4241e8beea2f61b4d5365abadfb55f6
$ hg debugnodemap --dump-disk | f --sha256 --bytes=256 --hexdump --size
size=122880, sha256=1e38e9ffaa45cad13f15c1a9880ad606f4241e8beea2f61b4d5365abadfb55f6
0000: 00 00 00 76 00 00 01 65 00 00 00 95 00 00 01 34 |...v...e.......4|
0010: 00 00 00 19 00 00 01 69 00 00 00 ab 00 00 00 4b |.......i.......K|
0020: 00 00 00 07 00 00 01 4c 00 00 00 f8 00 00 00 8f |.......L........|
0030: 00 00 00 c0 00 00 00 a7 00 00 00 89 00 00 01 46 |...............F|
0040: 00 00 00 92 00 00 01 bc 00 00 00 71 00 00 00 ac |...........q....|
0050: 00 00 00 af 00 00 00 b4 00 00 00 34 00 00 01 ca |...........4....|
0060: 00 00 00 23 00 00 01 45 00 00 00 2d 00 00 00 b2 |...#...E...-....|
0070: 00 00 00 56 00 00 01 0f 00 00 00 4e 00 00 02 4c |...V.......N...L|
0080: 00 00 00 e7 00 00 00 cd 00 00 01 5b 00 00 00 78 |...........[...x|
0090: 00 00 00 e3 00 00 01 8e 00 00 00 4f 00 00 00 b1 |...........O....|
00a0: 00 00 00 30 00 00 00 11 00 00 00 25 00 00 00 d2 |...0.......%....|
00b0: 00 00 00 ec 00 00 00 69 00 00 01 2b 00 00 01 2e |.......i...+....|
00c0: 00 00 00 aa 00 00 00 15 00 00 00 3a 00 00 01 4e |...........:...N|
00d0: 00 00 00 4d 00 00 00 9d 00 00 00 8e 00 00 00 a4 |...M............|
00e0: 00 00 00 c3 00 00 00 eb 00 00 00 29 00 00 00 ad |...........)....|
00f0: 00 00 01 3a 00 00 01 32 00 00 00 04 00 00 00 53 |...:...2.......S|
#else
nodemap: delete older raw data file when creating a new ones...
r44793 $ f --sha256 .hg/store/00changelog-*.nd
.hg/store/00changelog-????????????????.nd: sha256=b961925120e1c9bc345c199b2cc442abc477029fdece37ef9d99cbe59c0558b7 (glob)
nodemap: add a function to read the data from disk...
r44790 $ hg debugnodemap --dump-new | f --sha256 --size
nodemap: write nodemap data on disk...
r44789 size=122880, sha256=b961925120e1c9bc345c199b2cc442abc477029fdece37ef9d99cbe59c0558b7
nodemap: add a function to read the data from disk...
r44790 $ hg debugnodemap --dump-disk | f --sha256 --bytes=256 --hexdump --size
nodemap: have some python code writing a nodemap in persistent binary form...
r44788 size=122880, sha256=b961925120e1c9bc345c199b2cc442abc477029fdece37ef9d99cbe59c0558b7
0000: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
0010: ff ff ff ff ff ff ff ff ff ff fa c2 ff ff ff ff |................|
0020: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
0030: ff ff ff ff ff ff ed b3 ff ff ff ff ff ff ff ff |................|
0040: ff ff ff ff ff ff ee 34 00 00 00 00 ff ff ff ff |.......4........|
0050: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
0060: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
0070: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
0080: ff ff ff ff ff ff f8 50 ff ff ff ff ff ff ff ff |.......P........|
0090: ff ff ff ff ff ff ff ff ff ff ec c7 ff ff ff ff |................|
00a0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
00b0: ff ff ff ff ff ff fa be ff ff f2 fc ff ff ff ff |................|
00c0: ff ff ff ff ff ff ef ea ff ff ff ff ff ff f9 17 |................|
00d0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
00e0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
00f0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000
#endif
nodemap: add basic checking of the on disk nodemap content...
r44799 $ hg debugnodemap --check
revision in index: 5001
revision in nodemap: 5001
nodemap: delete older raw data file when creating a new ones...
r44793
add a new commit
$ hg up
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ echo foo > foo
$ hg add foo
$ hg ci -m 'foo'
nodemap: track the total and unused amount of data in the rawdata file...
r44808
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000 #if no-pure no-rust
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5001
nodemap: track the tip_node for validation...
r45002 tip-node: 2dd9b5258caa46469ff07d4a3da1eb3529a51f49
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000 data-length: 122880
data-unused: 0
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.000%
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000 #else
nodemap: add a flag to dump the details of the docket...
r44806 $ hg debugnodemap --metadata
uid: ???????????????? (glob)
nodemap: track the maximum revision tracked in the nodemap...
r44807 tip-rev: 5001
nodemap: track the tip_node for validation...
r45002 tip-node: 2dd9b5258caa46469ff07d4a3da1eb3529a51f49
nodemap: track the total and unused amount of data in the rawdata file...
r44808 data-length: 123072
data-unused: 192
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.156%
nodemap: track the total and unused amount of data in the rawdata file...
r44808 #endif
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000
nodemap: delete older raw data file when creating a new ones...
r44793 $ f --size .hg/store/00changelog.n
nodemap: track the tip_node for validation...
r45002 .hg/store/00changelog.n: size=70
nodemap: introduce append-only incremental update of the persistent data...
r44805
(The pure code use the debug code that perform incremental update, the C code reencode from scratch)
#if pure
$ f --sha256 .hg/store/00changelog-*.nd --size
.hg/store/00changelog-????????????????.nd: size=123072, sha256=136472751566c8198ff09e306a7d2f9bd18bd32298d614752b73da4d6df23340 (glob)
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000 #endif
nodemap: introduce append-only incremental update of the persistent data...
r44805
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000 #if rust
$ f --sha256 .hg/store/00changelog-*.nd --size
.hg/store/00changelog-????????????????.nd: size=123072, sha256=ccc8a43310ace13812fcc648683e259346754ef934c12dd238cf9b7fadfe9a4b (glob)
#endif
#if no-pure no-rust
nodemap: delete older raw data file when creating a new ones...
r44793 $ f --sha256 .hg/store/00changelog-*.nd --size
.hg/store/00changelog-????????????????.nd: size=122880, sha256=bfafebd751c4f6d116a76a37a1dee2a251747affe7efbcc4f4842ccc746d4db9 (glob)
nodemap: introduce append-only incremental update of the persistent data...
r44805 #endif
nodemap: add basic checking of the on disk nodemap content...
r44799 $ hg debugnodemap --check
revision in index: 5002
revision in nodemap: 5002
nodemap: introduce an option to use mmap to read the nodemap mapping...
r44843
Test code path without mmap
---------------------------
$ echo bar > bar
$ hg add bar
$ hg ci -m 'bar' --config experimental.exp-persistent-nodemap.mmap=no
$ hg debugnodemap --check --config experimental.exp-persistent-nodemap.mmap=yes
revision in index: 5003
revision in nodemap: 5003
$ hg debugnodemap --check --config experimental.exp-persistent-nodemap.mmap=no
revision in index: 5003
revision in nodemap: 5003
#if pure
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5002
nodemap: track the tip_node for validation...
r45002 tip-node: 6ce944fafcee85af91f29ea5b51654cc6101ad7e
nodemap: introduce an option to use mmap to read the nodemap mapping...
r44843 data-length: 123328
data-unused: 384
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.311%
nodemap: introduce an option to use mmap to read the nodemap mapping...
r44843 $ f --sha256 .hg/store/00changelog-*.nd --size
.hg/store/00changelog-????????????????.nd: size=123328, sha256=10d26e9776b6596af0f89143a54eba8cc581e929c38242a02a7b0760698c6c70 (glob)
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000 #endif
#if rust
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5002
nodemap: track the tip_node for validation...
r45002 tip-node: 6ce944fafcee85af91f29ea5b51654cc6101ad7e
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000 data-length: 123328
data-unused: 384
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.311%
rust-nodemap: automatically use the rust index for persistent nodemap...
r45000 $ f --sha256 .hg/store/00changelog-*.nd --size
.hg/store/00changelog-????????????????.nd: size=123328, sha256=081eec9eb6708f2bf085d939b4c97bc0b6762bc8336bc4b93838f7fffa1516bf (glob)
#endif
#if no-pure no-rust
nodemap: introduce an option to use mmap to read the nodemap mapping...
r44843 $ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5002
nodemap: track the tip_node for validation...
r45002 tip-node: 6ce944fafcee85af91f29ea5b51654cc6101ad7e
nodemap: introduce an option to use mmap to read the nodemap mapping...
r44843 data-length: 122944
data-unused: 0
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.000%
nodemap: introduce an option to use mmap to read the nodemap mapping...
r44843 $ f --sha256 .hg/store/00changelog-*.nd --size
.hg/store/00changelog-????????????????.nd: size=122944, sha256=755976b22b64ab680401b45395953504e64e7fa8c31ac570f58dee21e15f9bc0 (glob)
#endif
nodemap: warm the persistent nodemap on disk with debugupdatecache...
r44932
Test force warming the cache
$ rm .hg/store/00changelog.n
$ hg debugnodemap --metadata
$ hg debugupdatecache
#if pure
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5002
nodemap: track the tip_node for validation...
r45002 tip-node: 6ce944fafcee85af91f29ea5b51654cc6101ad7e
nodemap: warm the persistent nodemap on disk with debugupdatecache...
r44932 data-length: 122944
data-unused: 0
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.000%
nodemap: warm the persistent nodemap on disk with debugupdatecache...
r44932 #else
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5002
nodemap: track the tip_node for validation...
r45002 tip-node: 6ce944fafcee85af91f29ea5b51654cc6101ad7e
nodemap: warm the persistent nodemap on disk with debugupdatecache...
r44932 data-length: 122944
data-unused: 0
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.000%
nodemap: warm the persistent nodemap on disk with debugupdatecache...
r44932 #endif
nodemap: test that an outdated nodemap can catch up...
r44984
Check out of sync nodemap
=========================
First copy old data on the side.
$ mkdir ../tmp-copies
$ cp .hg/store/00changelog-????????????????.nd .hg/store/00changelog.n ../tmp-copies
Nodemap lagging behind
----------------------
make a new commit
$ echo bar2 > bar
$ hg ci -m 'bar2'
$ NODE=`hg log -r tip -T '{node}\n'`
$ hg log -r "$NODE" -T '{rev}\n'
5003
If the nodemap is lagging behind, it can catch up fine
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5003
nodemap: track the tip_node for validation...
r45002 tip-node: 5c049e9c4a4af159bdcd65dce1b6bf303a0da6cf
nodemap: test that an outdated nodemap can catch up...
r44984 data-length: 123200 (pure !)
data-length: 123200 (rust !)
data-length: 122944 (no-rust no-pure !)
data-unused: 256 (pure !)
data-unused: 256 (rust !)
data-unused: 0 (no-rust no-pure !)
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.208% (pure !)
data-unused: 0.208% (rust !)
data-unused: 0.000% (no-rust no-pure !)
nodemap: test that an outdated nodemap can catch up...
r44984 $ cp -f ../tmp-copies/* .hg/store/
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5002
nodemap: track the tip_node for validation...
r45002 tip-node: 6ce944fafcee85af91f29ea5b51654cc6101ad7e
nodemap: test that an outdated nodemap can catch up...
r44984 data-length: 122944
data-unused: 0
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.000%
nodemap: test that an outdated nodemap can catch up...
r44984 $ hg log -r "$NODE" -T '{rev}\n'
5003
nodemap: track the tip_node for validation...
r45002
changelog altered
-----------------
If the nodemap is not gated behind a requirements, an unaware client can alter
the repository so the revlog used to generate the nodemap is not longer
compatible with the persistent nodemap. We need to detect that.
$ hg up "$NODE~5"
0 files updated, 0 files merged, 2 files removed, 0 files unresolved
$ echo bar > babar
$ hg add babar
$ hg ci -m 'babar'
created new head
$ OTHERNODE=`hg log -r tip -T '{node}\n'`
$ hg log -r "$OTHERNODE" -T '{rev}\n'
5004
$ hg --config extensions.strip= strip --rev "$NODE~1" --no-backup
the nodemap should detect the changelog have been tampered with and recover.
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5002
tip-node: 42bf3068c7ddfdfded53c4eb11d02266faeebfee
data-length: 123456 (pure !)
nodemap: automatically "vacuum" the persistent nodemap when too sparse...
r45126 data-length: 123008 (rust !)
nodemap: track the tip_node for validation...
r45002 data-length: 123008 (no-pure no-rust !)
data-unused: 448 (pure !)
nodemap: automatically "vacuum" the persistent nodemap when too sparse...
r45126 data-unused: 0 (rust !)
nodemap: track the tip_node for validation...
r45002 data-unused: 0 (no-pure no-rust !)
nodemap: automatically "vacuum" the persistent nodemap when too sparse...
r45126 data-unused: 0.000% (rust !)
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.363% (pure !)
data-unused: 0.000% (no-pure no-rust !)
nodemap: track the tip_node for validation...
r45002
$ cp -f ../tmp-copies/* .hg/store/
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5002
tip-node: 6ce944fafcee85af91f29ea5b51654cc6101ad7e
data-length: 122944
data-unused: 0
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.000%
nodemap: track the tip_node for validation...
r45002 $ hg log -r "$OTHERNODE" -T '{rev}\n'
5002
nodemap: make sure hooks have access to an up-to-date version...
r45003
Check transaction related property
==================================
An up to date nodemap should be available to shell hooks,
$ echo dsljfl > a
$ hg add a
$ hg ci -m a
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5003
tip-node: c91af76d172f1053cca41b83f7c2e4e514fe2bcf
data-length: 123008
data-unused: 0
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.000%
nodemap: make sure hooks have access to an up-to-date version...
r45003 $ echo babar2 > babar
$ hg ci -m 'babar2' --config "hooks.pretxnclose.nodemap-test=hg debugnodemap --metadata"
uid: ???????????????? (glob)
tip-rev: 5004
tip-node: ba87cd9559559e4b91b28cb140d003985315e031
data-length: 123328 (pure !)
data-length: 123328 (rust !)
data-length: 123136 (no-pure no-rust !)
data-unused: 192 (pure !)
data-unused: 192 (rust !)
data-unused: 0 (no-pure no-rust !)
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.156% (pure !)
data-unused: 0.156% (rust !)
data-unused: 0.000% (no-pure no-rust !)
nodemap: make sure hooks have access to an up-to-date version...
r45003 $ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5004
tip-node: ba87cd9559559e4b91b28cb140d003985315e031
data-length: 123328 (pure !)
data-length: 123328 (rust !)
data-length: 123136 (no-pure no-rust !)
data-unused: 192 (pure !)
data-unused: 192 (rust !)
data-unused: 0 (no-pure no-rust !)
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.156% (pure !)
data-unused: 0.156% (rust !)
data-unused: 0.000% (no-pure no-rust !)
nodemap: test that concurrent process don't see the pending transaction...
r45123
Another process does not see the pending nodemap content during run.
$ PATH=$RUNTESTDIR/testlib/:$PATH
$ echo qpoasp > a
$ hg ci -m a2 \
> --config "hooks.pretxnclose=wait-on-file 20 sync-repo-read sync-txn-pending" \
> --config "hooks.txnclose=touch sync-txn-close" > output.txt 2>&1 &
(read the repository while the commit transaction is pending)
$ wait-on-file 20 sync-txn-pending && \
> hg debugnodemap --metadata && \
> wait-on-file 20 sync-txn-close sync-repo-read
uid: ???????????????? (glob)
tip-rev: 5004
tip-node: ba87cd9559559e4b91b28cb140d003985315e031
data-length: 123328 (pure !)
data-length: 123328 (rust !)
data-length: 123136 (no-pure no-rust !)
data-unused: 192 (pure !)
data-unused: 192 (rust !)
data-unused: 0 (no-pure no-rust !)
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.156% (pure !)
data-unused: 0.156% (rust !)
data-unused: 0.000% (no-pure no-rust !)
nodemap: test that concurrent process don't see the pending transaction...
r45123 $ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5005
tip-node: bae4d45c759e30f1cb1a40e1382cf0e0414154db
data-length: 123584 (pure !)
data-length: 123584 (rust !)
data-length: 123136 (no-pure no-rust !)
data-unused: 448 (pure !)
data-unused: 448 (rust !)
data-unused: 0 (no-pure no-rust !)
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-unused: 0.363% (pure !)
data-unused: 0.363% (rust !)
data-unused: 0.000% (no-pure no-rust !)
nodemap: test that concurrent process don't see the pending transaction...
r45123
$ cat output.txt
nodemap: make sure on disk change get rolled back with the transaction...
r45124 Check that a failing transaction will properly revert the data
$ echo plakfe > a
$ f --size --sha256 .hg/store/00changelog-*.nd
.hg/store/00changelog-????????????????.nd: size=123584, sha256=8c6cef6fd3d3fac291968793ee19a4be6d0b8375e9508bd5c7d4a8879e8df180 (glob) (pure !)
.hg/store/00changelog-????????????????.nd: size=123584, sha256=eb9e9a4bcafdb5e1344bc8a0cbb3288b2106413b8efae6265fb8a7973d7e97f9 (glob) (rust !)
.hg/store/00changelog-????????????????.nd: size=123136, sha256=4f504f5a834db3811ced50ab3e9e80bcae3581bb0f9b13a7a9f94b7fc34bcebe (glob) (no-pure no-rust !)
$ hg ci -m a3 --config "extensions.abort=$RUNTESTDIR/testlib/crash_transaction_late.py"
transaction abort!
rollback completed
abort: This is a late abort
[255]
$ hg debugnodemap --metadata
uid: ???????????????? (glob)
tip-rev: 5005
tip-node: bae4d45c759e30f1cb1a40e1382cf0e0414154db
nodemap: display percentage of unused in `hg debugnodemap`...
r45125 data-length: 123584 (pure !)
data-length: 123584 (rust !)
data-length: 123136 (no-pure no-rust !)
data-unused: 448 (pure !)
data-unused: 448 (rust !)
data-unused: 0 (no-pure no-rust !)
data-unused: 0.363% (pure !)
data-unused: 0.363% (rust !)
data-unused: 0.000% (no-pure no-rust !)
nodemap: make sure on disk change get rolled back with the transaction...
r45124 $ f --size --sha256 .hg/store/00changelog-*.nd
.hg/store/00changelog-????????????????.nd: size=123584, sha256=8c6cef6fd3d3fac291968793ee19a4be6d0b8375e9508bd5c7d4a8879e8df180 (glob) (pure !)
.hg/store/00changelog-????????????????.nd: size=123584, sha256=eb9e9a4bcafdb5e1344bc8a0cbb3288b2106413b8efae6265fb8a7973d7e97f9 (glob) (rust !)
.hg/store/00changelog-????????????????.nd: size=123136, sha256=4f504f5a834db3811ced50ab3e9e80bcae3581bb0f9b13a7a9f94b7fc34bcebe (glob) (no-pure no-rust !)