test-subrepo-relative-path.t
190 lines
| 5.8 KiB
| text/troff
|
Tads3Lexer
/ tests / test-subrepo-relative-path.t
Matt Mackall
|
r22046 | #require killdaemons | ||
Mads Kiilerich
|
r15446 | |||
Martin Geisler
|
r11915 | Preparing the subrepository 'sub' | ||
$ hg init sub | ||||
$ echo sub > sub/sub | ||||
$ hg add -R sub | ||||
Matt Harbison
|
r35394 | adding sub/sub | ||
Martin Geisler
|
r11915 | $ hg commit -R sub -m "sub import" | ||
Preparing the 'main' repo which depends on the subrepo 'sub' | ||||
$ hg init main | ||||
$ echo main > main/main | ||||
$ echo "sub = ../sub" > main/.hgsub | ||||
$ hg clone sub main/sub | ||||
updating to branch default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg add -R main | ||||
Matt Harbison
|
r35394 | adding main/.hgsub | ||
adding main/main | ||||
Martin Geisler
|
r11915 | $ hg commit -R main -m "main import" | ||
Cleaning both repositories, just as a clone -U | ||||
$ hg up -C -R sub null | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ hg up -C -R main null | ||||
0 files updated, 0 files merged, 3 files removed, 0 files unresolved | ||||
$ rm -rf main/sub | ||||
Mads Kiilerich
|
r17015 | hide outer repo | ||
$ hg init | ||||
Martin Geisler
|
r11915 | Serving them both using hgweb | ||
$ printf '[paths]\n/main = main\nsub = sub\n' > webdir.conf | ||||
$ hg serve --webdir-conf webdir.conf -a localhost -p $HGPORT \ | ||||
> -A /dev/null -E /dev/null --pid-file hg.pid -d | ||||
$ cat hg.pid >> $DAEMON_PIDS | ||||
Clone main from hgweb | ||||
$ hg clone "http://localhost:$HGPORT/main" cloned | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 3 changes to 3 files | ||||
Denis Laxalde
|
r34662 | new changesets fdfeeb3e979e | ||
Martin Geisler
|
r11915 | updating to branch default | ||
Martin Geisler
|
r14281 | cloning subrepo sub from http://localhost:$HGPORT/sub | ||
Martin Geisler
|
r11915 | requesting all changes | ||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
Denis Laxalde
|
r34662 | new changesets 863c1745b441 | ||
Martin Geisler
|
r11915 | 3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Checking cloned repo ids | ||||
$ hg id -R cloned | ||||
fdfeeb3e979e tip | ||||
$ hg id -R cloned/sub | ||||
863c1745b441 tip | ||||
subrepo debug for 'main' clone | ||||
$ hg debugsub -R cloned | ||||
path sub | ||||
source ../sub | ||||
revision 863c1745b441bd97a8c4a096e87793073f4fb215 | ||||
Matt Harbison
|
r36704 | Test sharing with a remote URL reference | ||
$ hg init absolute_subrepo | ||||
$ cd absolute_subrepo | ||||
$ echo foo > foo.txt | ||||
$ hg ci -Am 'initial commit' | ||||
adding foo.txt | ||||
$ echo "sub = http://localhost:$HGPORT/sub" > .hgsub | ||||
$ hg ci -Am 'add absolute subrepo' | ||||
adding .hgsub | ||||
$ cd .. | ||||
Matt Harbison
|
r36706 | Clone pooling works for local clones with a remote subrepo reference. The | ||
subrepo is cloned to the pool and shared from there, so that all clones will | ||||
share the same subrepo. | ||||
Matt Harbison
|
r36704 | |||
$ hg --config extensions.share= --config share.pool=$TESTTMP/pool \ | ||||
> clone absolute_subrepo cloned_from_abs | ||||
(sharing from new pooled repository 8d6a2f1e993b34b6557de0042cfe825ae12a8dae) | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 2 changesets with 3 changes to 3 files | ||||
Matt Harbison
|
r36707 | new changesets 8d6a2f1e993b:* (glob) | ||
Matt Harbison
|
r36704 | searching for changes | ||
no changes found | ||||
updating working directory | ||||
Matt Harbison
|
r36705 | cloning subrepo sub from http://localhost:$HGPORT/sub | ||
Matt Harbison
|
r36706 | (sharing from new pooled repository 863c1745b441bd97a8c4a096e87793073f4fb215) | ||
Matt Harbison
|
r36705 | requesting all changes | ||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
new changesets 863c1745b441 | ||||
Matt Harbison
|
r36706 | searching for changes | ||
no changes found | ||||
Matt Harbison
|
r36705 | 3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Vanilla sharing with a subrepo remote path reference will clone the subrepo. | ||||
Each share of these top level repos will end up with independent subrepo copies | ||||
(potentially leaving the shared parent with dangling cset references). | ||||
Matt Harbison
|
r36704 | |||
$ hg --config extensions.share= share absolute_subrepo shared_from_abs | ||||
updating working directory | ||||
Matt Harbison
|
r36705 | cloning subrepo sub from http://localhost:$HGPORT/sub | ||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
new changesets 863c1745b441 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Matt Harbison
|
r36704 | |||
$ hg --config extensions.share= share -U absolute_subrepo shared_from_abs2 | ||||
$ hg -R shared_from_abs2 update -r tip | ||||
Matt Harbison
|
r36705 | cloning subrepo sub from http://localhost:$HGPORT/sub | ||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
new changesets 863c1745b441 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Matt Harbison
|
r36704 | |||
Matt Harbison
|
r36705 | A parent repo without its subrepo available locally can be shared if the | ||
Matt Harbison
|
r36704 | subrepo is referenced by absolute path. | ||
$ hg clone -U absolute_subrepo cloned_null_from_abs | ||||
$ hg --config extensions.share= share cloned_null_from_abs shared_from_null_abs | ||||
updating working directory | ||||
Matt Harbison
|
r36705 | cloning subrepo sub from http://localhost:$HGPORT/sub | ||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
new changesets 863c1745b441 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Matt Harbison
|
r36704 | |||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Mads Kiilerich
|
r14187 | |||
subrepo paths with ssh urls | ||||
Matt Harbison
|
r33335 | $ hg clone -e "\"$PYTHON\" \"$TESTDIR/dummyssh\"" ssh://user@dummy/cloned sshclone | ||
Mads Kiilerich
|
r14187 | requesting all changes | ||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 3 changes to 3 files | ||||
Denis Laxalde
|
r34662 | new changesets fdfeeb3e979e | ||
Mads Kiilerich
|
r14187 | updating to branch default | ||
Martin Geisler
|
r14281 | cloning subrepo sub from ssh://user@dummy/sub | ||
Mads Kiilerich
|
r14187 | requesting all changes | ||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
Denis Laxalde
|
r34662 | new changesets 863c1745b441 | ||
Mads Kiilerich
|
r14187 | 3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Matt Harbison
|
r33335 | $ hg -R sshclone push -e "\"$PYTHON\" \"$TESTDIR/dummyssh\"" ssh://user@dummy/`pwd`/cloned | ||
Mads Kiilerich
|
r14187 | pushing to ssh://user@dummy/$TESTTMP/cloned | ||
pushing subrepo sub to ssh://user@dummy/$TESTTMP/sub | ||||
searching for changes | ||||
no changes found | ||||
searching for changes | ||||
no changes found | ||||
Matt Mackall
|
r16023 | [1] | ||
Mads Kiilerich
|
r14187 | |||
$ cat dummylog | ||||
Mads Kiilerich
|
r15622 | Got arguments 1:user@dummy 2:hg -R cloned serve --stdio | ||
Got arguments 1:user@dummy 2:hg -R sub serve --stdio | ||||
Got arguments 1:user@dummy 2:hg -R $TESTTMP/cloned serve --stdio | ||||
Got arguments 1:user@dummy 2:hg -R $TESTTMP/sub serve --stdio | ||||