test-treemanifest.t
827 lines
| 25.1 KiB
| text/troff
|
Tads3Lexer
/ tests / test-treemanifest.t
timeless
|
r28168 | #require killdaemons | ||
Pierre-Yves David
|
r26920 | $ cat << EOF >> $HGRCPATH | ||
> [format] | ||||
> usegeneraldelta=yes | ||||
Martin von Zweigbergk
|
r27953 | > [ui] | ||
> ssh=python "$TESTDIR/dummyssh" | ||||
Pierre-Yves David
|
r26920 | > EOF | ||
Martin von Zweigbergk
|
r25091 | |||
Set up repo | ||||
$ hg --config experimental.treemanifest=True init repo | ||||
$ cd repo | ||||
Requirements get set on init | ||||
$ grep treemanifest .hg/requires | ||||
treemanifest | ||||
Without directories, looks like any other repo | ||||
$ echo 0 > a | ||||
$ echo 0 > b | ||||
$ hg ci -Aqm initial | ||||
$ hg debugdata -m 0 | ||||
a\x00362fef284ce2ca02aecc8de6d5e8a1c3af0556fe (esc) | ||||
b\x00362fef284ce2ca02aecc8de6d5e8a1c3af0556fe (esc) | ||||
Submanifest is stored in separate revlog | ||||
$ mkdir dir1 | ||||
$ echo 1 > dir1/a | ||||
$ echo 1 > dir1/b | ||||
$ echo 1 > e | ||||
$ hg ci -Aqm 'add dir1' | ||||
$ hg debugdata -m 1 | ||||
a\x00362fef284ce2ca02aecc8de6d5e8a1c3af0556fe (esc) | ||||
b\x00362fef284ce2ca02aecc8de6d5e8a1c3af0556fe (esc) | ||||
Martin von Zweigbergk
|
r27271 | dir1\x008b3ffd73f901e83304c83d33132c8e774ceac44et (esc) | ||
Martin von Zweigbergk
|
r25091 | e\x00b8e02f6433738021a065f94175c7cd23db5f05be (esc) | ||
Martin von Zweigbergk
|
r25119 | $ hg debugdata --dir dir1 0 | ||
Martin von Zweigbergk
|
r25091 | a\x00b8e02f6433738021a065f94175c7cd23db5f05be (esc) | ||
b\x00b8e02f6433738021a065f94175c7cd23db5f05be (esc) | ||||
Can add nested directories | ||||
$ mkdir dir1/dir1 | ||||
$ echo 2 > dir1/dir1/a | ||||
$ echo 2 > dir1/dir1/b | ||||
$ mkdir dir1/dir2 | ||||
$ echo 2 > dir1/dir2/a | ||||
$ echo 2 > dir1/dir2/b | ||||
$ hg ci -Aqm 'add dir1/dir1' | ||||
$ hg files -r . | ||||
a | ||||
b | ||||
Matt Harbison
|
r25153 | dir1/a (glob) | ||
dir1/b (glob) | ||||
dir1/dir1/a (glob) | ||||
dir1/dir1/b (glob) | ||||
dir1/dir2/a (glob) | ||||
dir1/dir2/b (glob) | ||||
Martin von Zweigbergk
|
r25091 | e | ||
Augie Fackler
|
r29699 | The manifest command works | ||
$ hg manifest | ||||
a | ||||
b | ||||
dir1/a | ||||
dir1/b | ||||
dir1/dir1/a | ||||
dir1/dir1/b | ||||
dir1/dir2/a | ||||
dir1/dir2/b | ||||
e | ||||
Martin von Zweigbergk
|
r25091 | Revision is not created for unchanged directory | ||
$ mkdir dir2 | ||||
$ echo 3 > dir2/a | ||||
$ hg add dir2 | ||||
Matt Harbison
|
r25153 | adding dir2/a (glob) | ||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir1 > before | ||
Martin von Zweigbergk
|
r25091 | $ hg ci -qm 'add dir2' | ||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir1 > after | ||
Martin von Zweigbergk
|
r25091 | $ diff before after | ||
$ rm before after | ||||
Removing directory does not create an revlog entry | ||||
$ hg rm dir1/dir1 | ||||
Matt Harbison
|
r25153 | removing dir1/dir1/a (glob) | ||
removing dir1/dir1/b (glob) | ||||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir1/dir1 > before | ||
Martin von Zweigbergk
|
r25091 | $ hg ci -qm 'remove dir1/dir1' | ||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir1/dir1 > after | ||
Martin von Zweigbergk
|
r25091 | $ diff before after | ||
$ rm before after | ||||
Check that hg files (calls treemanifest.walk()) works | ||||
Martin von Zweigbergk
|
r25222 | without loading all directory revlogs | ||
Martin von Zweigbergk
|
r25091 | |||
$ hg co 'desc("add dir2")' | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Martin von Zweigbergk
|
r25222 | $ mv .hg/store/meta/dir2 .hg/store/meta/dir2-backup | ||
Martin von Zweigbergk
|
r25091 | $ hg files -r . dir1 | ||
Matt Harbison
|
r25153 | dir1/a (glob) | ||
dir1/b (glob) | ||||
dir1/dir1/a (glob) | ||||
dir1/dir1/b (glob) | ||||
dir1/dir2/a (glob) | ||||
dir1/dir2/b (glob) | ||||
Martin von Zweigbergk
|
r25091 | |||
Check that status between revisions works (calls treemanifest.matches()) | ||||
Martin von Zweigbergk
|
r25222 | without loading all directory revlogs | ||
Martin von Zweigbergk
|
r25091 | |||
$ hg status --rev 'desc("add dir1")' --rev . dir1 | ||||
A dir1/dir1/a | ||||
A dir1/dir1/b | ||||
A dir1/dir2/a | ||||
A dir1/dir2/b | ||||
Martin von Zweigbergk
|
r25222 | $ mv .hg/store/meta/dir2-backup .hg/store/meta/dir2 | ||
Martin von Zweigbergk
|
r25091 | |||
Merge creates 2-parent revision of directory revlog | ||||
$ echo 5 > dir1/a | ||||
$ hg ci -Aqm 'modify dir1/a' | ||||
$ hg co '.^' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo 6 > dir1/b | ||||
$ hg ci -Aqm 'modify dir1/b' | ||||
$ hg merge 'desc("modify dir1/a")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m 'conflict-free merge involving dir1/' | ||||
$ cat dir1/a | ||||
5 | ||||
$ cat dir1/b | ||||
6 | ||||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir1 | ||
Pierre-Yves David
|
r26920 | rev offset length delta linkrev nodeid p1 p2 | ||
0 0 54 -1 1 8b3ffd73f901 000000000000 000000000000 | ||||
Martin von Zweigbergk
|
r27271 | 1 54 68 0 2 68e9d057c5a8 8b3ffd73f901 000000000000 | ||
2 122 12 1 4 4698198d2624 68e9d057c5a8 000000000000 | ||||
3 134 55 1 5 44844058ccce 68e9d057c5a8 000000000000 | ||||
4 189 55 1 6 bf3d9b744927 68e9d057c5a8 000000000000 | ||||
5 244 55 4 7 dde7c0af2a03 bf3d9b744927 44844058ccce | ||||
Martin von Zweigbergk
|
r25091 | |||
Merge keeping directory from parent 1 does not create revlog entry. (Note that | ||||
dir1's manifest does change, but only because dir1/a's filelog changes.) | ||||
$ hg co 'desc("add dir2")' | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo 8 > dir2/a | ||||
$ hg ci -m 'modify dir2/a' | ||||
created new head | ||||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir2 > before | ||
Martin von Zweigbergk
|
r25091 | $ hg merge 'desc("modify dir1/a")' | ||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg revert -r 'desc("modify dir2/a")' . | ||||
reverting dir1/a (glob) | ||||
$ hg ci -m 'merge, keeping parent 1' | ||||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir2 > after | ||
Martin von Zweigbergk
|
r25091 | $ diff before after | ||
$ rm before after | ||||
Merge keeping directory from parent 2 does not create revlog entry. (Note that | ||||
dir2's manifest does change, but only because dir2/a's filelog changes.) | ||||
$ hg co 'desc("modify dir2/a")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir1 > before | ||
Martin von Zweigbergk
|
r25091 | $ hg merge 'desc("modify dir1/a")' | ||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg revert -r 'desc("modify dir1/a")' . | ||||
reverting dir2/a (glob) | ||||
$ hg ci -m 'merge, keeping parent 2' | ||||
created new head | ||||
Martin von Zweigbergk
|
r25119 | $ hg debugindex --dir dir1 > after | ||
Martin von Zweigbergk
|
r25091 | $ diff before after | ||
$ rm before after | ||||
Create flat source repo for tests with mixed flat/tree manifests | ||||
$ cd .. | ||||
$ hg init repo-flat | ||||
$ cd repo-flat | ||||
Create a few commits with flat manifest | ||||
$ echo 0 > a | ||||
$ echo 0 > b | ||||
$ echo 0 > e | ||||
$ for d in dir1 dir1/dir1 dir1/dir2 dir2 | ||||
> do | ||||
> mkdir $d | ||||
> echo 0 > $d/a | ||||
> echo 0 > $d/b | ||||
> done | ||||
$ hg ci -Aqm initial | ||||
$ echo 1 > a | ||||
$ echo 1 > dir1/a | ||||
$ echo 1 > dir1/dir1/a | ||||
$ hg ci -Aqm 'modify on branch 1' | ||||
$ hg co 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo 2 > b | ||||
$ echo 2 > dir1/b | ||||
$ echo 2 > dir1/dir1/b | ||||
$ hg ci -Aqm 'modify on branch 2' | ||||
$ hg merge 1 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m 'merge of flat manifests to new flat manifest' | ||||
Martin von Zweigbergk
|
r27953 | $ hg serve -p $HGPORT -d --pid-file=hg.pid --errorlog=errors.log | ||
$ cat hg.pid >> $DAEMON_PIDS | ||||
Martin von Zweigbergk
|
r25091 | Create clone with tree manifests enabled | ||
$ cd .. | ||||
Martin von Zweigbergk
|
r27953 | $ hg clone --config experimental.treemanifest=1 \ | ||
> http://localhost:$HGPORT repo-mixed -r 1 | ||||
Martin von Zweigbergk
|
r25091 | adding changesets | ||
adding manifests | ||||
adding file changes | ||||
Martin von Zweigbergk
|
r27953 | added 2 changesets with 14 changes to 11 files | ||
Martin von Zweigbergk
|
r25091 | updating to branch default | ||
11 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd repo-mixed | ||||
Martin von Zweigbergk
|
r27952 | $ test -d .hg/store/meta | ||
Martin von Zweigbergk
|
r25091 | [1] | ||
$ grep treemanifest .hg/requires | ||||
treemanifest | ||||
Martin von Zweigbergk
|
r27953 | Should be possible to push updates from flat to tree manifest repo | ||
$ hg -R ../repo-flat push ssh://user@dummy/repo-mixed | ||||
pushing to ssh://user@dummy/repo-mixed | ||||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 2 changesets with 3 changes to 3 files | ||||
Martin von Zweigbergk
|
r25091 | Commit should store revlog per directory | ||
$ hg co 1 | ||||
Martin von Zweigbergk
|
r27953 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Martin von Zweigbergk
|
r25091 | $ echo 3 > a | ||
$ echo 3 > dir1/a | ||||
$ echo 3 > dir1/dir1/a | ||||
$ hg ci -m 'first tree' | ||||
created new head | ||||
$ find .hg/store/meta | sort | ||||
.hg/store/meta | ||||
.hg/store/meta/dir1 | ||||
.hg/store/meta/dir1/00manifest.i | ||||
.hg/store/meta/dir1/dir1 | ||||
.hg/store/meta/dir1/dir1/00manifest.i | ||||
.hg/store/meta/dir1/dir2 | ||||
.hg/store/meta/dir1/dir2/00manifest.i | ||||
.hg/store/meta/dir2 | ||||
.hg/store/meta/dir2/00manifest.i | ||||
Merge of two trees | ||||
$ hg co 2 | ||||
6 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 1 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m 'merge of flat manifests to new tree manifest' | ||||
created new head | ||||
$ hg diff -r 3 | ||||
Parent of tree root manifest should be flat manifest, and two for merge | ||||
$ hg debugindex -m | ||||
Pierre-Yves David
|
r26920 | rev offset length delta linkrev nodeid p1 p2 | ||
0 0 80 -1 0 40536115ed9e 000000000000 000000000000 | ||||
Martin von Zweigbergk
|
r25091 | 1 80 83 0 1 f3376063c255 40536115ed9e 000000000000 | ||
Pierre-Yves David
|
r26920 | 2 163 89 0 2 5d9b9da231a2 40536115ed9e 000000000000 | ||
3 252 83 2 3 d17d663cbd8a 5d9b9da231a2 f3376063c255 | ||||
Martin von Zweigbergk
|
r27271 | 4 335 124 1 4 51e32a8c60ee f3376063c255 000000000000 | ||
5 459 126 2 5 cc5baa78b230 5d9b9da231a2 f3376063c255 | ||||
Martin von Zweigbergk
|
r25091 | |||
Status across flat/tree boundary should work | ||||
$ hg status --rev '.^' --rev . | ||||
M a | ||||
M dir1/a | ||||
M dir1/dir1/a | ||||
Turning off treemanifest config has no effect | ||||
Martin von Zweigbergk
|
r27952 | $ hg debugindex --dir dir1 | ||
Pierre-Yves David
|
r26920 | rev offset length delta linkrev nodeid p1 p2 | ||
Martin von Zweigbergk
|
r27271 | 0 0 127 -1 4 064927a0648a 000000000000 000000000000 | ||
1 127 111 0 5 25ecb8cb8618 000000000000 000000000000 | ||||
Martin von Zweigbergk
|
r25091 | $ echo 2 > dir1/a | ||
$ hg --config experimental.treemanifest=False ci -qm 'modify dir1/a' | ||||
Martin von Zweigbergk
|
r27952 | $ hg debugindex --dir dir1 | ||
Pierre-Yves David
|
r26920 | rev offset length delta linkrev nodeid p1 p2 | ||
Martin von Zweigbergk
|
r27271 | 0 0 127 -1 4 064927a0648a 000000000000 000000000000 | ||
1 127 111 0 5 25ecb8cb8618 000000000000 000000000000 | ||||
2 238 55 1 6 5b16163a30c6 25ecb8cb8618 000000000000 | ||||
Drew Gottlieb
|
r25231 | |||
Martin von Zweigbergk
|
r27930 | Stripping and recovering changes should work | ||
$ hg st --change tip | ||||
M dir1/a | ||||
$ hg --config extensions.strip= strip tip | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
saved backup bundle to $TESTTMP/repo-mixed/.hg/strip-backup/51cfd7b1e13b-78a2f3ed-backup.hg (glob) | ||||
Martin von Zweigbergk
|
r29464 | $ hg debugindex --dir dir1 | ||
rev offset length delta linkrev nodeid p1 p2 | ||||
0 0 127 -1 4 064927a0648a 000000000000 000000000000 | ||||
1 127 111 0 5 25ecb8cb8618 000000000000 000000000000 | ||||
Augie Fackler
|
r29715 | $ hg incoming .hg/strip-backup/* | ||
comparing with .hg/strip-backup/*-backup.hg (glob) | ||||
searching for changes | ||||
changeset: 6:51cfd7b1e13b | ||||
tag: tip | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: modify dir1/a | ||||
$ hg pull .hg/strip-backup/* | ||||
pulling from .hg/strip-backup/51cfd7b1e13b-78a2f3ed-backup.hg | ||||
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) | ||||
$ hg --config extensions.strip= strip tip | ||||
saved backup bundle to $TESTTMP/repo-mixed/.hg/strip-backup/*-backup.hg (glob) | ||||
Martin von Zweigbergk
|
r27930 | $ hg unbundle -q .hg/strip-backup/* | ||
Martin von Zweigbergk
|
r29464 | $ hg debugindex --dir dir1 | ||
rev offset length delta linkrev nodeid p1 p2 | ||||
0 0 127 -1 4 064927a0648a 000000000000 000000000000 | ||||
1 127 111 0 5 25ecb8cb8618 000000000000 000000000000 | ||||
2 238 55 1 6 5b16163a30c6 25ecb8cb8618 000000000000 | ||||
Martin von Zweigbergk
|
r27930 | $ hg st --change tip | ||
M dir1/a | ||||
Martin von Zweigbergk
|
r27931 | Shelving and unshelving should work | ||
$ echo foo >> dir1/a | ||||
$ hg --config extensions.shelve= shelve | ||||
shelved as default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg --config extensions.shelve= unshelve | ||||
unshelving change 'default' | ||||
$ hg diff --nodates | ||||
diff -r 708a273da119 dir1/a | ||||
--- a/dir1/a | ||||
+++ b/dir1/a | ||||
@@ -1,1 +1,2 @@ | ||||
1 | ||||
+foo | ||||
Martin von Zweigbergk
|
r27938 | Pushing from treemanifest repo to an empty repo makes that a treemanifest repo | ||
$ cd .. | ||||
$ hg init empty-repo | ||||
$ cat << EOF >> empty-repo/.hg/hgrc | ||||
> [experimental] | ||||
> changegroup3=yes | ||||
> EOF | ||||
$ grep treemanifest empty-repo/.hg/requires | ||||
[1] | ||||
$ hg push -R repo -r 0 empty-repo | ||||
pushing to empty-repo | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 2 changes to 2 files | ||||
$ grep treemanifest empty-repo/.hg/requires | ||||
treemanifest | ||||
Augie Fackler
|
r27946 | Pushing to an empty repo works | ||
$ hg --config experimental.treemanifest=1 init clone | ||||
$ grep treemanifest clone/.hg/requires | ||||
treemanifest | ||||
$ hg push -R repo clone | ||||
pushing to clone | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 11 changesets with 15 changes to 10 files (+3 heads) | ||||
$ grep treemanifest clone/.hg/requires | ||||
treemanifest | ||||
Martin von Zweigbergk
|
r28240 | $ hg -R clone verify | ||
checking changesets | ||||
checking manifests | ||||
checking directory manifests | ||||
crosschecking files in changesets and manifests | ||||
checking files | ||||
10 files, 11 changesets, 15 total revisions | ||||
Augie Fackler
|
r27946 | |||
Drew Gottlieb
|
r25231 | Create deeper repo with tree manifests. | ||
$ hg --config experimental.treemanifest=True init deeprepo | ||||
$ cd deeprepo | ||||
Martin von Zweigbergk
|
r28007 | $ mkdir .A | ||
Drew Gottlieb
|
r25231 | $ mkdir b | ||
$ mkdir b/bar | ||||
$ mkdir b/bar/orange | ||||
$ mkdir b/bar/orange/fly | ||||
$ mkdir b/foo | ||||
$ mkdir b/foo/apple | ||||
$ mkdir b/foo/apple/bees | ||||
Martin von Zweigbergk
|
r28007 | $ touch .A/one.txt | ||
$ touch .A/two.txt | ||||
Drew Gottlieb
|
r25231 | $ touch b/bar/fruits.txt | ||
$ touch b/bar/orange/fly/gnat.py | ||||
$ touch b/bar/orange/fly/housefly.txt | ||||
$ touch b/foo/apple/bees/flower.py | ||||
$ touch c.txt | ||||
$ touch d.py | ||||
$ hg ci -Aqm 'initial' | ||||
We'll see that visitdir works by removing some treemanifest revlogs and running | ||||
the files command with various parameters. | ||||
Test files from the root. | ||||
$ hg files -r . | ||||
Martin von Zweigbergk
|
r28007 | .A/one.txt (glob) | ||
.A/two.txt (glob) | ||||
Matt Harbison
|
r25299 | b/bar/fruits.txt (glob) | ||
b/bar/orange/fly/gnat.py (glob) | ||||
b/bar/orange/fly/housefly.txt (glob) | ||||
b/foo/apple/bees/flower.py (glob) | ||||
Drew Gottlieb
|
r25231 | c.txt | ||
d.py | ||||
Martin von Zweigbergk
|
r25362 | Excludes with a glob should not exclude everything from the glob's root | ||
$ hg files -r . -X 'b/fo?' b | ||||
Matt Harbison
|
r25398 | b/bar/fruits.txt (glob) | ||
b/bar/orange/fly/gnat.py (glob) | ||||
b/bar/orange/fly/housefly.txt (glob) | ||||
Jun Wu
|
r30556 | $ cp -R .hg/store .hg/store-copy | ||
Martin von Zweigbergk
|
r25362 | |||
Drew Gottlieb
|
r25231 | Test files for a subdirectory. | ||
Martin von Zweigbergk
|
r28007 | $ rm -r .hg/store/meta/~2e_a | ||
Drew Gottlieb
|
r25231 | $ hg files -r . b | ||
Matt Harbison
|
r25299 | b/bar/fruits.txt (glob) | ||
b/bar/orange/fly/gnat.py (glob) | ||||
b/bar/orange/fly/housefly.txt (glob) | ||||
b/foo/apple/bees/flower.py (glob) | ||||
Jun Wu
|
r30556 | $ cp -R .hg/store-copy/. .hg/store | ||
Drew Gottlieb
|
r25231 | |||
Test files with just includes and excludes. | ||||
Martin von Zweigbergk
|
r28007 | $ rm -r .hg/store/meta/~2e_a | ||
Martin von Zweigbergk
|
r28005 | $ rm -r .hg/store/meta/b/bar/orange/fly | ||
$ rm -r .hg/store/meta/b/foo/apple/bees | ||||
Martin von Zweigbergk
|
r25362 | $ hg files -r . -I path:b/bar -X path:b/bar/orange/fly -I path:b/foo -X path:b/foo/apple/bees | ||
Matt Harbison
|
r25299 | b/bar/fruits.txt (glob) | ||
Jun Wu
|
r30556 | $ cp -R .hg/store-copy/. .hg/store | ||
Drew Gottlieb
|
r25231 | |||
Test files for a subdirectory, excluding a directory within it. | ||||
Martin von Zweigbergk
|
r28007 | $ rm -r .hg/store/meta/~2e_a | ||
Martin von Zweigbergk
|
r28005 | $ rm -r .hg/store/meta/b/foo | ||
Martin von Zweigbergk
|
r25362 | $ hg files -r . -X path:b/foo b | ||
Matt Harbison
|
r25299 | b/bar/fruits.txt (glob) | ||
b/bar/orange/fly/gnat.py (glob) | ||||
b/bar/orange/fly/housefly.txt (glob) | ||||
Jun Wu
|
r30556 | $ cp -R .hg/store-copy/. .hg/store | ||
Drew Gottlieb
|
r25231 | |||
Test files for a sub directory, including only a directory within it, and | ||||
including an unrelated directory. | ||||
Martin von Zweigbergk
|
r28007 | $ rm -r .hg/store/meta/~2e_a | ||
Martin von Zweigbergk
|
r28005 | $ rm -r .hg/store/meta/b/foo | ||
Martin von Zweigbergk
|
r25362 | $ hg files -r . -I path:b/bar/orange -I path:a b | ||
Matt Harbison
|
r25299 | b/bar/orange/fly/gnat.py (glob) | ||
b/bar/orange/fly/housefly.txt (glob) | ||||
Jun Wu
|
r30556 | $ cp -R .hg/store-copy/. .hg/store | ||
Drew Gottlieb
|
r25231 | |||
Test files for a pattern, including a directory, and excluding a directory | ||||
within that. | ||||
Martin von Zweigbergk
|
r28007 | $ rm -r .hg/store/meta/~2e_a | ||
Martin von Zweigbergk
|
r28005 | $ rm -r .hg/store/meta/b/foo | ||
$ rm -r .hg/store/meta/b/bar/orange | ||||
Martin von Zweigbergk
|
r25362 | $ hg files -r . glob:**.txt -I path:b/bar -X path:b/bar/orange | ||
Matt Harbison
|
r25299 | b/bar/fruits.txt (glob) | ||
Jun Wu
|
r30556 | $ cp -R .hg/store-copy/. .hg/store | ||
Drew Gottlieb
|
r25231 | |||
Augie Fackler
|
r27432 | Add some more changes to the deep repo | ||
$ echo narf >> b/bar/fruits.txt | ||||
$ hg ci -m narf | ||||
$ echo troz >> b/bar/orange/fly/gnat.py | ||||
$ hg ci -m troz | ||||
Martin von Zweigbergk
|
r28031 | Verify works | ||
$ hg verify | ||||
checking changesets | ||||
checking manifests | ||||
Martin von Zweigbergk
|
r28203 | checking directory manifests | ||
Martin von Zweigbergk
|
r28031 | crosschecking files in changesets and manifests | ||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
Dirlogs are included in fncache | ||||
$ grep meta/.A/00manifest.i .hg/store/fncache | ||||
meta/.A/00manifest.i | ||||
Rebuilt fncache includes dirlogs | ||||
$ rm .hg/store/fncache | ||||
$ hg debugrebuildfncache | ||||
adding data/.A/one.txt.i | ||||
adding data/.A/two.txt.i | ||||
adding data/b/bar/fruits.txt.i | ||||
adding data/b/bar/orange/fly/gnat.py.i | ||||
adding data/b/bar/orange/fly/housefly.txt.i | ||||
adding data/b/foo/apple/bees/flower.py.i | ||||
adding data/c.txt.i | ||||
adding data/d.py.i | ||||
adding meta/.A/00manifest.i | ||||
adding meta/b/00manifest.i | ||||
adding meta/b/bar/00manifest.i | ||||
adding meta/b/bar/orange/00manifest.i | ||||
adding meta/b/bar/orange/fly/00manifest.i | ||||
adding meta/b/foo/00manifest.i | ||||
adding meta/b/foo/apple/00manifest.i | ||||
adding meta/b/foo/apple/bees/00manifest.i | ||||
16 items added, 0 removed from fncache | ||||
timeless
|
r28168 | Finish first server | ||
$ killdaemons.py | ||||
Martin von Zweigbergk
|
r28203 | Back up the recently added revlogs | ||
Jun Wu
|
r30556 | $ cp -R .hg/store .hg/store-newcopy | ||
Martin von Zweigbergk
|
r28203 | |||
Verify reports missing dirlog | ||||
$ rm .hg/store/meta/b/00manifest.* | ||||
$ hg verify | ||||
checking changesets | ||||
checking manifests | ||||
checking directory manifests | ||||
0: empty or missing b/ | ||||
b/@0: parent-directory manifest refers to unknown revision 67688a370455 | ||||
b/@1: parent-directory manifest refers to unknown revision f38e85d334c5 | ||||
b/@2: parent-directory manifest refers to unknown revision 99c9792fd4b0 | ||||
Martin von Zweigbergk
|
r28204 | warning: orphan revlog 'meta/b/bar/00manifest.i' | ||
warning: orphan revlog 'meta/b/bar/orange/00manifest.i' | ||||
warning: orphan revlog 'meta/b/bar/orange/fly/00manifest.i' | ||||
warning: orphan revlog 'meta/b/foo/00manifest.i' | ||||
warning: orphan revlog 'meta/b/foo/apple/00manifest.i' | ||||
warning: orphan revlog 'meta/b/foo/apple/bees/00manifest.i' | ||||
Martin von Zweigbergk
|
r28203 | crosschecking files in changesets and manifests | ||
b/bar/fruits.txt@0: in changeset but not in manifest | ||||
b/bar/orange/fly/gnat.py@0: in changeset but not in manifest | ||||
b/bar/orange/fly/housefly.txt@0: in changeset but not in manifest | ||||
b/foo/apple/bees/flower.py@0: in changeset but not in manifest | ||||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
Martin von Zweigbergk
|
r28204 | 6 warnings encountered! | ||
Martin von Zweigbergk
|
r28203 | 8 integrity errors encountered! | ||
(first damaged changeset appears to be 0) | ||||
[1] | ||||
Jun Wu
|
r30556 | $ cp -R .hg/store-newcopy/. .hg/store | ||
Martin von Zweigbergk
|
r28203 | |||
Verify reports missing dirlog entry | ||||
$ mv -f .hg/store-copy/meta/b/00manifest.* .hg/store/meta/b/ | ||||
$ hg verify | ||||
checking changesets | ||||
checking manifests | ||||
checking directory manifests | ||||
b/@1: parent-directory manifest refers to unknown revision f38e85d334c5 | ||||
b/@2: parent-directory manifest refers to unknown revision 99c9792fd4b0 | ||||
b/bar/@?: rev 1 points to unexpected changeset 1 | ||||
b/bar/@?: 5e03c4ee5e4a not in parent-directory manifest | ||||
b/bar/@?: rev 2 points to unexpected changeset 2 | ||||
b/bar/@?: 1b16940d66d6 not in parent-directory manifest | ||||
b/bar/orange/@?: rev 1 points to unexpected changeset 2 | ||||
(expected None) | ||||
b/bar/orange/fly/@?: rev 1 points to unexpected changeset 2 | ||||
(expected None) | ||||
crosschecking files in changesets and manifests | ||||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
2 warnings encountered! | ||||
8 integrity errors encountered! | ||||
(first damaged changeset appears to be 1) | ||||
[1] | ||||
Jun Wu
|
r30556 | $ cp -R .hg/store-newcopy/. .hg/store | ||
Martin von Zweigbergk
|
r28203 | |||
Augie Fackler
|
r27432 | Test cloning a treemanifest repo over http. | ||
timeless
|
r28168 | $ hg serve -p $HGPORT -d --pid-file=hg.pid --errorlog=errors.log | ||
Augie Fackler
|
r27432 | $ cat hg.pid >> $DAEMON_PIDS | ||
$ cd .. | ||||
We can clone even with the knob turned off and we'll get a treemanifest repo. | ||||
$ hg clone --config experimental.treemanifest=False \ | ||||
Martin von Zweigbergk
|
r27752 | > --config experimental.changegroup3=True \ | ||
timeless
|
r28168 | > http://localhost:$HGPORT deepclone | ||
Augie Fackler
|
r27432 | requesting all changes | ||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 3 changesets with 10 changes to 8 files | ||||
updating to branch default | ||||
8 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
No server errors. | ||||
$ cat deeprepo/errors.log | ||||
requires got updated to include treemanifest | ||||
$ cat deepclone/.hg/requires | grep treemanifest | ||||
treemanifest | ||||
Tree manifest revlogs exist. | ||||
$ find deepclone/.hg/store/meta | sort | ||||
deepclone/.hg/store/meta | ||||
deepclone/.hg/store/meta/b | ||||
deepclone/.hg/store/meta/b/00manifest.i | ||||
deepclone/.hg/store/meta/b/bar | ||||
deepclone/.hg/store/meta/b/bar/00manifest.i | ||||
deepclone/.hg/store/meta/b/bar/orange | ||||
deepclone/.hg/store/meta/b/bar/orange/00manifest.i | ||||
deepclone/.hg/store/meta/b/bar/orange/fly | ||||
deepclone/.hg/store/meta/b/bar/orange/fly/00manifest.i | ||||
deepclone/.hg/store/meta/b/foo | ||||
deepclone/.hg/store/meta/b/foo/00manifest.i | ||||
deepclone/.hg/store/meta/b/foo/apple | ||||
deepclone/.hg/store/meta/b/foo/apple/00manifest.i | ||||
deepclone/.hg/store/meta/b/foo/apple/bees | ||||
deepclone/.hg/store/meta/b/foo/apple/bees/00manifest.i | ||||
Martin von Zweigbergk
|
r28007 | deepclone/.hg/store/meta/~2e_a | ||
deepclone/.hg/store/meta/~2e_a/00manifest.i | ||||
Augie Fackler
|
r27432 | Verify passes. | ||
$ cd deepclone | ||||
$ hg verify | ||||
checking changesets | ||||
checking manifests | ||||
Martin von Zweigbergk
|
r28203 | checking directory manifests | ||
Augie Fackler
|
r27432 | crosschecking files in changesets and manifests | ||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
$ cd .. | ||||
Martin von Zweigbergk
|
r28006 | |||
Create clones using old repo formats to use in later tests | ||||
$ hg clone --config format.usestore=False \ | ||||
> --config experimental.changegroup3=True \ | ||||
timeless
|
r28168 | > http://localhost:$HGPORT deeprepo-basicstore | ||
Martin von Zweigbergk
|
r28006 | requesting all changes | ||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 3 changesets with 10 changes to 8 files | ||||
updating to branch default | ||||
8 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Martin von Zweigbergk
|
r28007 | $ cd deeprepo-basicstore | ||
$ grep store .hg/requires | ||||
Martin von Zweigbergk
|
r28006 | [1] | ||
timeless
|
r28168 | $ hg serve -p $HGPORT1 -d --pid-file=hg.pid --errorlog=errors.log | ||
Martin von Zweigbergk
|
r28007 | $ cat hg.pid >> $DAEMON_PIDS | ||
$ cd .. | ||||
Martin von Zweigbergk
|
r28006 | $ hg clone --config format.usefncache=False \ | ||
> --config experimental.changegroup3=True \ | ||||
timeless
|
r28168 | > http://localhost:$HGPORT deeprepo-encodedstore | ||
Martin von Zweigbergk
|
r28006 | requesting all changes | ||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 3 changesets with 10 changes to 8 files | ||||
updating to branch default | ||||
8 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Martin von Zweigbergk
|
r28007 | $ cd deeprepo-encodedstore | ||
$ grep fncache .hg/requires | ||||
Martin von Zweigbergk
|
r28006 | [1] | ||
timeless
|
r28168 | $ hg serve -p $HGPORT2 -d --pid-file=hg.pid --errorlog=errors.log | ||
Martin von Zweigbergk
|
r28007 | $ cat hg.pid >> $DAEMON_PIDS | ||
$ cd .. | ||||
Martin von Zweigbergk
|
r28006 | |||
Local clone with basicstore | ||||
$ hg clone -U deeprepo-basicstore local-clone-basicstore | ||||
$ hg -R local-clone-basicstore verify | ||||
checking changesets | ||||
checking manifests | ||||
Martin von Zweigbergk
|
r28203 | checking directory manifests | ||
Martin von Zweigbergk
|
r28006 | crosschecking files in changesets and manifests | ||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
Local clone with encodedstore | ||||
$ hg clone -U deeprepo-encodedstore local-clone-encodedstore | ||||
$ hg -R local-clone-encodedstore verify | ||||
checking changesets | ||||
checking manifests | ||||
Martin von Zweigbergk
|
r28203 | checking directory manifests | ||
Martin von Zweigbergk
|
r28006 | crosschecking files in changesets and manifests | ||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
Local clone with fncachestore | ||||
$ hg clone -U deeprepo local-clone-fncachestore | ||||
$ hg -R local-clone-fncachestore verify | ||||
checking changesets | ||||
checking manifests | ||||
Martin von Zweigbergk
|
r28203 | checking directory manifests | ||
Martin von Zweigbergk
|
r28006 | crosschecking files in changesets and manifests | ||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
Martin von Zweigbergk
|
r28007 | |||
Stream clone with basicstore | ||||
$ hg clone --config experimental.changegroup3=True --uncompressed -U \ | ||||
timeless
|
r28168 | > http://localhost:$HGPORT1 stream-clone-basicstore | ||
Martin von Zweigbergk
|
r28007 | streaming all changes | ||
18 files to transfer, * of data (glob) | ||||
transferred * in * seconds (*) (glob) | ||||
searching for changes | ||||
no changes found | ||||
$ hg -R stream-clone-basicstore verify | ||||
checking changesets | ||||
checking manifests | ||||
Martin von Zweigbergk
|
r28203 | checking directory manifests | ||
Martin von Zweigbergk
|
r28007 | crosschecking files in changesets and manifests | ||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
Stream clone with encodedstore | ||||
$ hg clone --config experimental.changegroup3=True --uncompressed -U \ | ||||
timeless
|
r28168 | > http://localhost:$HGPORT2 stream-clone-encodedstore | ||
Martin von Zweigbergk
|
r28007 | streaming all changes | ||
18 files to transfer, * of data (glob) | ||||
transferred * in * seconds (*) (glob) | ||||
searching for changes | ||||
no changes found | ||||
$ hg -R stream-clone-encodedstore verify | ||||
checking changesets | ||||
checking manifests | ||||
Martin von Zweigbergk
|
r28203 | checking directory manifests | ||
Martin von Zweigbergk
|
r28007 | crosschecking files in changesets and manifests | ||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
Stream clone with fncachestore | ||||
$ hg clone --config experimental.changegroup3=True --uncompressed -U \ | ||||
timeless
|
r28168 | > http://localhost:$HGPORT stream-clone-fncachestore | ||
Martin von Zweigbergk
|
r28007 | streaming all changes | ||
18 files to transfer, * of data (glob) | ||||
transferred * in * seconds (*) (glob) | ||||
searching for changes | ||||
no changes found | ||||
$ hg -R stream-clone-fncachestore verify | ||||
checking changesets | ||||
checking manifests | ||||
Martin von Zweigbergk
|
r28203 | checking directory manifests | ||
Martin von Zweigbergk
|
r28007 | crosschecking files in changesets and manifests | ||
checking files | ||||
8 files, 3 changesets, 10 total revisions | ||||
Packed bundle | ||||
$ hg -R deeprepo debugcreatestreamclonebundle repo-packed.hg | ||||
writing 3349 bytes for 18 files | ||||
bundle requirements: generaldelta, revlogv1, treemanifest | ||||
$ hg debugbundle --spec repo-packed.hg | ||||
none-packed1;requirements%3Dgeneraldelta%2Crevlogv1%2Ctreemanifest | ||||
Martin von Zweigbergk
|
r28669 | |||
Bundle with changegroup2 is not supported | ||||
$ hg -R deeprepo bundle --all -t v2 deeprepo.bundle | ||||
abort: repository does not support bundle version 02 | ||||
[255] | ||||
Martin von Zweigbergk
|
r29371 | |||
Pull does not include changegroup for manifest the client already has from | ||||
other branch | ||||
$ mkdir grafted-dir-repo | ||||
$ cd grafted-dir-repo | ||||
$ hg --config experimental.treemanifest=1 init | ||||
$ mkdir dir | ||||
$ echo a > dir/file | ||||
$ echo a > file | ||||
$ hg ci -Am initial | ||||
adding dir/file | ||||
adding file | ||||
$ echo b > dir/file | ||||
$ hg ci -m updated | ||||
$ hg co '.^' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg revert -r tip dir/ | ||||
reverting dir/file (glob) | ||||
$ echo b > file # to make sure root manifest is sent | ||||
$ hg ci -m grafted | ||||
created new head | ||||
$ cd .. | ||||
$ hg --config experimental.treemanifest=1 clone --pull -r 1 \ | ||||
> grafted-dir-repo grafted-dir-repo-clone | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 2 changesets with 3 changes to 2 files | ||||
updating to branch default | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd grafted-dir-repo-clone | ||||
$ hg pull -r 2 | ||||
pulling from $TESTTMP/grafted-dir-repo (glob) | ||||
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) | ||||