# HG changeset patch # User Jun Wu # Date 2017-06-25 04:01:28 # Node ID be3584712b202523b76ac44034755e7c11e5e333 # Parent a49ab7f5e7e765a94a1dfab2ee3b1da695789eb6 test-rebase: add a test showing rebasestate left behind The test demonstrates that .hg/rebasestate is left behind if "rebase" was called inside an existing transaction. diff --git a/tests/test-rebase-scenario-global.t b/tests/test-rebase-scenario-global.t --- a/tests/test-rebase-scenario-global.t +++ b/tests/test-rebase-scenario-global.t @@ -1,6 +1,7 @@ $ cat >> $HGRCPATH < [extensions] > rebase= + > drawdag=$TESTDIR/drawdag.py > > [phases] > publish=False @@ -915,3 +916,42 @@ Testing from upper head date: Thu Jan 01 00:00:00 1970 +0000 summary: second source with subdir +Testing rebase being called inside another transaction + + $ cd $TESTTMP + $ hg init tr-state + $ cd tr-state + $ cat > $TESTTMP/wraprebase.py < from __future__ import absolute_import + > from mercurial import extensions + > def _rebase(orig, ui, repo, *args, **kwargs): + > with repo.wlock(): + > with repo.lock(): + > with repo.transaction('wrappedrebase'): + > return orig(ui, repo, *args, **kwargs) + > def wraprebase(loaded): + > assert loaded + > rebasemod = extensions.find('rebase') + > extensions.wrapcommand(rebasemod.cmdtable, 'rebase', _rebase) + > def extsetup(ui): + > extensions.afterloaded('rebase', wraprebase) + > EOF + + $ cat >> .hg/hgrc < [extensions] + > wraprebase=$TESTTMP/wraprebase.py + > [experimental] + > evolution=all + > EOF + + $ hg debugdrawdag <<'EOS' + > B C + > |/ + > A + > EOS + + $ hg rebase -s C -d B + rebasing 2:dc0947a82db8 "C" (C tip) + + $ [ -f .hg/rebasestate ] && echo 'WRONG: rebasestate should not exist' + WRONG: rebasestate should not exist