2016-10-25 21:10:47 +03:00
|
|
|
Set up test environment.
|
|
|
|
$ . $TESTDIR/require-ext.sh directaccess evolve inhibit
|
|
|
|
$ extpath=`dirname $TESTDIR`
|
|
|
|
$ cp $extpath/hgext3rd/fbamend.py $TESTTMP # use $TESTTMP substitution in message
|
|
|
|
$ cat >> $HGRCPATH << EOF
|
|
|
|
> [extensions]
|
|
|
|
> directaccess=
|
|
|
|
> evolve=
|
|
|
|
> fbamend=$TESTTMP/fbamend.py
|
|
|
|
> inhibit=
|
|
|
|
> rebase=
|
|
|
|
> strip=
|
2017-03-08 22:30:14 +03:00
|
|
|
> tweakdefaults=
|
2016-10-25 21:10:47 +03:00
|
|
|
> [experimental]
|
|
|
|
> evolution = createmarkers
|
2017-01-20 11:24:45 +03:00
|
|
|
> evolutioncommands = prev next split fold
|
2016-10-25 21:10:47 +03:00
|
|
|
> [fbamend]
|
|
|
|
> userestack=true
|
|
|
|
> EOF
|
|
|
|
$ mkcommit() {
|
|
|
|
> echo "$1" > "$1"
|
|
|
|
> hg add "$1"
|
|
|
|
> echo "add $1" > msg
|
|
|
|
> hg ci -l msg
|
|
|
|
> }
|
|
|
|
$ reset() {
|
|
|
|
> cd ..
|
|
|
|
> rm -rf userestack
|
|
|
|
> hg init userestack
|
|
|
|
> cd userestack
|
|
|
|
> }
|
|
|
|
$ showgraph() {
|
2017-03-08 22:30:14 +03:00
|
|
|
> hg log --graph -r '(::.)::' -T "{rev} {desc|firstline}" | sed \$d
|
2016-10-25 21:10:47 +03:00
|
|
|
> }
|
|
|
|
$ hg init userestack && cd userestack
|
|
|
|
|
|
|
|
Test that no preamend bookmark is created.
|
|
|
|
$ mkcommit a
|
|
|
|
$ mkcommit b
|
|
|
|
$ mkcommit c
|
|
|
|
$ mkcommit d
|
|
|
|
$ hg up 1
|
|
|
|
0 files updated, 0 files merged, 2 files removed, 0 files unresolved
|
|
|
|
$ hg amend -m "amended"
|
|
|
|
warning: the changeset's children were left behind
|
2017-01-09 22:09:02 +03:00
|
|
|
(use 'hg rebase --restack' (alias: 'hg restack') to rebase them)
|
2016-10-25 21:10:47 +03:00
|
|
|
$ hg book
|
|
|
|
no bookmarks set
|
|
|
|
|
|
|
|
Test hg amend --fixup.
|
|
|
|
$ showgraph
|
|
|
|
@ 4 amended
|
|
|
|
|
|
|
|
|
| o 3 add d
|
|
|
|
| |
|
|
|
|
| o 2 add c
|
|
|
|
| |
|
|
|
|
| o 1 add b
|
|
|
|
|/
|
|
|
|
o 0 add a
|
2017-03-08 22:30:14 +03:00
|
|
|
|
2016-10-25 21:10:47 +03:00
|
|
|
$ hg amend --fixup
|
2017-03-08 22:30:14 +03:00
|
|
|
rebasing 2:* "add c" (glob)
|
|
|
|
rebasing 3:* "add d" (glob)
|
2016-10-25 21:10:47 +03:00
|
|
|
$ showgraph
|
|
|
|
o 6 add d
|
|
|
|
|
|
|
|
|
o 5 add c
|
|
|
|
|
|
|
|
|
@ 4 amended
|
|
|
|
|
|
|
|
|
o 0 add a
|
2017-03-08 22:30:14 +03:00
|
|
|
|
|
|
|
Test that the operation field on the metadata is correctly set.
|
|
|
|
$ hg debugobsolete
|
|
|
|
[a-f0-9]* [a-f0-9]* 0 .* {'operation': 'amend', 'user': 'test'} (re)
|
|
|
|
[a-f0-9]* [a-f0-9]* 0 .* {'operation': 'rebase', 'user': 'test'} (re)
|
|
|
|
[a-f0-9]* [a-f0-9]* 0 .* {'operation': 'rebase', 'user': 'test'} (re)
|
2016-10-25 21:10:47 +03:00
|
|
|
|
|
|
|
Test hg amend --rebase
|
|
|
|
$ hg amend -m "amended again" --rebase
|
2017-03-08 22:30:14 +03:00
|
|
|
rebasing 5:* "add c" (glob)
|
|
|
|
rebasing 6:* "add d" (glob)
|
2016-10-25 21:10:47 +03:00
|
|
|
$ showgraph
|
|
|
|
o 9 add d
|
|
|
|
|
|
|
|
|
o 8 add c
|
|
|
|
|
|
|
|
|
@ 7 amended again
|
|
|
|
|
|
|
|
|
o 0 add a
|