Show More
test-mq-qpush-fail.t
471 lines
| 9.5 KiB
| text/troff
|
Tads3Lexer
/ tests / test-mq-qpush-fail.t
Matt Mackall
|
r12467 | Test that qpush cleans things up if it doesn't complete | ||
$ echo "[extensions]" >> $HGRCPATH | ||||
$ echo "mq=" >> $HGRCPATH | ||||
$ hg init repo | ||||
$ cd repo | ||||
$ echo foo > foo | ||||
$ hg ci -Am 'add foo' | ||||
adding foo | ||||
$ touch untracked-file | ||||
$ echo 'syntax: glob' > .hgignore | ||||
$ echo '.hgignore' >> .hgignore | ||||
$ hg qinit | ||||
test qpush on empty series | ||||
$ hg qpush | ||||
no patches in series | ||||
$ hg qnew patch1 | ||||
$ echo >> foo | ||||
$ hg qrefresh -m 'patch 1' | ||||
$ hg qnew patch2 | ||||
$ echo bar > bar | ||||
$ hg add bar | ||||
$ hg qrefresh -m 'patch 2' | ||||
Mads Kiilerich
|
r22545 | $ hg qnew --config 'mq.plain=true' -U bad-patch | ||
Matt Mackall
|
r12467 | $ echo >> foo | ||
$ hg qrefresh | ||||
$ hg qpop -a | ||||
popping bad-patch | ||||
popping patch2 | ||||
popping patch1 | ||||
patch queue now empty | ||||
Matt Harbison
|
r39743 | $ "$PYTHON" -c 'import sys; getattr(sys.stdout, "buffer", sys.stdout).write(b"\xe9\n")' > message | ||
Matt Mackall
|
r12467 | $ cat .hg/patches/bad-patch >> message | ||
$ mv message .hg/patches/bad-patch | ||||
FUJIWARA Katsunori
|
r24992 | $ cat > $TESTTMP/wrapplayback.py <<EOF | ||
> import os | ||||
> from mercurial import extensions, transaction | ||||
> def wrapplayback(orig, | ||||
> journal, report, opener, vfsmap, entries, backupentries, | ||||
FUJIWARA Katsunori
|
r33278 | > unlink=True, checkambigfiles=None): | ||
> orig(journal, report, opener, vfsmap, entries, backupentries, unlink, | ||||
> checkambigfiles) | ||||
FUJIWARA Katsunori
|
r24992 | > # Touching files truncated at "transaction.abort" causes | ||
> # forcible re-loading invalidated filecache properties | ||||
> # (including repo.changelog) | ||||
> for f, o, _ignore in entries: | ||||
> if o or not unlink: | ||||
> os.utime(opener.join(f), (0.0, 0.0)) | ||||
> def extsetup(ui): | ||||
> extensions.wrapfunction(transaction, '_playback', wrapplayback) | ||||
> EOF | ||||
$ hg qpush -a --config extensions.wrapplayback=$TESTTMP/wrapplayback.py && echo 'qpush succeeded?!' | ||||
Matt Mackall
|
r12467 | applying patch1 | ||
applying patch2 | ||||
applying bad-patch | ||||
transaction abort! | ||||
rollback completed | ||||
Matt Mackall
|
r26654 | cleaning up working directory... | ||
reverting foo | ||||
done | ||||
Mads Kiilerich
|
r12942 | abort: decoding near '\xe9': 'ascii' codec can't decode byte 0xe9 in position 0: ordinal not in range(128)! (esc) | ||
Matt Mackall
|
r12467 | [255] | ||
$ hg parents | ||||
changeset: 0:bbd179dfa0a7 | ||||
tag: tip | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: add foo | ||||
Matt Mackall
|
r13508 | test corrupt status file | ||
$ hg qpush | ||||
applying patch1 | ||||
now at: patch1 | ||||
$ cp .hg/patches/status .hg/patches/status.orig | ||||
$ hg qpop | ||||
popping patch1 | ||||
patch queue now empty | ||||
$ cp .hg/patches/status.orig .hg/patches/status | ||||
$ hg qpush | ||||
abort: working directory revision is not qtip | ||||
[255] | ||||
$ rm .hg/patches/status .hg/patches/status.orig | ||||
Matt Mackall
|
r12467 | bar should be gone; other unknown/ignored files should still be around | ||
$ hg status -A | ||||
? untracked-file | ||||
I .hgignore | ||||
C foo | ||||
preparing qpush of a missing patch | ||||
$ hg qpop -a | ||||
no patches applied | ||||
$ hg qpush | ||||
applying patch1 | ||||
now at: patch1 | ||||
$ rm .hg/patches/patch2 | ||||
now we expect the push to fail, but it should NOT complain about patch1 | ||||
$ hg qpush | ||||
applying patch2 | ||||
unable to read patch2 | ||||
now at: patch1 | ||||
[1] | ||||
preparing qpush of missing patch with no patch applied | ||||
$ hg qpop -a | ||||
popping patch1 | ||||
patch queue now empty | ||||
$ rm .hg/patches/patch1 | ||||
qpush should fail the same way as below | ||||
$ hg qpush | ||||
applying patch1 | ||||
unable to read patch1 | ||||
[1] | ||||
Afuna
|
r13369 | |||
Test qpush to a patch below the currently applied patch. | ||||
$ hg qq -c guardedseriesorder | ||||
$ hg qnew a | ||||
$ hg qguard +block | ||||
$ hg qnew b | ||||
$ hg qnew c | ||||
$ hg qpop -a | ||||
popping c | ||||
popping b | ||||
popping a | ||||
patch queue now empty | ||||
try to push and pop while a is guarded | ||||
$ hg qpush a | ||||
Martin Geisler
|
r14464 | cannot push 'a' - guarded by '+block' | ||
Afuna
|
r13369 | [1] | ||
$ hg qpush -a | ||||
applying b | ||||
patch b is empty | ||||
applying c | ||||
patch c is empty | ||||
now at: c | ||||
now try it when a is unguarded, and we're at the top of the queue | ||||
FUJIWARA Katsunori
|
r22453 | |||
$ hg qapplied -v | ||||
0 G a | ||||
1 A b | ||||
2 A c | ||||
Afuna
|
r13369 | $ hg qsel block | ||
$ hg qpush b | ||||
abort: cannot push to a previous patch: b | ||||
[255] | ||||
$ hg qpush a | ||||
abort: cannot push to a previous patch: a | ||||
[255] | ||||
and now we try it one more time with a unguarded, while we're not at the top of the queue | ||||
$ hg qpop b | ||||
popping c | ||||
now at: b | ||||
$ hg qpush a | ||||
abort: cannot push to a previous patch: a | ||||
[255] | ||||
Patrick Mezard
|
r16633 | test qpop --force and backup files | ||
$ hg qpop -a | ||||
popping b | ||||
patch queue now empty | ||||
$ hg qq --create force | ||||
$ echo a > a | ||||
$ echo b > b | ||||
$ echo c > c | ||||
$ hg ci -Am add a b c | ||||
$ echo a >> a | ||||
$ hg rm b | ||||
$ hg rm c | ||||
$ hg qnew p1 | ||||
$ echo a >> a | ||||
$ echo bb > b | ||||
$ hg add b | ||||
$ echo cc > c | ||||
$ hg add c | ||||
$ hg qpop --force --verbose | ||||
saving current version of a as a.orig | ||||
saving current version of b as b.orig | ||||
saving current version of c as c.orig | ||||
popping p1 | ||||
patch queue now empty | ||||
$ hg st | ||||
? a.orig | ||||
? b.orig | ||||
? c.orig | ||||
? untracked-file | ||||
$ cat a.orig | ||||
a | ||||
a | ||||
a | ||||
$ cat b.orig | ||||
bb | ||||
$ cat c.orig | ||||
cc | ||||
Patrick Mezard
|
r16634 | |||
Patrick Mezard
|
r16635 | test qpop --force --no-backup | ||
$ hg qpush | ||||
applying p1 | ||||
now at: p1 | ||||
$ rm a.orig | ||||
$ echo a >> a | ||||
$ hg qpop --force --no-backup --verbose | ||||
popping p1 | ||||
patch queue now empty | ||||
$ test -f a.orig && echo 'error: backup with --no-backup' | ||||
[1] | ||||
Patrick Mezard
|
r16733 | test qpop --keep-changes | ||
Patrick Mezard
|
r16653 | |||
$ hg qpush | ||||
applying p1 | ||||
now at: p1 | ||||
Patrick Mezard
|
r16733 | $ hg qpop --keep-changes --force | ||
abort: cannot use both --force and --keep-changes | ||||
Patrick Mezard
|
r16653 | [255] | ||
$ echo a >> a | ||||
Patrick Mezard
|
r16733 | $ hg qpop --keep-changes | ||
timeless@mozdev.org
|
r26780 | abort: local changes found, qrefresh first | ||
Patrick Mezard
|
r16653 | [255] | ||
$ hg revert -qa a | ||||
$ rm a | ||||
Patrick Mezard
|
r16733 | $ hg qpop --keep-changes | ||
timeless@mozdev.org
|
r26780 | abort: local changes found, qrefresh first | ||
Patrick Mezard
|
r16653 | [255] | ||
$ hg rm -A a | ||||
Patrick Mezard
|
r16733 | $ hg qpop --keep-changes | ||
timeless@mozdev.org
|
r26780 | abort: local changes found, qrefresh first | ||
Patrick Mezard
|
r16653 | [255] | ||
$ hg revert -qa a | ||||
$ echo b > b | ||||
$ hg add b | ||||
Patrick Mezard
|
r16733 | $ hg qpop --keep-changes | ||
timeless@mozdev.org
|
r26780 | abort: local changes found, qrefresh first | ||
Patrick Mezard
|
r16653 | [255] | ||
$ hg forget b | ||||
$ echo d > d | ||||
$ hg add d | ||||
Patrick Mezard
|
r16733 | $ hg qpop --keep-changes | ||
Patrick Mezard
|
r16653 | popping p1 | ||
patch queue now empty | ||||
$ hg forget d | ||||
$ rm d | ||||
Patrick Mezard
|
r16634 | test qpush --force and backup files | ||
$ echo a >> a | ||||
$ hg qnew p2 | ||||
$ echo b >> b | ||||
$ echo d > d | ||||
$ echo e > e | ||||
$ hg add d e | ||||
$ hg rm c | ||||
$ hg qnew p3 | ||||
$ hg qpop -a | ||||
popping p3 | ||||
popping p2 | ||||
patch queue now empty | ||||
$ echo a >> a | ||||
$ echo b1 >> b | ||||
$ echo d1 > d | ||||
$ hg add d | ||||
$ echo e1 > e | ||||
$ hg qpush -a --force --verbose | ||||
applying p2 | ||||
saving current version of a as a.orig | ||||
patching file a | ||||
Mads Kiilerich
|
r23749 | committing files: | ||
Patrick Mezard
|
r16634 | a | ||
Mads Kiilerich
|
r23749 | committing manifest | ||
committing changelog | ||||
Patrick Mezard
|
r16634 | applying p3 | ||
saving current version of b as b.orig | ||||
saving current version of d as d.orig | ||||
patching file b | ||||
patching file c | ||||
patching file d | ||||
file d already exists | ||||
1 out of 1 hunks FAILED -- saving rejects to file d.rej | ||||
patching file e | ||||
file e already exists | ||||
1 out of 1 hunks FAILED -- saving rejects to file e.rej | ||||
patch failed to apply | ||||
Mads Kiilerich
|
r23749 | committing files: | ||
Patrick Mezard
|
r16634 | b | ||
Mads Kiilerich
|
r23749 | committing manifest | ||
committing changelog | ||||
Yuya Nishihara
|
r24365 | patch failed, rejects left in working directory | ||
timeless@mozdev.org
|
r26780 | errors during apply, please fix and qrefresh p3 | ||
Patrick Mezard
|
r16634 | [2] | ||
$ cat a.orig | ||||
a | ||||
a | ||||
$ cat b.orig | ||||
b | ||||
b1 | ||||
$ cat d.orig | ||||
d1 | ||||
Patrick Mezard
|
r16635 | |||
test qpush --force --no-backup | ||||
$ hg revert -qa | ||||
$ hg qpop -a | ||||
popping p3 | ||||
popping p2 | ||||
patch queue now empty | ||||
$ echo a >> a | ||||
$ rm a.orig | ||||
$ hg qpush --force --no-backup --verbose | ||||
applying p2 | ||||
patching file a | ||||
Mads Kiilerich
|
r23749 | committing files: | ||
Patrick Mezard
|
r16635 | a | ||
Mads Kiilerich
|
r23749 | committing manifest | ||
committing changelog | ||||
Patrick Mezard
|
r16635 | now at: p2 | ||
$ test -f a.orig && echo 'error: backup with --no-backup' | ||||
[1] | ||||
test qgoto --force --no-backup | ||||
$ hg qpop | ||||
popping p2 | ||||
patch queue now empty | ||||
$ echo a >> a | ||||
$ hg qgoto --force --no-backup p2 --verbose | ||||
applying p2 | ||||
patching file a | ||||
Mads Kiilerich
|
r23749 | committing files: | ||
Patrick Mezard
|
r16635 | a | ||
Mads Kiilerich
|
r23749 | committing manifest | ||
committing changelog | ||||
Patrick Mezard
|
r16635 | now at: p2 | ||
$ test -f a.orig && echo 'error: backup with --no-backup' | ||||
[1] | ||||
Patrick Mezard
|
r16654 | |||
Patrick Mezard
|
r16733 | test qpush --keep-changes | ||
Patrick Mezard
|
r16654 | |||
Patrick Mezard
|
r16733 | $ hg qpush --keep-changes --force | ||
abort: cannot use both --force and --keep-changes | ||||
Patrick Mezard
|
r16654 | [255] | ||
Patrick Mezard
|
r16733 | $ hg qpush --keep-changes --exact | ||
abort: cannot use --exact and --keep-changes together | ||||
Patrick Mezard
|
r16654 | [255] | ||
$ echo b >> b | ||||
Patrick Mezard
|
r16733 | $ hg qpush --keep-changes | ||
Patrick Mezard
|
r16654 | applying p3 | ||
Matt Mackall
|
r24826 | abort: conflicting local changes found | ||
(did you forget to qrefresh?) | ||||
[255] | ||||
Patrick Mezard
|
r16654 | $ rm b | ||
Patrick Mezard
|
r16733 | $ hg qpush --keep-changes | ||
Patrick Mezard
|
r16654 | applying p3 | ||
Matt Mackall
|
r24826 | abort: conflicting local changes found | ||
(did you forget to qrefresh?) | ||||
[255] | ||||
Patrick Mezard
|
r16654 | $ hg rm -A b | ||
Patrick Mezard
|
r16733 | $ hg qpush --keep-changes | ||
Patrick Mezard
|
r16654 | applying p3 | ||
Matt Mackall
|
r24826 | abort: conflicting local changes found | ||
(did you forget to qrefresh?) | ||||
[255] | ||||
Patrick Mezard
|
r16654 | $ hg revert -aq b | ||
$ echo d > d | ||||
$ hg add d | ||||
Patrick Mezard
|
r16733 | $ hg qpush --keep-changes | ||
Patrick Mezard
|
r16654 | applying p3 | ||
Matt Mackall
|
r24826 | abort: conflicting local changes found | ||
(did you forget to qrefresh?) | ||||
[255] | ||||
Patrick Mezard
|
r16654 | $ hg forget d | ||
$ rm d | ||||
$ hg qpop | ||||
popping p2 | ||||
patch queue now empty | ||||
$ echo b >> b | ||||
Patrick Mezard
|
r16733 | $ hg qpush -a --keep-changes | ||
Patrick Mezard
|
r16654 | applying p2 | ||
applying p3 | ||||
Matt Mackall
|
r24826 | abort: conflicting local changes found | ||
(did you forget to qrefresh?) | ||||
[255] | ||||
Patrick Mezard
|
r16654 | $ hg qtop | ||
p2 | ||||
$ hg parents --template "{rev} {desc}\n" | ||||
2 imported patch p2 | ||||
$ hg st b | ||||
M b | ||||
$ cat b | ||||
b | ||||
b | ||||
Patrick Mezard
|
r16655 | |||
Patrick Mezard
|
r16733 | test qgoto --keep-changes | ||
Patrick Mezard
|
r16655 | |||
$ hg revert -aq b | ||||
$ rm e | ||||
Patrick Mezard
|
r16733 | $ hg qgoto --keep-changes --force p3 | ||
abort: cannot use both --force and --keep-changes | ||||
Patrick Mezard
|
r16655 | [255] | ||
$ echo a >> a | ||||
Patrick Mezard
|
r16733 | $ hg qgoto --keep-changes p3 | ||
Patrick Mezard
|
r16655 | applying p3 | ||
now at: p3 | ||||
$ hg st a | ||||
M a | ||||
Patrick Mezard
|
r16733 | $ hg qgoto --keep-changes p2 | ||
Patrick Mezard
|
r16655 | popping p3 | ||
now at: p2 | ||||
$ hg st a | ||||
M a | ||||
Patrick Mezard
|
r16656 | |||
Patrick Mezard
|
r16733 | test mq.keepchanges setting | ||
Patrick Mezard
|
r16656 | |||
Patrick Mezard
|
r16733 | $ hg --config mq.keepchanges=1 qpush | ||
Patrick Mezard
|
r16656 | applying p3 | ||
now at: p3 | ||||
$ hg st a | ||||
M a | ||||
Patrick Mezard
|
r16733 | $ hg --config mq.keepchanges=1 qpop | ||
Patrick Mezard
|
r16656 | popping p3 | ||
now at: p2 | ||||
$ hg st a | ||||
M a | ||||
Patrick Mezard
|
r16733 | $ hg --config mq.keepchanges=1 qgoto p3 | ||
Patrick Mezard
|
r16656 | applying p3 | ||
now at: p3 | ||||
$ hg st a | ||||
M a | ||||
$ echo b >> b | ||||
Christian Delahousse
|
r26943 | $ hg --config mq.keepchanges=1 qpop --force --config 'ui.origbackuppath=.hg/origbackups' | ||
Patrick Mezard
|
r16656 | popping p3 | ||
now at: p2 | ||||
$ hg st b | ||||
Patrick Mezard
|
r16733 | $ hg --config mq.keepchanges=1 qpush --exact | ||
timeless@mozdev.org
|
r26780 | abort: local changes found, qrefresh first | ||
Patrick Mezard
|
r16656 | [255] | ||
$ hg revert -qa a | ||||
$ hg qpop | ||||
popping p2 | ||||
patch queue now empty | ||||
$ echo a >> a | ||||
Patrick Mezard
|
r16733 | $ hg --config mq.keepchanges=1 qpush --force | ||
Patrick Mezard
|
r16656 | applying p2 | ||
now at: p2 | ||||
$ hg st a | ||||
Mads Kiilerich
|
r16913 | |||
Christian Delahousse
|
r26943 | test previous qpop (with --force and --config) saved .orig files to where user | ||
wants them | ||||
$ ls .hg/origbackups | ||||
Mark Thomas
|
r34145 | b | ||
Christian Delahousse
|
r26943 | $ rm -rf .hg/origbackups | ||
Mads Kiilerich
|
r16913 | $ cd .. | ||