[Updated] D10726: recover: only apply last journal record per file
joerg.sonnenberger (Joerg Sonnenberger)
phabricator at mercurial-scm.org
Tue May 18 18:48:39 UTC 2021
joerg.sonnenberger updated this revision to Diff 28081.
REPOSITORY
rHG Mercurial
CHANGES SINCE LAST UPDATE
https://phab.mercurial-scm.org/D10726?vs=28065&id=28081
BRANCH
default
CHANGES SINCE LAST ACTION
https://phab.mercurial-scm.org/D10726/new/
REVISION DETAIL
https://phab.mercurial-scm.org/D10726
AFFECTED FILES
mercurial/transaction.py
tests/test-transaction-rollback-on-revlog-split.t
CHANGE DETAILS
diff --git a/tests/test-transaction-rollback-on-revlog-split.t b/tests/test-transaction-rollback-on-revlog-split.t
--- a/tests/test-transaction-rollback-on-revlog-split.t
+++ b/tests/test-transaction-rollback-on-revlog-split.t
@@ -4,9 +4,9 @@
Helper extension to intercept renames.
$ cat > $TESTTMP/intercept_rename.py << EOF
- > from mercurial.extensions import wrapfunction
- > from mercurial.util import atomictempfile
- > import os, sys
+ > import os
+ > import sys
+ > from mercurial import extensions, util
>
> def extsetup(ui):
> def close(orig, *args, **kwargs):
@@ -14,7 +14,7 @@
> if path.endswith(b'/.hg/store/data/file.i'):
> os._exit(80)
> return orig(*args, **kwargs)
- > wrapfunction(atomictempfile, 'close', close)
+ > extensions.wrapfunction(util.atomictempfile, 'close', close)
> EOF
@@ -62,9 +62,32 @@
data/file.d 0
data/file.d 1046
data/file.i 128
+ $ hg recover
+ rolling back interrupted transaction
+ (verify step skipped, run `hg verify` to check your repository content)
+ $ f -s .hg/store/data/file*
+ .hg/store/data/file.d: size=1046
+ .hg/store/data/file.i: size=128
+ $ hg tip
+ changeset: 1:3ce491143aec
+ tag: tip
+ user: test
+ date: Thu Jan 01 00:00:00 1970 +0000
+ summary: _
+
+ $ hg verify
+ checking changesets
+ checking manifests
+ crosschecking files in changesets and manifests
+ checking files
+ warning: revlog 'data/file.d' not in fncache!
+ checked 2 changesets with 2 changes to 1 files
+ 1 warnings encountered!
+ hint: run "hg debugrebuildfncache" to recover from corrupt fncache
$ cd ..
-Now retry the same but intercept the rename of the index and check that
+
+Now retry the procedure but intercept the rename of the index and check that
the journal does not contain the new index size. This demonstrates the edge case
where the data file is left as garbage.
@@ -83,4 +106,65 @@
data/file.i 1174
data/file.d 0
data/file.d 1046
+
+ $ hg recover
+ rolling back interrupted transaction
+ (verify step skipped, run `hg verify` to check your repository content)
+ $ f -s .hg/store/data/file*
+ .hg/store/data/file.d: size=1046
+ .hg/store/data/file.i: size=1174
+ $ hg tip
+ changeset: 1:3ce491143aec
+ tag: tip
+ user: test
+ date: Thu Jan 01 00:00:00 1970 +0000
+ summary: _
+
+ $ hg verify
+ checking changesets
+ checking manifests
+ crosschecking files in changesets and manifests
+ checking files
+ checked 2 changesets with 2 changes to 1 files
$ cd ..
+
+
+Repeat the original test but let hg rollback the transaction.
+
+ $ hg clone -r 1 troffset-computation troffset-computation-copy-rb --config format.revlog-compression=none -q
+ $ cd troffset-computation-copy-rb
+ $ cat > .hg/hgrc <<EOF
+ > [hooks]
+ > pretxnchangegroup = false
+ > EOF
+ $ hg pull ../troffset-computation
+ pulling from ../troffset-computation
+ searching for changes
+ adding changesets
+ adding manifests
+ adding file changes
+ transaction abort!
+ rollback completed
+ abort: pretxnchangegroup hook exited with status 1
+ [40]
+ $ f -s .hg/store/data/file*
+ .hg/store/data/file.d: size=1046
+ .hg/store/data/file.i: size=128
+ $ hg tip
+ changeset: 1:3ce491143aec
+ tag: tip
+ user: test
+ date: Thu Jan 01 00:00:00 1970 +0000
+ summary: _
+
+ $ hg verify
+ checking changesets
+ checking manifests
+ crosschecking files in changesets and manifests
+ checking files
+ warning: revlog 'data/file.d' not in fncache!
+ checked 2 changesets with 2 changes to 1 files
+ 1 warnings encountered!
+ hint: run "hg debugrebuildfncache" to recover from corrupt fncache
+ $ cd ..
+
diff --git a/mercurial/transaction.py b/mercurial/transaction.py
--- a/mercurial/transaction.py
+++ b/mercurial/transaction.py
@@ -56,7 +56,7 @@
unlink=True,
checkambigfiles=None,
):
- for f, o in entries:
+ for f, o in sorted(dict(entries).items()):
if o or not unlink:
checkambig = checkambigfiles and (f, b'') in checkambigfiles
try:
To: joerg.sonnenberger, #hg-reviewers
Cc: mercurial-patches
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mercurial-scm.org/pipermail/mercurial-patches/attachments/20210518/4b8ce0f0/attachment-0002.html>
More information about the Mercurial-patches
mailing list