##// END OF EJS Templates
phabricator: warn if unable to amend, instead of aborting after posting...
phabricator: warn if unable to amend, instead of aborting after posting There was a divergence in behavior here between obsolete and strip based amending. I first noticed the abort when testing outside of the test harness, but then had trouble recreating it here after reverting the code changes. It turns out, strip based amend was successfully amending the public commit after it was posted! It looks like the protection is in the `commit --amend` command, not in the underlying code that it calls. I considered doing a preflight check and aborting. But the locks are only acquired at the end, if amending, and this is too large a section of code to be wrapped in a maybe-it's-held-or-not context manager for my tastes. Additionally, some people do post-push reviews, and amending is the default behavior, so they shouldn't see a misleading error message. The lack of a 'Differential Revision' entry in the commit message breaks a {phabreview} test, so it had to be partially conditionalized.

File last commit:

r38081:fc3cca40 default
r41198:0101a35d default
Show More
test-bugzilla.t
104 lines | 2.9 KiB | text/troff | Tads3Lexer
Yuya Nishihara
bugzilla: do not load style file if template is specified (BC)...
r28950 mock bugzilla driver for testing template output:
$ cat <<EOF > bzmock.py
> from __future__ import absolute_import
> from mercurial import extensions
Boris Feld
configitems: register the 'bugzilla.mocklog' config
r33432 > from mercurial import registrar
Yuya Nishihara
bugzilla: do not load style file if template is specified (BC)...
r28950 >
Boris Feld
configitems: register the 'bugzilla.mocklog' config
r33432 > configtable = {}
> configitem = registrar.configitem(configtable)
>
Pulkit Goyal
py3: add b'' prefixes in tests/test-bugzilla.t...
r38081 > configitem(b'bugzilla', b'mocklog',
Boris Feld
configitems: register the 'bugzilla.mocklog' config
r33432 > default=None,
> )
Yuya Nishihara
bugzilla: do not load style file if template is specified (BC)...
r28950 > def extsetup(ui):
Pulkit Goyal
py3: add b'' prefixes in tests/test-bugzilla.t...
r38081 > bugzilla = extensions.find(b'bugzilla')
Yuya Nishihara
bugzilla: do not load style file if template is specified (BC)...
r28950 > class bzmock(bugzilla.bzaccess):
> def __init__(self, ui):
> super(bzmock, self).__init__(ui)
Pulkit Goyal
py3: add b'' prefixes in tests/test-bugzilla.t...
r38081 > self._logfile = ui.config(b'bugzilla', b'mocklog')
Yuya Nishihara
bugzilla: do not load style file if template is specified (BC)...
r28950 > def updatebug(self, bugid, newstate, text, committer):
> with open(self._logfile, 'a') as f:
> f.write('update bugid=%r, newstate=%r, committer=%r\n'
> % (bugid, newstate, committer))
> f.write('----\n' + text + '\n----\n')
> def notify(self, bugs, committer):
> with open(self._logfile, 'a') as f:
> f.write('notify bugs=%r, committer=%r\n'
> % (bugs, committer))
Pulkit Goyal
py3: add b'' prefixes in tests/test-bugzilla.t...
r38081 > bugzilla.bugzilla._versions[b'mock'] = bzmock
Yuya Nishihara
bugzilla: do not load style file if template is specified (BC)...
r28950 > EOF
set up mock repository:
$ hg init mockremote
$ cat <<EOF > mockremote/.hg/hgrc
> [extensions]
> bugzilla =
> bzmock = $TESTTMP/bzmock.py
>
> [bugzilla]
> version = mock
> mocklog = $TESTTMP/bzmock.log
>
> [hooks]
> incoming.bugzilla = python:hgext.bugzilla.hook
>
> [web]
> baseurl=http://example.org/hg
>
> %include $TESTTMP/bzstyle.hgrc
> EOF
$ hg clone -q mockremote mocklocal
push with default template:
$ echo '[bugzilla]' > bzstyle.hgrc
$ echo foo > mocklocal/foo
$ hg ci -R mocklocal -Aqm 'Fixes bug 123'
$ hg -R mocklocal push -q
$ cat bzmock.log && rm bzmock.log
update bugid=123, newstate={}, committer='test'
----
Matt Harbison
tests: remove (glob) annotations that were only for '\' matches...
r35394 changeset 7875a8342c6f in repo $TESTTMP/mockremote refers to bug 123.
Yuya Nishihara
bugzilla: do not load style file if template is specified (BC)...
r28950 details:
Fixes bug 123
----
notify bugs={123: {}}, committer='test'
push with style:
$ cat <<EOF > bzstyle.map
> changeset = "{node|short} refers to bug {bug}."
> EOF
$ echo "style = $TESTTMP/bzstyle.map" >> bzstyle.hgrc
$ echo foo >> mocklocal/foo
$ hg ci -R mocklocal -qm 'Fixes bug 456'
$ hg -R mocklocal push -q
$ cat bzmock.log && rm bzmock.log
update bugid=456, newstate={}, committer='test'
----
2808b172464b refers to bug 456.
----
notify bugs={456: {}}, committer='test'
push with template (overrides style):
$ cat <<EOF >> bzstyle.hgrc
> template = Changeset {node|short} in {root|basename}.
> {hgweb}/rev/{node|short}\n
> {desc}
> EOF
$ echo foo >> mocklocal/foo
$ hg ci -R mocklocal -qm 'Fixes bug 789'
$ hg -R mocklocal push -q
$ cat bzmock.log && rm bzmock.log
update bugid=789, newstate={}, committer='test'
----
Changeset a770f3e409f2 in mockremote.
http://example.org/hg/rev/a770f3e409f2
Fixes bug 789
----
notify bugs={789: {}}, committer='test'