test-narrow-expanddirstate.t
164 lines
| 5.0 KiB
| text/troff
|
Tads3Lexer
/ tests / test-narrow-expanddirstate.t
Augie Fackler
|
r36096 | $ . "$TESTDIR/narrow-library.sh" | ||
$ hg init master | ||||
$ cd master | ||||
$ mkdir inside | ||||
$ echo inside > inside/f1 | ||||
$ mkdir outside | ||||
$ echo outside > outside/f2 | ||||
$ mkdir patchdir | ||||
$ echo patch_this > patchdir/f3 | ||||
$ hg ci -Aqm 'initial' | ||||
$ cd .. | ||||
$ hg clone --narrow ssh://user@dummy/master narrow --include inside | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
new changesets dff6a2a6d433 | ||||
updating to branch default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd narrow | ||||
$ mkdir outside | ||||
$ echo other_contents > outside/f2 | ||||
$ grep outside .hg/narrowspec | ||||
[1] | ||||
$ grep outside .hg/dirstate | ||||
[1] | ||||
$ hg status | ||||
`hg status` did not add outside. | ||||
$ grep outside .hg/narrowspec | ||||
[1] | ||||
$ grep outside .hg/dirstate | ||||
[1] | ||||
Unfortunately this is not really a candidate for adding to narrowhg proper, | ||||
since it depends on some other source for providing the manifests (when using | ||||
treemanifests) and file contents. Something like a virtual filesystem and/or | ||||
remotefilelog. We want to be useful when not using those systems, so we do not | ||||
have this method available in narrowhg proper at the moment. | ||||
$ cat > "$TESTTMP/expand_extension.py" <<EOF | ||||
> import os | ||||
> import sys | ||||
> | ||||
Augie Fackler
|
r36365 | > from mercurial import encoding | ||
Augie Fackler
|
r36096 | > from mercurial import extensions | ||
> from mercurial import localrepo | ||||
> from mercurial import match as matchmod | ||||
Gregory Szorc
|
r36178 | > from mercurial import narrowspec | ||
Augie Fackler
|
r36096 | > from mercurial import patch | ||
> from mercurial import util as hgutil | ||||
> | ||||
> def expandnarrowspec(ui, repo, newincludes=None): | ||||
> if not newincludes: | ||||
> return | ||||
> import sys | ||||
> newincludes = set([newincludes]) | ||||
> includes, excludes = repo.narrowpats | ||||
Gregory Szorc
|
r36178 | > currentmatcher = narrowspec.match(repo.root, includes, excludes) | ||
Augie Fackler
|
r36096 | > includes = includes | newincludes | ||
> if not repo.currenttransaction(): | ||||
Augie Fackler
|
r36365 | > ui.develwarn(b'expandnarrowspec called outside of transaction!') | ||
Augie Fackler
|
r36096 | > repo.setnarrowpats(includes, excludes) | ||
Gregory Szorc
|
r36178 | > newmatcher = narrowspec.match(repo.root, includes, excludes) | ||
Augie Fackler
|
r36096 | > added = matchmod.differencematcher(newmatcher, currentmatcher) | ||
Augie Fackler
|
r36365 | > for f in repo[b'.'].manifest().walk(added): | ||
Augie Fackler
|
r36096 | > repo.dirstate.normallookup(f) | ||
> | ||||
Kyle Lippincott
|
r38142 | > def wrapds(ui, repo, ds): | ||
> class expandingdirstate(ds.__class__): | ||||
> @hgutil.propertycache | ||||
> def _map(self): | ||||
> ret = super(expandingdirstate, self)._map | ||||
> with repo.wlock(), repo.lock(), repo.transaction( | ||||
> b'expandnarrowspec'): | ||||
> expandnarrowspec(ui, repo, | ||||
> encoding.environ.get(b'DIRSTATEINCLUDES')) | ||||
> return ret | ||||
> ds.__class__ = expandingdirstate | ||||
> return ds | ||||
Augie Fackler
|
r36096 | > | ||
> def reposetup(ui, repo): | ||||
Kyle Lippincott
|
r38142 | > class expandingrepo(repo.__class__): | ||
> def _makedirstate(self): | ||||
> dirstate = super(expandingrepo, self)._makedirstate() | ||||
> return wrapds(ui, repo, dirstate) | ||||
> repo.__class__ = expandingrepo | ||||
> | ||||
> def extsetup(unused_ui): | ||||
> def overridepatch(orig, ui, repo, *args, **kwargs): | ||||
Augie Fackler
|
r36096 | > with repo.wlock(): | ||
Augie Fackler
|
r36365 | > expandnarrowspec(ui, repo, encoding.environ.get(b'PATCHINCLUDES')) | ||
Kyle Lippincott
|
r38142 | > return orig(ui, repo, *args, **kwargs) | ||
Augie Fackler
|
r36096 | > | ||
Augie Fackler
|
r36365 | > extensions.wrapfunction(patch, b'patch', overridepatch) | ||
Augie Fackler
|
r36096 | > EOF | ||
$ cat >> ".hg/hgrc" <<EOF | ||||
> [extensions] | ||||
> expand_extension = $TESTTMP/expand_extension.py | ||||
> EOF | ||||
Since we do not have the ability to rely on a virtual filesystem or | ||||
remotefilelog in the test, we just fake it by copying the data from the 'master' | ||||
repo. | ||||
$ cp -a ../master/.hg/store/data/* .hg/store/data | ||||
Do that for patchdir as well. | ||||
$ cp -a ../master/patchdir . | ||||
`hg status` will now add outside, but not patchdir. | ||||
$ DIRSTATEINCLUDES=path:outside hg status | ||||
M outside/f2 | ||||
$ grep outside .hg/narrowspec | ||||
path:outside | ||||
$ grep outside .hg/dirstate > /dev/null | ||||
$ grep patchdir .hg/narrowspec | ||||
[1] | ||||
$ grep patchdir .hg/dirstate | ||||
[1] | ||||
Get rid of the modification to outside/f2. | ||||
$ hg update -C . | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
This patch will not apply cleanly at the moment, so `hg import` will break | ||||
$ cat > "$TESTTMP/foo.patch" <<EOF | ||||
> --- patchdir/f3 | ||||
> +++ patchdir/f3 | ||||
> @@ -1,1 +1,1 @@ | ||||
> -this should be "patch_this", but its not, so patch fails | ||||
> +this text is irrelevant | ||||
> EOF | ||||
$ PATCHINCLUDES=path:patchdir hg import -p0 -e "$TESTTMP/foo.patch" -m ignored | ||||
applying $TESTTMP/foo.patch | ||||
patching file patchdir/f3 | ||||
Hunk #1 FAILED at 0 | ||||
1 out of 1 hunks FAILED -- saving rejects to file patchdir/f3.rej | ||||
abort: patch failed to apply | ||||
[255] | ||||
$ grep patchdir .hg/narrowspec | ||||
[1] | ||||
$ grep patchdir .hg/dirstate > /dev/null | ||||
[1] | ||||
Let's make it apply cleanly and see that it *did* expand properly | ||||
$ cat > "$TESTTMP/foo.patch" <<EOF | ||||
> --- patchdir/f3 | ||||
> +++ patchdir/f3 | ||||
> @@ -1,1 +1,1 @@ | ||||
> -patch_this | ||||
> +patched_this | ||||
> EOF | ||||
$ PATCHINCLUDES=path:patchdir hg import -p0 -e "$TESTTMP/foo.patch" -m message | ||||
applying $TESTTMP/foo.patch | ||||
$ cat patchdir/f3 | ||||
patched_this | ||||
$ grep patchdir .hg/narrowspec | ||||
path:patchdir | ||||
$ grep patchdir .hg/dirstate > /dev/null | ||||