Mercurial > evolve
view tests/test-amend.t @ 269:6c6bb7a23bb5 0.1.0
stabilize: improve unstable selection heuristic
Without argument, stabilize was picking the first in:
"unstable() and ((suspended() or obsancestors(::.))::)"
which usually returned the "oldest" unstable revision in parent
predecessors descendants. This revision is interesting because it
usually gives "soft" merges but rebasing it left the working directory
on a remote branch, which was very confusing.
The new heuristic picks an unstable changeset which can be rebased on
top of the parent revision, or on top of one of its descendants
(selected in revision order). This has the advantage of selecting a
revision which can be rebased on the current subtree, and leave the
working directory in a more convenient location.
author | Patrick Mezard <patrick@mezard.eu> |
---|---|
date | Wed, 13 Jun 2012 18:28:10 +0200 |
parents | 24943df310d4 |
children | 87e4d1eec5e8 |
line wrap: on
line source
$ cat >> $HGRCPATH <<EOF > [defaults] > amend=-d "0 0" > [extensions] > hgext.rebase= > hgext.graphlog= > EOF $ echo "obsolete=$(echo $(dirname $TESTDIR))/hgext/obsolete.py" >> $HGRCPATH $ echo "evolve=$(echo $(dirname $TESTDIR))/hgext/evolve.py" >> $HGRCPATH $ glog() { > hg glog --template '{rev}@{branch}({phase}) {desc|firstline}\n' "$@" > } $ hg init repo $ cd repo $ echo a > a $ hg ci -Am adda adding a Test amend captures branches $ hg branch foo marked working directory as branch foo (branches are permanent and global, did you want a bookmark?) $ hg amend $ hg branch foo $ hg branches foo 2:a34b93d251e4 default 0:07f494440405 (inactive) $ glog @ 2@foo(draft) adda Test no-op $ hg amend abort: no updates found [255] $ glog @ 2@foo(draft) adda Test forcing the message to the same value, no intermediate revision. $ hg amend -m 'adda' abort: no updates found [255] $ glog @ 2@foo(draft) adda Test collapsing into an existing revision, no intermediate revision. $ echo a >> a $ hg ci -m changea $ echo a > a $ hg ci -m reseta $ hg amend --change 2 abort: no updates found [255] $ hg phase 2 2: draft $ glog @ 4@foo(draft) reseta | o 3@foo(draft) changea | o 2@foo(draft) adda Test collapsing into an existing rev, with an intermediate revision. $ hg branch --force default marked working directory as branch default (branches are permanent and global, did you want a bookmark?) $ hg ci -m resetbranch created new head $ hg branch --force foo marked working directory as branch foo (branches are permanent and global, did you want a bookmark?) $ hg amend --change 2 abort: no updates found [255] $ glog @ 6@foo(secret) amends a34b93d251e49c93d5685ebacad785c73a7e8605 | o 5@default(draft) resetbranch | o 4@foo(draft) reseta | o 3@foo(draft) changea | o 2@foo(draft) adda