test-mq-missingfiles.t
149 lines
| 2.5 KiB
| text/troff
|
Tads3Lexer
/ tests / test-mq-missingfiles.t
Adrian Buehlmann
|
r12324 | |||
Martin Geisler
|
r12399 | Issue835: qpush fails immediately when patching a missing file, but | ||
remaining added files are still created empty which will trick a | ||||
future qrefresh. | ||||
Adrian Buehlmann
|
r12324 | |||
$ cat > writelines.py <<EOF | ||||
> import sys | ||||
> path = sys.argv[1] | ||||
> args = sys.argv[2:] | ||||
> assert (len(args) % 2) == 0 | ||||
> | ||||
> f = file(path, 'wb') | ||||
> for i in xrange(len(args)/2): | ||||
> count, s = args[2*i:2*i+2] | ||||
> count = int(count) | ||||
> s = s.decode('string_escape') | ||||
> f.write(s*count) | ||||
> f.close() | ||||
> EOF | ||||
$ echo "[extensions]" >> $HGRCPATH | ||||
$ echo "mq=" >> $HGRCPATH | ||||
$ hg init normal | ||||
$ cd normal | ||||
$ python ../writelines.py b 10 'a\n' | ||||
$ hg ci -Am addb | ||||
adding b | ||||
$ echo a > a | ||||
$ python ../writelines.py b 2 'b\n' 10 'a\n' 2 'c\n' | ||||
$ echo c > c | ||||
$ hg add a c | ||||
$ hg qnew -f changeb | ||||
$ hg qpop | ||||
popping changeb | ||||
patch queue now empty | ||||
$ hg rm b | ||||
$ hg ci -Am rmb | ||||
Push patch with missing target: | ||||
$ hg qpush | ||||
applying changeb | ||||
unable to find 'b' for patching | ||||
2 out of 2 hunks FAILED -- saving rejects to file b.rej | ||||
patch failed, unable to continue (try -v) | ||||
patch failed, rejects left in working dir | ||||
errors during apply, please fix and refresh changeb | ||||
[2] | ||||
Display added files: | ||||
$ cat a | ||||
a | ||||
$ cat c | ||||
c | ||||
Display rejections: | ||||
$ cat b.rej | ||||
--- b | ||||
+++ b | ||||
@@ -1,3 +1,5 @@ | ||||
+b | ||||
+b | ||||
a | ||||
a | ||||
a | ||||
@@ -8,3 +10,5 @@ | ||||
a | ||||
a | ||||
a | ||||
+c | ||||
+c | ||||
$ cd .. | ||||
$ echo "[diff]" >> $HGRCPATH | ||||
$ echo "git=1" >> $HGRCPATH | ||||
$ hg init git | ||||
$ cd git | ||||
$ python ../writelines.py b 1 '\x00' | ||||
$ hg ci -Am addb | ||||
adding b | ||||
$ echo a > a | ||||
$ python ../writelines.py b 1 '\x01' 1 '\x00' | ||||
$ echo c > c | ||||
$ hg add a c | ||||
$ hg qnew -f changeb | ||||
$ hg qpop | ||||
popping changeb | ||||
patch queue now empty | ||||
$ hg rm b | ||||
$ hg ci -Am rmb | ||||
Push git patch with missing target: | ||||
$ hg qpush | ||||
applying changeb | ||||
unable to find 'b' for patching | ||||
1 out of 1 hunks FAILED -- saving rejects to file b.rej | ||||
patch failed, unable to continue (try -v) | ||||
b: No such file or directory | ||||
patch failed, rejects left in working dir | ||||
errors during apply, please fix and refresh changeb | ||||
[2] | ||||
$ hg st | ||||
? b.rej | ||||
Display added files: | ||||
$ cat a | ||||
a | ||||
$ cat c | ||||
c | ||||
Display rejections: | ||||
$ cat b.rej | ||||
--- b | ||||
+++ b | ||||
GIT binary patch | ||||
literal 2 | ||||
Jc${No0000400IC2 | ||||
$ cd .. | ||||
Test push creating directory during git copy or rename: | ||||
$ hg init missingdir | ||||
$ cd missingdir | ||||
$ echo a > a | ||||
$ hg ci -Am adda | ||||
adding a | ||||
$ mkdir d | ||||
$ hg copy a d/a2 | ||||
$ hg mv a d/a | ||||
$ hg qnew -g -f patch | ||||
$ hg qpop | ||||
popping patch | ||||
patch queue now empty | ||||
$ hg qpush | ||||
applying patch | ||||
now at: patch | ||||
$ cd .. | ||||