mirror of
https://github.com/facebook/sapling.git
synced 2024-10-11 01:07:15 +03:00
6657b619f0
Summary: Create pack files instead of loose files for local data. Now this feature is under the config flag. Reviewed By: DurhamG Differential Revision: D9700992 fbshipit-source-id: b1ee897ac6fd2fe208f54f999b230353aebaca5b
151 lines
5.2 KiB
Raku
151 lines
5.2 KiB
Raku
|
|
$ . "$TESTDIR/library.sh"
|
|
|
|
$ hginit master
|
|
$ cd master
|
|
$ cat >> .hg/hgrc <<EOF
|
|
> [remotefilelog]
|
|
> server=True
|
|
> serverexpiration=-1
|
|
> EOF
|
|
$ echo line > file
|
|
$ echo x > x
|
|
$ hg commit -qAm x
|
|
$ echo line >> file
|
|
$ echo x >> x
|
|
$ hg commit -qAm x2
|
|
$ findfilessorted .hg/store/data
|
|
.hg/store/data/file.i
|
|
.hg/store/data/x.i
|
|
$ cd ..
|
|
|
|
$ hgcloneshallow ssh://user@dummy/master shallow -q
|
|
2 files fetched over 1 fetches - (2 misses, 0.00% hit ratio) over *s (glob)
|
|
|
|
# Set the prefetchdays config to zero so that all commits are prefetched
|
|
# no matter what their creation date is.
|
|
$ cd shallow
|
|
$ cat >> .hg/hgrc <<EOF
|
|
> [remotefilelog]
|
|
> localdatarepack=True
|
|
> packlocaldata=True
|
|
> prefetchdays=0
|
|
> EOF
|
|
$ cd ..
|
|
|
|
# Pull from master
|
|
$ cd shallow
|
|
$ hg pull -q
|
|
$ hg up -q tip
|
|
|
|
# Test pack local data
|
|
$ findfilessorted .hg/store/data
|
|
$ test -d .hg/store/packs
|
|
[1]
|
|
|
|
# new loose file is created
|
|
$ echo "new commit" > new_file
|
|
$ echo "something else" > base_file
|
|
$ hg commit -qAm "one more node"
|
|
$ findfilessorted .hg/store/data
|
|
$ findfilessorted .hg/store/packs
|
|
.hg/store/packs/39a8e8bed95e2e3bb5391ee6bda40ca3ca572916.histidx
|
|
.hg/store/packs/39a8e8bed95e2e3bb5391ee6bda40ca3ca572916.histpack
|
|
.hg/store/packs/56ada2b7be9789489f60b142cc493ce506db4b97.dataidx
|
|
.hg/store/packs/56ada2b7be9789489f60b142cc493ce506db4b97.datapack
|
|
|
|
$ echo "new commit - 2" > new_file
|
|
$ hg commit -qAm "one more node - 2"
|
|
$ findfilessorted .hg/store/data
|
|
$ findfilessorted .hg/store/packs
|
|
.hg/store/packs/07330c1ad616e8ccf9d924d039769934ebc82db8.dataidx
|
|
.hg/store/packs/07330c1ad616e8ccf9d924d039769934ebc82db8.datapack
|
|
.hg/store/packs/39a8e8bed95e2e3bb5391ee6bda40ca3ca572916.histidx
|
|
.hg/store/packs/39a8e8bed95e2e3bb5391ee6bda40ca3ca572916.histpack
|
|
.hg/store/packs/3cd8d266014a45ac9f32ce6fe60bbba3ef841577.histidx
|
|
.hg/store/packs/3cd8d266014a45ac9f32ce6fe60bbba3ef841577.histpack
|
|
.hg/store/packs/56ada2b7be9789489f60b142cc493ce506db4b97.dataidx
|
|
.hg/store/packs/56ada2b7be9789489f60b142cc493ce506db4b97.datapack
|
|
|
|
# check the commit data
|
|
$ hg cat -r . new_file
|
|
new commit - 2
|
|
$ hg cat -r .~1 new_file
|
|
new commit
|
|
|
|
# Test repack
|
|
$ hg repack --looseonly
|
|
$ findfilessorted .hg/store/packs
|
|
.hg/store/packs/07330c1ad616e8ccf9d924d039769934ebc82db8.dataidx
|
|
.hg/store/packs/07330c1ad616e8ccf9d924d039769934ebc82db8.datapack
|
|
.hg/store/packs/39a8e8bed95e2e3bb5391ee6bda40ca3ca572916.histidx
|
|
.hg/store/packs/39a8e8bed95e2e3bb5391ee6bda40ca3ca572916.histpack
|
|
.hg/store/packs/3cd8d266014a45ac9f32ce6fe60bbba3ef841577.histidx
|
|
.hg/store/packs/3cd8d266014a45ac9f32ce6fe60bbba3ef841577.histpack
|
|
.hg/store/packs/56ada2b7be9789489f60b142cc493ce506db4b97.dataidx
|
|
.hg/store/packs/56ada2b7be9789489f60b142cc493ce506db4b97.datapack
|
|
$ hg repack
|
|
$ findfilessorted .hg/store/packs
|
|
.hg/store/packs/7edafc4e8f1fcf89ce1abe2046a76ffff61d9e18.dataidx
|
|
.hg/store/packs/7edafc4e8f1fcf89ce1abe2046a76ffff61d9e18.datapack
|
|
.hg/store/packs/ba63ac333b14fd0bac5b28ffcf28c465a6d8e93a.histidx
|
|
.hg/store/packs/ba63ac333b14fd0bac5b28ffcf28c465a6d8e93a.histpack
|
|
|
|
# check the commit data again
|
|
$ hg cat -r . new_file
|
|
new commit - 2
|
|
$ hg cat -r .~1 new_file
|
|
new commit
|
|
$ hg up -r .~1
|
|
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
$ hg cat -r . base_file
|
|
something else
|
|
|
|
# Check that files are not fetched from the server for the full history
|
|
# after clearing cache the file will be fetched because it needs a content of it
|
|
$ findfilessorted $CACHEDIR
|
|
$TESTTMP/hgcache/master/packs/729c1f9b99edec87840818cfda1cfb5c026549cd.dataidx
|
|
$TESTTMP/hgcache/master/packs/729c1f9b99edec87840818cfda1cfb5c026549cd.datapack
|
|
$TESTTMP/hgcache/master/packs/8439c9deb49aa426fddba0f12b66e39ed3b229f7.histidx
|
|
$TESTTMP/hgcache/master/packs/8439c9deb49aa426fddba0f12b66e39ed3b229f7.histpack
|
|
$TESTTMP/hgcache/master/packs/repacklock
|
|
$TESTTMP/hgcache/repos
|
|
$ clearcache
|
|
$ echo "new line" >> file
|
|
$ hg commit -vm "expecting to fetch"
|
|
committing files:
|
|
file
|
|
committing manifest
|
|
committing changelog
|
|
committed changeset 4:dc68270aa18f
|
|
calling hook commit.prefetch: hgext.remotefilelog.wcpprefetch
|
|
1 files fetched over 1 fetches - (1 misses, 0.00% hit ratio) over *s (glob)
|
|
|
|
# if the loose file format is used then the file will be fetched because of the
|
|
# historical data the content is known, because previous cahnges were local
|
|
$ clearcache
|
|
$ echo "new line" >> file
|
|
$ hg commit -vm "check still fetches" --config "remotefilelog.packlocaldata=False"
|
|
committing files:
|
|
file
|
|
committing manifest
|
|
committing changelog
|
|
committed changeset 5:74c424ec1e23
|
|
calling hook commit.prefetch: hgext.remotefilelog.wcpprefetch
|
|
1 files fetched over 1 fetches - (1 misses, 0.00% hit ratio) over *s (glob)
|
|
$ findfilessorted $CACHEDIR
|
|
$TESTTMP/hgcache/master/97/1c419dd609331343dee105fffd0f4608dc0bf2/ea096176809b81541cdb77bc9dcf6a43a7ea6bc7
|
|
$TESTTMP/hgcache/repos
|
|
|
|
# don't need fetch anything if the pack files format is used
|
|
$ clearcache
|
|
$ echo "new line" >> file
|
|
$ hg commit -vm "won't download"
|
|
committing files:
|
|
file
|
|
committing manifest
|
|
committing changelog
|
|
committed changeset 6:3462713eae99
|
|
calling hook commit.prefetch: hgext.remotefilelog.wcpprefetch
|
|
$ findfilessorted $CACHEDIR
|