[Request] [++- ] D8575: hooklib: fix detection of successors for changeset_obsoleted
joerg.sonnenberger (Joerg Sonnenberger)
phabricator at mercurial-scm.org
Thu May 21 17:07:36 UTC 2020
joerg.sonnenberger created this revision.
Herald added a reviewer: hg-reviewers.
Herald added a subscriber: mercurial-patches.
REVISION SUMMARY
Provide a hook for obsutil.getobsolete to be used with either a
transaction or the changes item of the transaction, since hooks only
have access to the latter. Use that to find the correct list of
revisions with obsmarkers, even new ones, and then filter out revisions
with known successors.
Move the processing from pretxnclose to txnclose as the transaction
access itself is no longer necessary. This is more in line with notify
and ensures that sanity checks can abort the transaction first.
REPOSITORY
rHG Mercurial
BRANCH
stable
REVISION DETAIL
https://phab.mercurial-scm.org/D8575
AFFECTED FILES
hgext/hooklib/changeset_obsoleted.py
mercurial/obsutil.py
tests/test-hooklib-changeset_obsoleted.t
CHANGE DETAILS
diff --git a/tests/test-hooklib-changeset_obsoleted.t b/tests/test-hooklib-changeset_obsoleted.t
--- a/tests/test-hooklib-changeset_obsoleted.t
+++ b/tests/test-hooklib-changeset_obsoleted.t
@@ -24,7 +24,7 @@
$ cat <<EOF >> b/.hg/hgrc
> [hooks]
> incoming.notify = python:hgext.notify.hook
- > pretxnclose.changeset_obsoleted = python:hgext.hooklib.changeset_obsoleted.hook
+ > txnclose.changeset_obsoleted = python:hgext.hooklib.changeset_obsoleted.hook
> EOF
$ hg --cwd b pull ../a | "$PYTHON" $TESTDIR/unwrap-message-id.py
pulling from ../a
@@ -72,6 +72,8 @@
pushing to ../b
searching for changes
no changes found
+ 1 new obsolescence markers
+ obsoleted 1 changesets
Subject: changeset abandoned
In-reply-to: <hg.81c297828fd2d5afaadf2775a6a71b74143b6451dfaac09fac939e9107a50d01 at example.com>
Message-Id: <hg.d6329e9481594f0f3c8a84362b3511318bfbce50748ab1123f909eb6fbcab018 at example.com>
@@ -80,5 +82,33 @@
To: baz at example.com
This changeset has been abandoned.
+
+Check that known changesets with known successors do not result in a mail.
+
+ $ hg init c
+ $ hg init d
+ $ cat <<EOF >> d/.hg/hgrc
+ > [hooks]
+ > incoming.notify = python:hgext.notify.hook
+ > txnclose.changeset_obsoleted = python:hgext.hooklib.changeset_obsoleted.hook
+ > EOF
+ $ hg --cwd c debugbuilddag '.:parent.*parent'
+ $ hg --cwd c push ../d -r 1
+ pushing to ../d
+ searching for changes
+ adding changesets
+ adding manifests
+ adding file changes
+ added 2 changesets with 0 changes to 0 files
+ $ hg --cwd c debugobsolete $(hg --cwd c log -T '{node}' -r 1) $(hg --cwd c log -T '{node}' -r 2)
1 new obsolescence markers
obsoleted 1 changesets
+ $ hg --cwd c push ../d | "$PYTHON" $TESTDIR/unwrap-message-id.py
+ pushing to ../d
+ searching for changes
+ adding changesets
+ adding manifests
+ adding file changes
+ added 1 changesets with 0 changes to 0 files (+1 heads)
+ 1 new obsolescence markers
+ obsoleted 1 changesets
diff --git a/mercurial/obsutil.py b/mercurial/obsutil.py
--- a/mercurial/obsutil.py
+++ b/mercurial/obsutil.py
@@ -481,14 +481,21 @@
return effects
-def getobsoleted(repo, tr):
- """return the set of pre-existing revisions obsoleted by a transaction"""
+def getobsoleted(repo, tr=None, changes=None):
+ """return the set of pre-existing revisions obsoleted by a transaction
+
+ Either the transaction or changes item of the transaction (for hooks)
+ must be provided, but not both.
+ """
+ assert (tr is None) != (changes is None)
torev = repo.unfiltered().changelog.index.get_rev
phase = repo._phasecache.phase
succsmarkers = repo.obsstore.successors.get
public = phases.public
- addedmarkers = tr.changes[b'obsmarkers']
- origrepolen = tr.changes[b'origrepolen']
+ if changes is None:
+ changes = tr.changes
+ addedmarkers = changes[b'obsmarkers']
+ origrepolen = changes[b'origrepolen']
seenrevs = set()
obsoleted = set()
for mark in addedmarkers:
diff --git a/hgext/hooklib/changeset_obsoleted.py b/hgext/hooklib/changeset_obsoleted.py
--- a/hgext/hooklib/changeset_obsoleted.py
+++ b/hgext/hooklib/changeset_obsoleted.py
@@ -122,10 +122,18 @@
)
+def has_successor(repo, rev):
+ return any(
+ r for r in obsutil.allsuccessors(repo.obsstore, [rev]) if r != rev
+ )
+
+
def hook(ui, repo, hooktype, node=None, **kwargs):
- if hooktype != b"pretxnclose":
+ if hooktype != b"txnclose":
raise error.Abort(
_(b'Unsupported hook type %r') % pycompat.bytestr(hooktype)
)
- for rev in obsutil.getobsoleted(repo, repo.currenttransaction()):
- _report_commit(ui, repo, repo.unfiltered()[rev])
+ for rev in obsutil.getobsoleted(repo, changes=kwargs['changes']):
+ ctx = repo.unfiltered()[rev]
+ if not has_successor(repo, ctx.node()):
+ _report_commit(ui, repo, ctx)
To: joerg.sonnenberger, #hg-reviewers
Cc: mercurial-patches, mercurial-devel
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mercurial-scm.org/pipermail/mercurial-patches/attachments/20200521/c50aac31/attachment-0001.html>
More information about the Mercurial-patches
mailing list