test-hook.t
1431 lines
| 39.1 KiB
| text/troff
|
Tads3Lexer
/ tests / test-hook.t
Matt Mackall
|
r12328 | commit hooks can see env vars | ||
Pierre-Yves David
|
r24821 | (and post-transaction one are run unlocked) | ||
Nicolas Dumazet
|
r11793 | |||
Pierre-Yves David
|
r25370 | |||
FUJIWARA Katsunori
|
r25218 | $ cat > $TESTTMP/txnabort.checkargs.py <<EOF | ||
Augie Fackler
|
r37772 | > from mercurial import pycompat | ||
FUJIWARA Katsunori
|
r25218 | > def showargs(ui, repo, hooktype, **kwargs): | ||
Augie Fackler
|
r37772 | > kwargs = pycompat.byteskwargs(kwargs) | ||
> ui.write(b'%s Python hook: %s\n' % (hooktype, | ||||
> b','.join(sorted(kwargs)))) | ||||
FUJIWARA Katsunori
|
r25218 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg init a | ||
$ cd a | ||||
Adrian Buehlmann
|
r16964 | $ cat > .hg/hgrc <<EOF | ||
> [hooks] | ||||
Boris Feld
|
r41788 | > commit = sh -c "HG_LOCAL= HG_TAG= printenv.py --line commit" | ||
> commit.b = sh -c "HG_LOCAL= HG_TAG= printenv.py --line commit.b" | ||||
> precommit = sh -c "HG_LOCAL= HG_NODE= HG_TAG= printenv.py --line precommit" | ||||
> pretxncommit = sh -c "HG_LOCAL= HG_TAG= printenv.py --line pretxncommit" | ||||
Adrian Buehlmann
|
r16964 | > pretxncommit.tip = hg -q tip | ||
Boris Feld
|
r41788 | > pre-identify = sh -c "printenv.py --line pre-identify 1" | ||
> pre-cat = sh -c "printenv.py --line pre-cat" | ||||
> post-cat = sh -c "printenv.py --line post-cat" | ||||
> pretxnopen = sh -c "HG_LOCAL= HG_TAG= printenv.py --line pretxnopen" | ||||
> pretxnclose = sh -c "HG_LOCAL= HG_TAG= printenv.py --line pretxnclose" | ||||
> txnclose = sh -c "HG_LOCAL= HG_TAG= printenv.py --line txnclose" | ||||
FUJIWARA Katsunori
|
r25218 | > txnabort.0 = python:$TESTTMP/txnabort.checkargs.py:showargs | ||
Boris Feld
|
r41788 | > txnabort.1 = sh -c "HG_LOCAL= HG_TAG= printenv.py --line txnabort" | ||
Matt Harbison
|
r24827 | > txnclose.checklock = sh -c "hg debuglock > /dev/null" | ||
Adrian Buehlmann
|
r16964 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ echo a > a | ||
$ hg add a | ||||
Martin Geisler
|
r12156 | $ hg commit -m a | ||
Boris Feld
|
r41788 | precommit hook: HG_HOOKNAME=precommit | ||
HG_HOOKTYPE=precommit | ||||
HG_PARENT1=0000000000000000000000000000000000000000 | ||||
pretxnopen hook: HG_HOOKNAME=pretxnopen | ||||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
pretxncommit hook: HG_HOOKNAME=pretxncommit | ||||
HG_HOOKTYPE=pretxncommit | ||||
HG_NODE=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
HG_PARENT1=0000000000000000000000000000000000000000 | ||||
HG_PENDING=$TESTTMP/a | ||||
Martin Geisler
|
r12156 | 0:cb9a9f314b8b | ||
Boris Feld
|
r41788 | pretxnclose hook: HG_HOOKNAME=pretxnclose | ||
HG_HOOKTYPE=pretxnclose | ||||
HG_PENDING=$TESTTMP/a | ||||
HG_PHASES_MOVED=1 | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
txnclose hook: HG_HOOKNAME=txnclose | ||||
HG_HOOKTYPE=txnclose | ||||
HG_PHASES_MOVED=1 | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
commit hook: HG_HOOKNAME=commit | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
HG_PARENT1=0000000000000000000000000000000000000000 | ||||
commit.b hook: HG_HOOKNAME=commit.b | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
HG_PARENT1=0000000000000000000000000000000000000000 | ||||
Nicolas Dumazet
|
r11793 | |||
$ hg clone . ../b | ||||
updating to branch default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd ../b | ||||
Matt Mackall
|
r12328 | changegroup hooks can see env vars | ||
Nicolas Dumazet
|
r11793 | |||
Adrian Buehlmann
|
r16964 | $ cat > .hg/hgrc <<EOF | ||
> [hooks] | ||||
Boris Feld
|
r41788 | > prechangegroup = sh -c "printenv.py --line prechangegroup" | ||
> changegroup = sh -c "printenv.py --line changegroup" | ||||
> incoming = sh -c "printenv.py --line incoming" | ||||
Adrian Buehlmann
|
r16964 | > EOF | ||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | pretxncommit and commit hooks can see both parents of merge | ||
Nicolas Dumazet
|
r11793 | |||
$ cd ../a | ||||
$ echo b >> a | ||||
$ hg commit -m a1 -d "1 0" | ||||
Boris Feld
|
r41788 | precommit hook: HG_HOOKNAME=precommit | ||
HG_HOOKTYPE=precommit | ||||
HG_PARENT1=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
pretxnopen hook: HG_HOOKNAME=pretxnopen | ||||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
pretxncommit hook: HG_HOOKNAME=pretxncommit | ||||
HG_HOOKTYPE=pretxncommit | ||||
HG_NODE=ab228980c14deea8b9555d91c9581127383e40fd | ||||
HG_PARENT1=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
HG_PENDING=$TESTTMP/a | ||||
Martin Geisler
|
r12156 | 1:ab228980c14d | ||
Boris Feld
|
r41788 | pretxnclose hook: HG_HOOKNAME=pretxnclose | ||
HG_HOOKTYPE=pretxnclose | ||||
HG_PENDING=$TESTTMP/a | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
txnclose hook: HG_HOOKNAME=txnclose | ||||
HG_HOOKTYPE=txnclose | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
commit hook: HG_HOOKNAME=commit | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=ab228980c14deea8b9555d91c9581127383e40fd | ||||
HG_PARENT1=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
commit.b hook: HG_HOOKNAME=commit.b | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=ab228980c14deea8b9555d91c9581127383e40fd | ||||
HG_PARENT1=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
Nicolas Dumazet
|
r11793 | $ hg update -C 0 | ||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo b > b | ||||
$ hg add b | ||||
$ hg commit -m b -d '1 0' | ||||
Boris Feld
|
r41788 | precommit hook: HG_HOOKNAME=precommit | ||
HG_HOOKTYPE=precommit | ||||
HG_PARENT1=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
pretxnopen hook: HG_HOOKNAME=pretxnopen | ||||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
pretxncommit hook: HG_HOOKNAME=pretxncommit | ||||
HG_HOOKTYPE=pretxncommit | ||||
HG_NODE=ee9deb46ab31e4cc3310f3cf0c3d668e4d8fffc2 | ||||
HG_PARENT1=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
HG_PENDING=$TESTTMP/a | ||||
Martin Geisler
|
r12156 | 2:ee9deb46ab31 | ||
Boris Feld
|
r41788 | pretxnclose hook: HG_HOOKNAME=pretxnclose | ||
HG_HOOKTYPE=pretxnclose | ||||
HG_PENDING=$TESTTMP/a | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
FUJIWARA Katsunori
|
r27192 | created new head | ||
Boris Feld
|
r41788 | txnclose hook: HG_HOOKNAME=txnclose | ||
HG_HOOKTYPE=txnclose | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
commit hook: HG_HOOKNAME=commit | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=ee9deb46ab31e4cc3310f3cf0c3d668e4d8fffc2 | ||||
HG_PARENT1=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
commit.b hook: HG_HOOKNAME=commit.b | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=ee9deb46ab31e4cc3310f3cf0c3d668e4d8fffc2 | ||||
HG_PARENT1=cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b | ||||
Nicolas Dumazet
|
r11793 | $ hg merge 1 | ||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg commit -m merge -d '2 0' | ||||
Boris Feld
|
r41788 | precommit hook: HG_HOOKNAME=precommit | ||
HG_HOOKTYPE=precommit | ||||
HG_PARENT1=ee9deb46ab31e4cc3310f3cf0c3d668e4d8fffc2 | ||||
HG_PARENT2=ab228980c14deea8b9555d91c9581127383e40fd | ||||
pretxnopen hook: HG_HOOKNAME=pretxnopen | ||||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
pretxncommit hook: HG_HOOKNAME=pretxncommit | ||||
HG_HOOKTYPE=pretxncommit | ||||
HG_NODE=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
HG_PARENT1=ee9deb46ab31e4cc3310f3cf0c3d668e4d8fffc2 | ||||
HG_PARENT2=ab228980c14deea8b9555d91c9581127383e40fd | ||||
HG_PENDING=$TESTTMP/a | ||||
Martin Geisler
|
r12156 | 3:07f3376c1e65 | ||
Boris Feld
|
r41788 | pretxnclose hook: HG_HOOKNAME=pretxnclose | ||
HG_HOOKTYPE=pretxnclose | ||||
HG_PENDING=$TESTTMP/a | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
txnclose hook: HG_HOOKNAME=txnclose | ||||
HG_HOOKTYPE=txnclose | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
commit hook: HG_HOOKNAME=commit | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
HG_PARENT1=ee9deb46ab31e4cc3310f3cf0c3d668e4d8fffc2 | ||||
HG_PARENT2=ab228980c14deea8b9555d91c9581127383e40fd | ||||
commit.b hook: HG_HOOKNAME=commit.b | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
HG_PARENT1=ee9deb46ab31e4cc3310f3cf0c3d668e4d8fffc2 | ||||
HG_PARENT2=ab228980c14deea8b9555d91c9581127383e40fd | ||||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | test generic hooks | ||
Nicolas Dumazet
|
r11793 | |||
$ hg id | ||||
Boris Feld
|
r41788 | pre-identify hook: HG_ARGS=id | ||
HG_HOOKNAME=pre-identify | ||||
HG_HOOKTYPE=pre-identify | ||||
HG_OPTS={'bookmarks': None, 'branch': None, 'id': None, 'insecure': None, 'num': None, 'remotecmd': '', 'rev': '', 'ssh': '', 'tags': None, 'template': ''} | ||||
HG_PATS=[] | ||||
Siddharth Agarwal
|
r19011 | abort: pre-identify hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | $ hg cat b | ||
Boris Feld
|
r41788 | pre-cat hook: HG_ARGS=cat b | ||
HG_HOOKNAME=pre-cat | ||||
HG_HOOKTYPE=pre-cat | ||||
HG_OPTS={'decode': None, 'exclude': [], 'include': [], 'output': '', 'rev': '', 'template': ''} | ||||
HG_PATS=['b'] | ||||
Dan Villiom Podlaski Christiansen
|
r13121 | b | ||
Boris Feld
|
r41788 | post-cat hook: HG_ARGS=cat b | ||
HG_HOOKNAME=post-cat | ||||
HG_HOOKTYPE=post-cat | ||||
HG_OPTS={'decode': None, 'exclude': [], 'include': [], 'output': '', 'rev': '', 'template': ''} | ||||
HG_PATS=['b'] | ||||
HG_RESULT=0 | ||||
Nicolas Dumazet
|
r11793 | |||
$ cd ../b | ||||
$ hg pull ../a | ||||
Mads Kiilerich
|
r13439 | pulling from ../a | ||
searching for changes | ||||
Boris Feld
|
r41788 | prechangegroup hook: HG_HOOKNAME=prechangegroup | ||
HG_HOOKTYPE=prechangegroup | ||||
HG_SOURCE=pull | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=pull | |||
file:/*/$TESTTMP/a (glob) | ||||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
Mads Kiilerich
|
r13439 | adding changesets | ||
adding manifests | ||||
adding file changes | ||||
added 3 changesets with 2 changes to 2 files | ||||
Denis Laxalde
|
r34662 | new changesets ab228980c14d:07f3376c1e65 | ||
Boris Feld
|
r41788 | changegroup hook: HG_HOOKNAME=changegroup | ||
HG_HOOKTYPE=changegroup | ||||
HG_NODE=ab228980c14deea8b9555d91c9581127383e40fd | ||||
HG_NODE_LAST=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
HG_SOURCE=pull | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=pull | |||
file:/*/$TESTTMP/a (glob) | ||||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
incoming hook: HG_HOOKNAME=incoming | ||||
HG_HOOKTYPE=incoming | ||||
HG_NODE=ab228980c14deea8b9555d91c9581127383e40fd | ||||
HG_SOURCE=pull | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=pull | |||
file:/*/$TESTTMP/a (glob) | ||||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
incoming hook: HG_HOOKNAME=incoming | ||||
HG_HOOKTYPE=incoming | ||||
HG_NODE=ee9deb46ab31e4cc3310f3cf0c3d668e4d8fffc2 | ||||
HG_SOURCE=pull | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=pull | |||
file:/*/$TESTTMP/a (glob) | ||||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
incoming hook: HG_HOOKNAME=incoming | ||||
HG_HOOKTYPE=incoming | ||||
HG_NODE=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
HG_SOURCE=pull | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=pull | |||
file:/*/$TESTTMP/a (glob) | ||||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
Nicolas Dumazet
|
r11793 | (run 'hg update' to get a working copy) | ||
Matt Mackall
|
r12328 | tag hooks can see env vars | ||
Nicolas Dumazet
|
r11793 | |||
$ cd ../a | ||||
Adrian Buehlmann
|
r16964 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > pretag = sh -c "printenv.py --line pretag" | ||
> tag = sh -c "HG_PARENT1= HG_PARENT2= printenv.py --line tag" | ||||
Adrian Buehlmann
|
r16964 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg tag -d '3 0' a | ||
Boris Feld
|
r41788 | pretag hook: HG_HOOKNAME=pretag | ||
HG_HOOKTYPE=pretag | ||||
HG_LOCAL=0 | ||||
HG_NODE=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
HG_TAG=a | ||||
precommit hook: HG_HOOKNAME=precommit | ||||
HG_HOOKTYPE=precommit | ||||
HG_PARENT1=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
pretxnopen hook: HG_HOOKNAME=pretxnopen | ||||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
pretxncommit hook: HG_HOOKNAME=pretxncommit | ||||
HG_HOOKTYPE=pretxncommit | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_PARENT1=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
HG_PENDING=$TESTTMP/a | ||||
Martin Geisler
|
r12156 | 4:539e4b31b6dc | ||
Boris Feld
|
r41788 | pretxnclose hook: HG_HOOKNAME=pretxnclose | ||
HG_HOOKTYPE=pretxnclose | ||||
HG_PENDING=$TESTTMP/a | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
tag hook: HG_HOOKNAME=tag | ||||
HG_HOOKTYPE=tag | ||||
HG_LOCAL=0 | ||||
HG_NODE=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
HG_TAG=a | ||||
txnclose hook: HG_HOOKNAME=txnclose | ||||
HG_HOOKTYPE=txnclose | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
commit hook: HG_HOOKNAME=commit | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_PARENT1=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
commit.b hook: HG_HOOKNAME=commit.b | ||||
HG_HOOKTYPE=commit | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_PARENT1=07f3376c1e655977439df2a814e3cc14b27abac2 | ||||
Nicolas Dumazet
|
r11793 | $ hg tag -l la | ||
Boris Feld
|
r41788 | pretag hook: HG_HOOKNAME=pretag | ||
HG_HOOKTYPE=pretag | ||||
HG_LOCAL=1 | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_TAG=la | ||||
tag hook: HG_HOOKNAME=tag | ||||
HG_HOOKTYPE=tag | ||||
HG_LOCAL=1 | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_TAG=la | ||||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | pretag hook can forbid tagging | ||
Nicolas Dumazet
|
r11793 | |||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > pretag.forbid = sh -c "printenv.py --line pretag.forbid 1" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg tag -d '4 0' fa | ||
Boris Feld
|
r41788 | pretag hook: HG_HOOKNAME=pretag | ||
HG_HOOKTYPE=pretag | ||||
HG_LOCAL=0 | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_TAG=fa | ||||
pretag.forbid hook: HG_HOOKNAME=pretag.forbid | ||||
HG_HOOKTYPE=pretag | ||||
HG_LOCAL=0 | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_TAG=fa | ||||
Nicolas Dumazet
|
r11793 | abort: pretag.forbid hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | $ hg tag -l fla | ||
Boris Feld
|
r41788 | pretag hook: HG_HOOKNAME=pretag | ||
HG_HOOKTYPE=pretag | ||||
HG_LOCAL=1 | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_TAG=fla | ||||
pretag.forbid hook: HG_HOOKNAME=pretag.forbid | ||||
HG_HOOKTYPE=pretag | ||||
HG_LOCAL=1 | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_TAG=fla | ||||
Nicolas Dumazet
|
r11793 | abort: pretag.forbid hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | pretxncommit hook can see changeset, can roll back txn, changeset no | ||
more there after | ||||
Nicolas Dumazet
|
r11793 | |||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
> pretxncommit.forbid0 = sh -c "hg tip -q" | ||||
Boris Feld
|
r41788 | > pretxncommit.forbid1 = sh -c "printenv.py --line pretxncommit.forbid 1" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ echo z > z | ||
$ hg add z | ||||
$ hg -q tip | ||||
Martin Geisler
|
r12156 | 4:539e4b31b6dc | ||
Nicolas Dumazet
|
r11793 | $ hg commit -m 'fail' -d '4 0' | ||
Boris Feld
|
r41788 | precommit hook: HG_HOOKNAME=precommit | ||
HG_HOOKTYPE=precommit | ||||
HG_PARENT1=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
pretxnopen hook: HG_HOOKNAME=pretxnopen | ||||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
pretxncommit hook: HG_HOOKNAME=pretxncommit | ||||
HG_HOOKTYPE=pretxncommit | ||||
HG_NODE=6f611f8018c10e827fee6bd2bc807f937e761567 | ||||
HG_PARENT1=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_PENDING=$TESTTMP/a | ||||
Martin Geisler
|
r12156 | 5:6f611f8018c1 | ||
5:6f611f8018c1 | ||||
Boris Feld
|
r41788 | pretxncommit.forbid hook: HG_HOOKNAME=pretxncommit.forbid1 | ||
HG_HOOKTYPE=pretxncommit | ||||
HG_NODE=6f611f8018c10e827fee6bd2bc807f937e761567 | ||||
HG_PARENT1=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_PENDING=$TESTTMP/a | ||||
Nicolas Dumazet
|
r11793 | transaction abort! | ||
Joerg Sonnenberger
|
r45350 | txnabort Python hook: changes,txnid,txnname | ||
Boris Feld
|
r41788 | txnabort hook: HG_HOOKNAME=txnabort.1 | ||
HG_HOOKTYPE=txnabort | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=commit | ||||
Nicolas Dumazet
|
r11793 | rollback completed | ||
abort: pretxncommit.forbid1 hook exited with status 1 | ||||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | $ hg -q tip | ||
Martin Geisler
|
r12156 | 4:539e4b31b6dc | ||
Nicolas Dumazet
|
r11793 | |||
Pierre-Yves David
|
r23292 | (Check that no 'changelog.i.a' file were left behind) | ||
$ ls -1 .hg/store/ | ||||
00changelog.i | ||||
00manifest.i | ||||
data | ||||
Gregory Szorc
|
r37433 | fncache (repofncache !) | ||
Pierre-Yves David
|
r23292 | journal.phaseroots | ||
phaseroots | ||||
undo | ||||
Gregory Szorc
|
r37433 | undo.backup.fncache (repofncache !) | ||
Pierre-Yves David
|
r23904 | undo.backupfiles | ||
Pierre-Yves David
|
r23292 | undo.phaseroots | ||
Matt Mackall
|
r12328 | precommit hook can prevent commit | ||
Nicolas Dumazet
|
r11793 | |||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > precommit.forbid = sh -c "printenv.py --line precommit.forbid 1" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg commit -m 'fail' -d '4 0' | ||
Boris Feld
|
r41788 | precommit hook: HG_HOOKNAME=precommit | ||
HG_HOOKTYPE=precommit | ||||
HG_PARENT1=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
precommit.forbid hook: HG_HOOKNAME=precommit.forbid | ||||
HG_HOOKTYPE=precommit | ||||
HG_PARENT1=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
Nicolas Dumazet
|
r11793 | abort: precommit.forbid hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | $ hg -q tip | ||
Martin Geisler
|
r12156 | 4:539e4b31b6dc | ||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | preupdate hook can prevent update | ||
Nicolas Dumazet
|
r11793 | |||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > preupdate = sh -c "printenv.py --line preupdate" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg update 1 | ||
Boris Feld
|
r41788 | preupdate hook: HG_HOOKNAME=preupdate | ||
HG_HOOKTYPE=preupdate | ||||
HG_PARENT1=ab228980c14d | ||||
Nicolas Dumazet
|
r11793 | 0 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||
Matt Mackall
|
r12328 | update hook | ||
Nicolas Dumazet
|
r11793 | |||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > update = sh -c "printenv.py --line update" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg update | ||
Boris Feld
|
r41788 | preupdate hook: HG_HOOKNAME=preupdate | ||
HG_HOOKTYPE=preupdate | ||||
HG_PARENT1=539e4b31b6dc | ||||
update hook: HG_ERROR=0 | ||||
HG_HOOKNAME=update | ||||
HG_HOOKTYPE=update | ||||
HG_PARENT1=539e4b31b6dc | ||||
Pierre-Yves David
|
r26028 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Nicolas Dumazet
|
r11793 | |||
Brodie Rao
|
r14102 | pushkey hook | ||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > pushkey = sh -c "printenv.py --line pushkey" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Brodie Rao
|
r14102 | $ cd ../b | ||
$ hg bookmark -r null foo | ||||
$ hg push -B foo ../a | ||||
pushing to ../a | ||||
searching for changes | ||||
no changes found | ||||
Boris Feld
|
r41788 | pretxnopen hook: HG_HOOKNAME=pretxnopen | ||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=push | ||||
pretxnclose hook: HG_BOOKMARK_MOVED=1 | ||||
HG_BUNDLE2=1 | ||||
HG_HOOKNAME=pretxnclose | ||||
HG_HOOKTYPE=pretxnclose | ||||
HG_PENDING=$TESTTMP/a | ||||
HG_SOURCE=push | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=push | ||||
HG_URL=file:$TESTTMP/a | ||||
pushkey hook: HG_BUNDLE2=1 | ||||
HG_HOOKNAME=pushkey | ||||
HG_HOOKTYPE=pushkey | ||||
HG_KEY=foo | ||||
HG_NAMESPACE=bookmarks | ||||
HG_NEW=0000000000000000000000000000000000000000 | ||||
HG_PUSHKEYCOMPAT=1 | ||||
HG_SOURCE=push | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=push | |||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
txnclose hook: HG_BOOKMARK_MOVED=1 | ||||
HG_BUNDLE2=1 | ||||
HG_HOOKNAME=txnclose | ||||
HG_HOOKTYPE=txnclose | ||||
HG_SOURCE=push | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=push | ||||
HG_URL=file:$TESTTMP/a | ||||
Brodie Rao
|
r14102 | exporting bookmark foo | ||
Matt Mackall
|
r16038 | [1] | ||
Brodie Rao
|
r14102 | $ cd ../a | ||
listkeys hook | ||||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > listkeys = sh -c "printenv.py --line listkeys" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Brodie Rao
|
r14102 | $ hg bookmark -r null bar | ||
Boris Feld
|
r41788 | pretxnopen hook: HG_HOOKNAME=pretxnopen | ||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=bookmark | ||||
pretxnclose hook: HG_BOOKMARK_MOVED=1 | ||||
HG_HOOKNAME=pretxnclose | ||||
HG_HOOKTYPE=pretxnclose | ||||
HG_PENDING=$TESTTMP/a | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=bookmark | ||||
txnclose hook: HG_BOOKMARK_MOVED=1 | ||||
HG_HOOKNAME=txnclose | ||||
HG_HOOKTYPE=txnclose | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=bookmark | ||||
Brodie Rao
|
r14102 | $ cd ../b | ||
$ hg pull -B bar ../a | ||||
pulling from ../a | ||||
Boris Feld
|
r41788 | listkeys hook: HG_HOOKNAME=listkeys | ||
HG_HOOKTYPE=listkeys | ||||
HG_NAMESPACE=bookmarks | ||||
HG_VALUES={'bar': '0000000000000000000000000000000000000000', 'foo': '0000000000000000000000000000000000000000'} | ||||
Pierre-Yves David
|
r25370 | no changes found | ||
adding remote bookmark bar | ||||
Brodie Rao
|
r14102 | $ cd ../a | ||
test that prepushkey can prevent incoming keys | ||||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > prepushkey = sh -c "printenv.py --line prepushkey.forbid 1" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Brodie Rao
|
r14102 | $ cd ../b | ||
$ hg bookmark -r null baz | ||||
$ hg push -B baz ../a | ||||
pushing to ../a | ||||
searching for changes | ||||
Boris Feld
|
r41788 | listkeys hook: HG_HOOKNAME=listkeys | ||
HG_HOOKTYPE=listkeys | ||||
HG_NAMESPACE=phases | ||||
HG_VALUES={'cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b': '1', 'publishing': 'True'} | ||||
listkeys hook: HG_HOOKNAME=listkeys | ||||
HG_HOOKTYPE=listkeys | ||||
HG_NAMESPACE=bookmarks | ||||
HG_VALUES={'bar': '0000000000000000000000000000000000000000', 'foo': '0000000000000000000000000000000000000000'} | ||||
Brodie Rao
|
r14102 | no changes found | ||
Boris Feld
|
r41788 | pretxnopen hook: HG_HOOKNAME=pretxnopen | ||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=push | ||||
prepushkey.forbid hook: HG_BUNDLE2=1 | ||||
HG_HOOKNAME=prepushkey | ||||
HG_HOOKTYPE=prepushkey | ||||
HG_KEY=baz | ||||
HG_NAMESPACE=bookmarks | ||||
HG_NEW=0000000000000000000000000000000000000000 | ||||
HG_PUSHKEYCOMPAT=1 | ||||
HG_SOURCE=push | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=push | |||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
Boris Feld
|
r35265 | abort: prepushkey hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Brodie Rao
|
r14102 | $ cd ../a | ||
test that prelistkeys can prevent listing keys | ||||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > prelistkeys = sh -c "printenv.py --line prelistkeys.forbid 1" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Brodie Rao
|
r14102 | $ hg bookmark -r null quux | ||
Boris Feld
|
r41788 | pretxnopen hook: HG_HOOKNAME=pretxnopen | ||
HG_HOOKTYPE=pretxnopen | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=bookmark | ||||
pretxnclose hook: HG_BOOKMARK_MOVED=1 | ||||
HG_HOOKNAME=pretxnclose | ||||
HG_HOOKTYPE=pretxnclose | ||||
HG_PENDING=$TESTTMP/a | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=bookmark | ||||
txnclose hook: HG_BOOKMARK_MOVED=1 | ||||
HG_HOOKNAME=txnclose | ||||
HG_HOOKTYPE=txnclose | ||||
HG_TXNID=TXN:$ID$ | ||||
HG_TXNNAME=bookmark | ||||
Brodie Rao
|
r14102 | $ cd ../b | ||
$ hg pull -B quux ../a | ||||
pulling from ../a | ||||
Boris Feld
|
r41788 | prelistkeys.forbid hook: HG_HOOKNAME=prelistkeys | ||
HG_HOOKTYPE=prelistkeys | ||||
HG_NAMESPACE=bookmarks | ||||
Brodie Rao
|
r14102 | abort: prelistkeys hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Brodie Rao
|
r14102 | $ cd ../a | ||
Siddharth Agarwal
|
r18850 | $ rm .hg/hgrc | ||
Brodie Rao
|
r14102 | |||
Matt Mackall
|
r12328 | prechangegroup hook can prevent incoming changes | ||
Nicolas Dumazet
|
r11793 | |||
$ cd ../b | ||||
$ hg -q tip | ||||
Martin Geisler
|
r12156 | 3:07f3376c1e65 | ||
Adrian Buehlmann
|
r16964 | $ cat > .hg/hgrc <<EOF | ||
> [hooks] | ||||
Boris Feld
|
r41788 | > prechangegroup.forbid = sh -c "printenv.py --line prechangegroup.forbid 1" | ||
Adrian Buehlmann
|
r16964 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg pull ../a | ||
pulling from ../a | ||||
searching for changes | ||||
Boris Feld
|
r41788 | prechangegroup.forbid hook: HG_HOOKNAME=prechangegroup.forbid | ||
HG_HOOKTYPE=prechangegroup | ||||
HG_SOURCE=pull | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=pull | |||
file:/*/$TESTTMP/a (glob) | ||||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
Nicolas Dumazet
|
r11793 | abort: prechangegroup.forbid hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | pretxnchangegroup hook can see incoming changes, can roll back txn, | ||
incoming changes no longer there after | ||||
Nicolas Dumazet
|
r11793 | |||
Adrian Buehlmann
|
r16964 | $ cat > .hg/hgrc <<EOF | ||
> [hooks] | ||||
> pretxnchangegroup.forbid0 = hg tip -q | ||||
Boris Feld
|
r41788 | > pretxnchangegroup.forbid1 = sh -c "printenv.py --line pretxnchangegroup.forbid 1" | ||
Adrian Buehlmann
|
r16964 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg pull ../a | ||
pulling from ../a | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
Mads Kiilerich
|
r13439 | 4:539e4b31b6dc | ||
Boris Feld
|
r41788 | pretxnchangegroup.forbid hook: HG_HOOKNAME=pretxnchangegroup.forbid1 | ||
HG_HOOKTYPE=pretxnchangegroup | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_NODE_LAST=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_PENDING=$TESTTMP/b | ||||
HG_SOURCE=pull | ||||
HG_TXNID=TXN:$ID$ | ||||
r42062 | HG_TXNNAME=pull | |||
file:/*/$TESTTMP/a (glob) | ||||
Boris Feld
|
r41788 | HG_URL=file:$TESTTMP/a | ||
Nicolas Dumazet
|
r11793 | transaction abort! | ||
rollback completed | ||||
abort: pretxnchangegroup.forbid1 hook exited with status 1 | ||||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | $ hg -q tip | ||
Martin Geisler
|
r12156 | 3:07f3376c1e65 | ||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | outgoing hooks can see env vars | ||
Nicolas Dumazet
|
r11793 | |||
$ rm .hg/hgrc | ||||
Adrian Buehlmann
|
r16964 | $ cat > ../a/.hg/hgrc <<EOF | ||
> [hooks] | ||||
Boris Feld
|
r41788 | > preoutgoing = sh -c "printenv.py --line preoutgoing" | ||
> outgoing = sh -c "printenv.py --line outgoing" | ||||
Adrian Buehlmann
|
r16964 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg pull ../a | ||
pulling from ../a | ||||
searching for changes | ||||
Boris Feld
|
r41788 | preoutgoing hook: HG_HOOKNAME=preoutgoing | ||
HG_HOOKTYPE=preoutgoing | ||||
HG_SOURCE=pull | ||||
outgoing hook: HG_HOOKNAME=outgoing | ||||
HG_HOOKTYPE=outgoing | ||||
HG_NODE=539e4b31b6dc99b3cfbaa6b53cbc1c1f9a1e3a10 | ||||
HG_SOURCE=pull | ||||
Nicolas Dumazet
|
r11793 | adding changesets | ||
adding manifests | ||||
adding file changes | ||||
r43167 | adding remote bookmark quux | |||
Nicolas Dumazet
|
r11793 | added 1 changesets with 1 changes to 1 files | ||
Denis Laxalde
|
r34662 | new changesets 539e4b31b6dc | ||
Nicolas Dumazet
|
r11793 | (run 'hg update' to get a working copy) | ||
$ hg rollback | ||||
Gilles Moris
|
r13446 | repository tip rolled back to revision 3 (undo pull) | ||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | preoutgoing hook can prevent outgoing changes | ||
Nicolas Dumazet
|
r11793 | |||
FUJIWARA Katsunori
|
r30234 | $ cat >> ../a/.hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > preoutgoing.forbid = sh -c "printenv.py --line preoutgoing.forbid 1" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg pull ../a | ||
Mads Kiilerich
|
r13439 | pulling from ../a | ||
searching for changes | ||||
Boris Feld
|
r41788 | preoutgoing hook: HG_HOOKNAME=preoutgoing | ||
HG_HOOKTYPE=preoutgoing | ||||
HG_SOURCE=pull | ||||
preoutgoing.forbid hook: HG_HOOKNAME=preoutgoing.forbid | ||||
HG_HOOKTYPE=preoutgoing | ||||
HG_SOURCE=pull | ||||
Nicolas Dumazet
|
r11793 | abort: preoutgoing.forbid hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | outgoing hooks work for local clones | ||
Nicolas Dumazet
|
r11793 | |||
$ cd .. | ||||
Adrian Buehlmann
|
r16964 | $ cat > a/.hg/hgrc <<EOF | ||
> [hooks] | ||||
Boris Feld
|
r41788 | > preoutgoing = sh -c "printenv.py --line preoutgoing" | ||
> outgoing = sh -c "printenv.py --line outgoing" | ||||
Adrian Buehlmann
|
r16964 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg clone a c | ||
Boris Feld
|
r41788 | preoutgoing hook: HG_HOOKNAME=preoutgoing | ||
HG_HOOKTYPE=preoutgoing | ||||
HG_SOURCE=clone | ||||
outgoing hook: HG_HOOKNAME=outgoing | ||||
HG_HOOKTYPE=outgoing | ||||
HG_NODE=0000000000000000000000000000000000000000 | ||||
HG_SOURCE=clone | ||||
Nicolas Dumazet
|
r11793 | updating to branch default | ||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ rm -rf c | ||||
Matt Mackall
|
r12328 | preoutgoing hook can prevent outgoing changes for local clones | ||
Nicolas Dumazet
|
r11793 | |||
FUJIWARA Katsunori
|
r30234 | $ cat >> a/.hg/hgrc <<EOF | ||
Boris Feld
|
r41788 | > preoutgoing.forbid = sh -c "printenv.py --line preoutgoing.forbid 1" | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Nicolas Dumazet
|
r11793 | $ hg clone a zzz | ||
Boris Feld
|
r41788 | preoutgoing hook: HG_HOOKNAME=preoutgoing | ||
HG_HOOKTYPE=preoutgoing | ||||
HG_SOURCE=clone | ||||
preoutgoing.forbid hook: HG_HOOKNAME=preoutgoing.forbid | ||||
HG_HOOKTYPE=preoutgoing | ||||
HG_SOURCE=clone | ||||
Nicolas Dumazet
|
r11793 | abort: preoutgoing.forbid hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Adrian Buehlmann
|
r16964 | |||
$ cd "$TESTTMP/b" | ||||
Nicolas Dumazet
|
r11793 | |||
$ cat > hooktests.py <<EOF | ||||
Augie Fackler
|
r33687 | > from __future__ import print_function | ||
Augie Fackler
|
r37772 | > from mercurial import ( | ||
> error, | ||||
> pycompat, | ||||
> ) | ||||
Nicolas Dumazet
|
r11793 | > | ||
> uncallable = 0 | ||||
> | ||||
Saurabh Singh
|
r34453 | > def printargs(ui, args): | ||
Augie Fackler
|
r37772 | > a = list(pycompat.byteskwargs(args).items()) | ||
Nicolas Dumazet
|
r11793 | > a.sort() | ||
Gregory Szorc
|
r36126 | > ui.write(b'hook args:\n') | ||
Nicolas Dumazet
|
r11793 | > for k, v in a: | ||
Gregory Szorc
|
r36126 | > ui.write(b' %s %s\n' % (k, v)) | ||
Nicolas Dumazet
|
r11793 | > | ||
Saurabh Singh
|
r34453 | > def passhook(ui, repo, **args): | ||
> printargs(ui, args) | ||||
Nicolas Dumazet
|
r11793 | > | ||
Saurabh Singh
|
r34453 | > def failhook(ui, repo, **args): | ||
> printargs(ui, args) | ||||
Nicolas Dumazet
|
r11793 | > return True | ||
> | ||||
> class LocalException(Exception): | ||||
> pass | ||||
> | ||||
> def raisehook(**args): | ||||
Augie Fackler
|
r37772 | > raise LocalException('exception from hook') | ||
Nicolas Dumazet
|
r11793 | > | ||
> def aborthook(**args): | ||||
Gregory Szorc
|
r36126 | > raise error.Abort(b'raise abort from hook') | ||
Nicolas Dumazet
|
r11793 | > | ||
> def brokenhook(**args): | ||||
> return 1 + {} | ||||
> | ||||
Idan Kamara
|
r14601 | > def verbosehook(ui, **args): | ||
Gregory Szorc
|
r36126 | > ui.note(b'verbose output from hook\n') | ||
Idan Kamara
|
r14601 | > | ||
Mads Kiilerich
|
r15929 | > def printtags(ui, repo, **args): | ||
Augie Fackler
|
r37771 | > ui.write(b'[%s]\n' % b', '.join(sorted(repo.tags()))) | ||
Mads Kiilerich
|
r15929 | > | ||
FUJIWARA Katsunori
|
r41880 | > class container(object): | ||
Nicolas Dumazet
|
r11793 | > unreachable = 1 | ||
> EOF | ||||
FUJIWARA Katsunori
|
r40241 | $ cat > syntaxerror.py << NO_CHECK_EOF | ||
Siddharth Agarwal
|
r28109 | > (foo | ||
FUJIWARA Katsunori
|
r40241 | > NO_CHECK_EOF | ||
Siddharth Agarwal
|
r28109 | |||
Matt Mackall
|
r12328 | test python hooks | ||
Nicolas Dumazet
|
r11793 | |||
Adrian Buehlmann
|
r16964 | #if windows | ||
$ PYTHONPATH="$TESTTMP/b;$PYTHONPATH" | ||||
#else | ||||
$ PYTHONPATH="$TESTTMP/b:$PYTHONPATH" | ||||
#endif | ||||
Nicolas Dumazet
|
r11793 | $ export PYTHONPATH | ||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.broken = python:hooktests.brokenhook' >> ../a/.hg/hgrc | ||||
$ hg pull ../a 2>&1 | grep 'raised an exception' | ||||
error: preoutgoing.broken hook raised an exception: unsupported operand type(s) for +: 'int' and 'dict' | ||||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.raise = python:hooktests.raisehook' >> ../a/.hg/hgrc | ||||
$ hg pull ../a 2>&1 | grep 'raised an exception' | ||||
error: preoutgoing.raise hook raised an exception: exception from hook | ||||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.abort = python:hooktests.aborthook' >> ../a/.hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
error: preoutgoing.abort hook failed: raise abort from hook | ||||
abort: raise abort from hook | ||||
Matt Mackall
|
r12316 | [255] | ||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.fail = python:hooktests.failhook' >> ../a/.hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
hook args: | ||||
hooktype preoutgoing | ||||
source pull | ||||
abort: preoutgoing.fail hook failed | ||||
Martin von Zweigbergk
|
r47145 | [40] | ||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.uncallable = python:hooktests.uncallable' >> ../a/.hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
Siddharth Agarwal
|
r28079 | abort: preoutgoing.uncallable hook is invalid: "hooktests.uncallable" is not callable | ||
Matt Mackall
|
r12316 | [255] | ||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.nohook = python:hooktests.nohook' >> ../a/.hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
Siddharth Agarwal
|
r28079 | abort: preoutgoing.nohook hook is invalid: "hooktests.nohook" is not defined | ||
Matt Mackall
|
r12316 | [255] | ||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.nomodule = python:nomodule' >> ../a/.hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
Siddharth Agarwal
|
r28106 | abort: preoutgoing.nomodule hook is invalid: "nomodule" not in a module | ||
Matt Mackall
|
r12316 | [255] | ||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.badmodule = python:nomodule.nowhere' >> ../a/.hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
Siddharth Agarwal
|
r28079 | abort: preoutgoing.badmodule hook is invalid: import of "nomodule" failed | ||
Siddharth Agarwal
|
r28080 | (run with --traceback for stack trace) | ||
Matt Mackall
|
r12316 | [255] | ||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
$ echo 'preoutgoing.unreachable = python:hooktests.container.unreachable' >> ../a/.hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
Siddharth Agarwal
|
r28079 | abort: preoutgoing.unreachable hook is invalid: import of "hooktests.container" failed | ||
Siddharth Agarwal
|
r28080 | (run with --traceback for stack trace) | ||
Matt Mackall
|
r12316 | [255] | ||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
Siddharth Agarwal
|
r28109 | $ echo 'preoutgoing.syntaxerror = python:syntaxerror.syntaxerror' >> ../a/.hg/hgrc | ||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
abort: preoutgoing.syntaxerror hook is invalid: import of "syntaxerror" failed | ||||
(run with --traceback for stack trace) | ||||
[255] | ||||
Denis Laxalde
|
r43586 | $ hg pull ../a --traceback 2>&1 | egrep 'pulling|searching|^exception|Traceback|SyntaxError|ImportError|ModuleNotFoundError|HookLoadError|abort' | ||
Siddharth Agarwal
|
r28109 | pulling from ../a | ||
searching for changes | ||||
exception from first failed import attempt: | ||||
Traceback (most recent call last): | ||||
Maciej Fijalkowski
|
r28737 | SyntaxError: * (glob) | ||
Siddharth Agarwal
|
r28109 | exception from second failed import attempt: | ||
Denis Laxalde
|
r43587 | Traceback (most recent call last): (py3 !) | ||
SyntaxError: * (glob) (py3 !) | ||||
Siddharth Agarwal
|
r28109 | Traceback (most recent call last): | ||
Denis Laxalde
|
r43587 | ImportError: No module named hgext_syntaxerror (no-py3 !) | ||
ImportError: No module named 'hgext_syntaxerror' (py3 no-py36 !) | ||||
ModuleNotFoundError: No module named 'hgext_syntaxerror' (py36 !) | ||||
Siddharth Agarwal
|
r28109 | Traceback (most recent call last): | ||
Denis Laxalde
|
r43587 | SyntaxError: * (glob) (py3 !) | ||
Traceback (most recent call last): (py3 !) | ||||
ImportError: No module named 'hgext_syntaxerror' (py3 no-py36 !) | ||||
ModuleNotFoundError: No module named 'hgext_syntaxerror' (py36 !) | ||||
Traceback (most recent call last): (py3 !) | ||||
Denis Laxalde
|
r43585 | HookLoadError: preoutgoing.syntaxerror hook is invalid: import of "syntaxerror" failed (no-py3 !) | ||
Gregory Szorc
|
r44580 | raise error.HookLoadError( (py38 !) | ||
Denis Laxalde
|
r43720 | mercurial.error.HookLoadError: preoutgoing.syntaxerror hook is invalid: import of "syntaxerror" failed (py3 !) | ||
Siddharth Agarwal
|
r28109 | abort: preoutgoing.syntaxerror hook is invalid: import of "syntaxerror" failed | ||
$ echo '[hooks]' > ../a/.hg/hgrc | ||||
Nicolas Dumazet
|
r11793 | $ echo 'preoutgoing.pass = python:hooktests.passhook' >> ../a/.hg/hgrc | ||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
hook args: | ||||
hooktype preoutgoing | ||||
source pull | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
r43167 | adding remote bookmark quux | |||
Nicolas Dumazet
|
r11793 | added 1 changesets with 1 changes to 1 files | ||
Denis Laxalde
|
r34662 | new changesets 539e4b31b6dc | ||
Nicolas Dumazet
|
r11793 | (run 'hg update' to get a working copy) | ||
Siddharth Agarwal
|
r28107 | post- python hooks that fail to *run* don't cause an abort | ||
$ rm ../a/.hg/hgrc | ||||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'post-pull.broken = python:hooktests.brokenhook' >> .hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
no changes found | ||||
error: post-pull.broken hook raised an exception: unsupported operand type(s) for +: 'int' and 'dict' | ||||
Siddharth Agarwal
|
r28108 | (run with --traceback for stack trace) | ||
Siddharth Agarwal
|
r28107 | |||
but post- python hooks that fail to *load* do | ||||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'post-pull.nomodule = python:nomodule' >> .hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
no changes found | ||||
abort: post-pull.nomodule hook is invalid: "nomodule" not in a module | ||||
[255] | ||||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'post-pull.badmodule = python:nomodule.nowhere' >> .hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
no changes found | ||||
abort: post-pull.badmodule hook is invalid: import of "nomodule" failed | ||||
(run with --traceback for stack trace) | ||||
[255] | ||||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'post-pull.nohook = python:hooktests.nohook' >> .hg/hgrc | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
no changes found | ||||
abort: post-pull.nohook hook is invalid: "hooktests.nohook" is not defined | ||||
[255] | ||||
Matt Mackall
|
r12328 | make sure --traceback works | ||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'commit.abort = python:hooktests.aborthook' >> .hg/hgrc | ||||
$ echo aa > a | ||||
$ hg --traceback commit -d '0 0' -ma 2>&1 | grep '^Traceback' | ||||
Traceback (most recent call last): | ||||
$ cd .. | ||||
$ hg init c | ||||
$ cd c | ||||
$ cat > hookext.py <<EOF | ||||
Saurabh Singh
|
r34453 | > def autohook(ui, **args): | ||
Augie Fackler
|
r37772 | > ui.write(b'Automatically installed hook\n') | ||
Nicolas Dumazet
|
r11793 | > | ||
> def reposetup(ui, repo): | ||||
Augie Fackler
|
r37772 | > repo.ui.setconfig(b"hooks", b"commit.auto", autohook) | ||
Nicolas Dumazet
|
r11793 | > EOF | ||
$ echo '[extensions]' >> .hg/hgrc | ||||
$ echo 'hookext = hookext.py' >> .hg/hgrc | ||||
$ touch foo | ||||
$ hg add foo | ||||
$ hg ci -d '0 0' -m 'add foo' | ||||
Automatically installed hook | ||||
$ echo >> foo | ||||
Nicolas Dumazet
|
r11794 | $ hg ci --debug -d '0 0' -m 'change foo' | ||
Mads Kiilerich
|
r23749 | committing files: | ||
Nicolas Dumazet
|
r11793 | foo | ||
Mads Kiilerich
|
r23749 | committing manifest | ||
committing changelog | ||||
Pierre-Yves David
|
r32267 | updating the branch cache | ||
FUJIWARA Katsunori
|
r27192 | committed changeset 1:52998019f6252a2b893452765fcb0a47351a5708 | ||
Mads Kiilerich
|
r20548 | calling hook commit.auto: hgext_hookext.autohook | ||
Nicolas Dumazet
|
r11793 | Automatically installed hook | ||
Nicolas Dumazet
|
r11794 | $ hg showconfig hooks | ||
Brodie Rao
|
r12376 | hooks.commit.auto=<function autohook at *> (glob) | ||
Nicolas Dumazet
|
r11793 | |||
Matt Mackall
|
r12328 | test python hook configured with python:[file]:[hook] syntax | ||
Nicolas Dumazet
|
r11793 | |||
$ cd .. | ||||
$ mkdir d | ||||
$ cd d | ||||
$ hg init repo | ||||
$ mkdir hooks | ||||
$ cd hooks | ||||
$ cat > testhooks.py <<EOF | ||||
Saurabh Singh
|
r34453 | > def testhook(ui, **args): | ||
Gregory Szorc
|
r36126 | > ui.write(b'hook works\n') | ||
Nicolas Dumazet
|
r11793 | > EOF | ||
$ echo '[hooks]' > ../repo/.hg/hgrc | ||||
$ echo "pre-commit.test = python:`pwd`/testhooks.py:testhook" >> ../repo/.hg/hgrc | ||||
$ cd ../repo | ||||
$ hg commit -d '0 0' | ||||
hook works | ||||
nothing changed | ||||
Matt Mackall
|
r12316 | [1] | ||
Nicolas Dumazet
|
r11793 | |||
Simon Heimberg
|
r17217 | $ echo '[hooks]' > .hg/hgrc | ||
timeless@mozdev.org
|
r17492 | $ echo "update.ne = python:`pwd`/nonexistent.py:testhook" >> .hg/hgrc | ||
Simon Heimberg
|
r17217 | $ echo "pre-identify.npmd = python:`pwd`/:no_python_module_dir" >> .hg/hgrc | ||
$ hg up null | ||||
loading update.ne hook failed: | ||||
Yuya Nishihara
|
r41465 | abort: $ENOENT$: '$TESTTMP/d/repo/nonexistent.py' | ||
Simon Heimberg
|
r17217 | [255] | ||
$ hg id | ||||
loading pre-identify.npmd hook failed: | ||||
Martin von Zweigbergk
|
r46518 | abort: No module named repo (no-py3 !) | ||
abort: No module named 'repo' (py3 !) | ||||
Simon Heimberg
|
r17217 | [255] | ||
Nicolas Dumazet
|
r11793 | $ cd ../../b | ||
Matt Mackall
|
r12328 | make sure --traceback works on hook import failure | ||
Nicolas Dumazet
|
r11793 | |||
$ cat > importfail.py <<EOF | ||||
> import somebogusmodule | ||||
> # dereference something in the module to force demandimport to load it | ||||
> somebogusmodule.whatever | ||||
> EOF | ||||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'precommit.importfail = python:importfail.whatever' >> .hg/hgrc | ||||
$ echo a >> a | ||||
Denis Laxalde
|
r43586 | $ hg --traceback commit -ma 2>&1 | egrep '^exception|ImportError|ModuleNotFoundError|Traceback|HookLoadError|abort' | ||
Nicolas Dumazet
|
r11793 | exception from first failed import attempt: | ||
Traceback (most recent call last): | ||||
Denis Laxalde
|
r43587 | ImportError: No module named somebogusmodule (no-py3 !) | ||
ImportError: No module named 'somebogusmodule' (py3 no-py36 !) | ||||
ModuleNotFoundError: No module named 'somebogusmodule' (py36 !) | ||||
Nicolas Dumazet
|
r11793 | exception from second failed import attempt: | ||
Denis Laxalde
|
r43587 | Traceback (most recent call last): (py3 !) | ||
ImportError: No module named 'somebogusmodule' (py3 no-py36 !) | ||||
ModuleNotFoundError: No module named 'somebogusmodule' (py36 !) | ||||
Traceback (most recent call last): (py3 !) | ||||
ImportError: No module named 'hgext_importfail' (py3 no-py36 !) | ||||
ModuleNotFoundError: No module named 'hgext_importfail' (py36 !) | ||||
Traceback (most recent call last): (py3 !) | ||||
ImportError: No module named 'somebogusmodule' (py3 no-py36 !) | ||||
ModuleNotFoundError: No module named 'somebogusmodule' (py36 !) | ||||
Nicolas Dumazet
|
r11793 | Traceback (most recent call last): | ||
Denis Laxalde
|
r43587 | ImportError: No module named hgext_importfail (no-py3 !) | ||
ImportError: No module named 'hgext_importfail' (py3 no-py36 !) | ||||
ModuleNotFoundError: No module named 'hgext_importfail' (py36 !) | ||||
Nicolas Dumazet
|
r11793 | Traceback (most recent call last): | ||
Denis Laxalde
|
r43585 | HookLoadError: precommit.importfail hook is invalid: import of "importfail" failed (no-py3 !) | ||
Gregory Szorc
|
r44580 | raise error.HookLoadError( (py38 !) | ||
Denis Laxalde
|
r43720 | mercurial.error.HookLoadError: precommit.importfail hook is invalid: import of "importfail" failed (py3 !) | ||
Siddharth Agarwal
|
r28079 | abort: precommit.importfail hook is invalid: import of "importfail" failed | ||
Nicolas Dumazet
|
r11793 | |||
Martin Geisler
|
r12399 | Issue1827: Hooks Update & Commit not completely post operation | ||
Matt Harbison
|
r24881 | commit and update hooks should run after command completion. The largefiles | ||
use demonstrates a recursive wlock, showing the hook doesn't run until the | ||||
final release (and dirstate flush). | ||||
Nicolas Dumazet
|
r11793 | |||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'commit = hg id' >> .hg/hgrc | ||||
$ echo 'update = hg id' >> .hg/hgrc | ||||
$ echo bb > a | ||||
Martin Geisler
|
r12156 | $ hg ci -ma | ||
223eafe2750c tip | ||||
Matt Harbison
|
r24881 | $ hg up 0 --config extensions.largefiles= | ||
FUJIWARA Katsunori
|
r33209 | The fsmonitor extension is incompatible with the largefiles extension and has been disabled. (fsmonitor !) | ||
FUJIWARA Katsunori
|
r26752 | cb9a9f314b8b | ||
Pierre-Yves David
|
r26028 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Nicolas Dumazet
|
r11793 | |||
timeless@mozdev.org
|
r17508 | make sure --verbose (and --quiet/--debug etc.) are propagated to the local ui | ||
Idan Kamara
|
r14601 | that is passed to pre/post hooks | ||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'pre-identify = python:hooktests.verbosehook' >> .hg/hgrc | ||||
$ hg id | ||||
cb9a9f314b8b | ||||
$ hg id --verbose | ||||
calling hook pre-identify: hooktests.verbosehook | ||||
verbose output from hook | ||||
cb9a9f314b8b | ||||
Matt Zuba
|
r15896 | |||
Ensure hooks can be prioritized | ||||
$ echo '[hooks]' > .hg/hgrc | ||||
$ echo 'pre-identify.a = python:hooktests.verbosehook' >> .hg/hgrc | ||||
$ echo 'pre-identify.b = python:hooktests.verbosehook' >> .hg/hgrc | ||||
$ echo 'priority.pre-identify.b = 1' >> .hg/hgrc | ||||
$ echo 'pre-identify.c = python:hooktests.verbosehook' >> .hg/hgrc | ||||
$ hg id --verbose | ||||
calling hook pre-identify.b: hooktests.verbosehook | ||||
verbose output from hook | ||||
calling hook pre-identify.a: hooktests.verbosehook | ||||
verbose output from hook | ||||
calling hook pre-identify.c: hooktests.verbosehook | ||||
verbose output from hook | ||||
cb9a9f314b8b | ||||
Mads Kiilerich
|
r15929 | |||
new tags must be visible in pretxncommit (issue3210) | ||||
$ echo 'pretxncommit.printtags = python:hooktests.printtags' >> .hg/hgrc | ||||
$ hg tag -f foo | ||||
Augie Fackler
|
r37771 | [a, foo, tip] | ||
Mads Kiilerich
|
r15929 | |||
Sietse Brouwer
|
r27228 | post-init hooks must not crash (issue4983) | ||
This also creates the `to` repo for the next test block. | ||||
$ cd .. | ||||
$ cat << EOF >> hgrc-with-post-init-hook | ||||
> [hooks] | ||||
Boris Feld
|
r41788 | > post-init = sh -c "printenv.py --line post-init" | ||
Sietse Brouwer
|
r27228 | > EOF | ||
$ HGRCPATH=hgrc-with-post-init-hook hg init to | ||||
Boris Feld
|
r41788 | post-init hook: HG_ARGS=init to | ||
HG_HOOKNAME=post-init | ||||
HG_HOOKTYPE=post-init | ||||
HG_OPTS={'insecure': None, 'remotecmd': '', 'ssh': ''} | ||||
HG_PATS=['to'] | ||||
HG_RESULT=0 | ||||
Sietse Brouwer
|
r27228 | |||
Bryan O'Sullivan
|
r16619 | new commits must be visible in pretxnchangegroup (issue3428) | ||
$ echo '[hooks]' >> to/.hg/hgrc | ||||
Durham Goode
|
r26859 | $ echo 'prechangegroup = hg --traceback tip' >> to/.hg/hgrc | ||
Bryan O'Sullivan
|
r16619 | $ echo 'pretxnchangegroup = hg --traceback tip' >> to/.hg/hgrc | ||
$ echo a >> to/a | ||||
$ hg --cwd to ci -Ama | ||||
adding a | ||||
$ hg clone to from | ||||
updating to branch default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo aa >> from/a | ||||
$ hg --cwd from ci -mb | ||||
$ hg --cwd from push | ||||
Matt Harbison
|
r35394 | pushing to $TESTTMP/to | ||
Bryan O'Sullivan
|
r16619 | searching for changes | ||
Durham Goode
|
r26859 | changeset: 0:cb9a9f314b8b | ||
tag: tip | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: a | ||||
Bryan O'Sullivan
|
r16619 | adding changesets | ||
adding manifests | ||||
adding file changes | ||||
changeset: 1:9836a07b9b9d | ||||
tag: tip | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: b | ||||
r43167 | added 1 changesets with 1 changes to 1 files | |||
Durham Goode
|
r27924 | |||
pretxnclose hook failure should abort the transaction | ||||
$ hg init txnfailure | ||||
$ cd txnfailure | ||||
$ touch a && hg commit -Aqm a | ||||
$ cat >> .hg/hgrc <<EOF | ||||
> [hooks] | ||||
> pretxnclose.error = exit 1 | ||||
> EOF | ||||
$ hg strip -r 0 --config extensions.strip= | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
saved backup bundle to * (glob) | ||||
transaction abort! | ||||
rollback completed | ||||
Martin von Zweigbergk
|
r29954 | strip failed, backup bundle stored in * (glob) | ||
Durham Goode
|
r27924 | abort: pretxnclose.error hook exited with status 1 | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Durham Goode
|
r27924 | $ hg recover | ||
no interrupted transaction available | ||||
[1] | ||||
Pierre-Yves David
|
r28938 | $ cd .. | ||
FUJIWARA Katsunori
|
r31054 | check whether HG_PENDING makes pending changes only in related | ||
repositories visible to an external hook. | ||||
(emulate a transaction running concurrently by copied | ||||
.hg/store/00changelog.i.a in subsequent test) | ||||
$ cat > $TESTTMP/savepending.sh <<EOF | ||||
> cp .hg/store/00changelog.i.a .hg/store/00changelog.i.a.saved | ||||
> exit 1 # to avoid adding new revision for subsequent tests | ||||
> EOF | ||||
$ cd a | ||||
$ hg tip -q | ||||
4:539e4b31b6dc | ||||
$ hg --config hooks.pretxnclose="sh $TESTTMP/savepending.sh" commit -m "invisible" | ||||
transaction abort! | ||||
rollback completed | ||||
abort: pretxnclose hook exited with status 1 | ||||
Martin von Zweigbergk
|
r47145 | [40] | ||
FUJIWARA Katsunori
|
r31054 | $ cp .hg/store/00changelog.i.a.saved .hg/store/00changelog.i.a | ||
(check (in)visibility of new changeset while transaction running in | ||||
repo) | ||||
$ cat > $TESTTMP/checkpending.sh <<EOF | ||||
> echo '@a' | ||||
Matt Harbison
|
r31767 | > hg -R "$TESTTMP/a" tip -q | ||
FUJIWARA Katsunori
|
r31054 | > echo '@a/nested' | ||
Matt Harbison
|
r31767 | > hg -R "$TESTTMP/a/nested" tip -q | ||
FUJIWARA Katsunori
|
r31054 | > exit 1 # to avoid adding new revision for subsequent tests | ||
> EOF | ||||
$ hg init nested | ||||
$ cd nested | ||||
$ echo a > a | ||||
$ hg add a | ||||
$ hg --config hooks.pretxnclose="sh $TESTTMP/checkpending.sh" commit -m '#0' | ||||
@a | ||||
4:539e4b31b6dc | ||||
@a/nested | ||||
0:bf5e395ced2c | ||||
transaction abort! | ||||
rollback completed | ||||
abort: pretxnclose hook exited with status 1 | ||||
Martin von Zweigbergk
|
r47145 | [40] | ||
FUJIWARA Katsunori
|
r31054 | |||
Pierre-Yves David
|
r28938 | Hook from untrusted hgrc are reported as failure | ||
================================================ | ||||
$ cat << EOF > $TESTTMP/untrusted.py | ||||
> from mercurial import scmutil, util | ||||
> def uisetup(ui): | ||||
> class untrustedui(ui.__class__): | ||||
> def _trusted(self, fp, f): | ||||
Gregory Szorc
|
r36126 | > if util.normpath(fp.name).endswith(b'untrusted/.hg/hgrc'): | ||
Pierre-Yves David
|
r28938 | > return False | ||
> return super(untrustedui, self)._trusted(fp, f) | ||||
> ui.__class__ = untrustedui | ||||
> EOF | ||||
$ cat << EOF >> $HGRCPATH | ||||
> [extensions] | ||||
> untrusted=$TESTTMP/untrusted.py | ||||
> EOF | ||||
$ hg init untrusted | ||||
$ cd untrusted | ||||
Non-blocking hook | ||||
----------------- | ||||
$ cat << EOF >> .hg/hgrc | ||||
> [hooks] | ||||
> txnclose.testing=echo txnclose hook called | ||||
> EOF | ||||
$ touch a && hg commit -Aqm a | ||||
Pierre-Yves David
|
r31743 | warning: untrusted hook txnclose.testing not executed | ||
Pierre-Yves David
|
r28938 | $ hg log | ||
changeset: 0:3903775176ed | ||||
tag: tip | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: a | ||||
Non-blocking hook | ||||
----------------- | ||||
$ cat << EOF >> .hg/hgrc | ||||
> [hooks] | ||||
> pretxnclose.testing=echo pre-txnclose hook called | ||||
> EOF | ||||
$ touch b && hg commit -Aqm a | ||||
transaction abort! | ||||
rollback completed | ||||
Pierre-Yves David
|
r31743 | abort: untrusted hook pretxnclose.testing not executed | ||
Pierre-Yves David
|
r28938 | (see 'hg help config.trusted') | ||
Martin von Zweigbergk
|
r47145 | [40] | ||
Pierre-Yves David
|
r28938 | $ hg log | ||
changeset: 0:3903775176ed | ||||
tag: tip | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: a | ||||
r47241 | ||||
unsetup the test | ||||
---------------- | ||||
# touch the file to unconfuse chg with a diffrent mtime | ||||
$ sleep 1 | ||||
$ touch $TESTTMP/untrusted.py | ||||
$ cat << EOF >> $HGRCPATH | ||||
> [extensions] | ||||
> untrusted=! | ||||
> EOF | ||||
HGPLAIN setting in hooks | ||||
======================== | ||||
$ cat << EOF >> .hg/hgrc | ||||
> [hooks] | ||||
r47242 | > pre-version.testing-default=echo '### default ###' plain: \${HGPLAIN:-'<unset>'} | |||
> pre-version.testing-yes=echo '### yes #######' plain: \${HGPLAIN:-'<unset>'} | ||||
> pre-version.testing-yes:run-with-plain=yes | ||||
> pre-version.testing-no=echo '### no ########' plain: \${HGPLAIN:-'<unset>'} | ||||
> pre-version.testing-no:run-with-plain=no | ||||
r47243 | > pre-version.testing-auto=echo '### auto ######' plain: \${HGPLAIN:-'<unset>'} | |||
> pre-version.testing-auto:run-with-plain=auto | ||||
r47241 | > EOF | |||
$ (unset HGPLAIN; hg version --quiet) | ||||
### default ### plain: 1 | ||||
r47242 | ### yes ####### plain: 1 | |||
### no ######## plain: <unset> | ||||
r47243 | ### auto ###### plain: <unset> | |||
r47241 | Mercurial Distributed SCM (*) (glob) | |||
$ HGPLAIN=1 hg version --quiet | ||||
### default ### plain: 1 | ||||
r47242 | ### yes ####### plain: 1 | |||
### no ######## plain: <unset> | ||||
r47243 | ### auto ###### plain: 1 | |||
r47241 | Mercurial Distributed SCM (*) (glob) | |||