test-mq-missingfiles.t
201 lines
| 3.6 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 | ||||
Gregory Szorc
|
r41359 | > if sys.version_info[0] >= 3: | ||
> encode = lambda x: x.encode('utf-8').decode('unicode_escape').encode('utf-8') | ||||
> else: | ||||
> encode = lambda x: x.decode('string_escape') | ||||
Adrian Buehlmann
|
r12324 | > path = sys.argv[1] | ||
> args = sys.argv[2:] | ||||
> assert (len(args) % 2) == 0 | ||||
> | ||||
Pulkit Goyal
|
r36039 | > f = open(path, 'wb') | ||
Pulkit Goyal
|
r36408 | > for i in range(len(args) // 2): | ||
Adrian Buehlmann
|
r12324 | > count, s = args[2*i:2*i+2] | ||
> count = int(count) | ||||
Gregory Szorc
|
r41359 | > s = encode(s) | ||
Adrian Buehlmann
|
r12324 | > f.write(s*count) | ||
> f.close() | ||||
> EOF | ||||
$ echo "[extensions]" >> $HGRCPATH | ||||
$ echo "mq=" >> $HGRCPATH | ||||
$ hg init normal | ||||
$ cd normal | ||||
Matt Harbison
|
r39743 | $ "$PYTHON" ../writelines.py b 10 'a\n' | ||
Adrian Buehlmann
|
r12324 | $ hg ci -Am addb | ||
adding b | ||||
$ echo a > a | ||||
Matt Harbison
|
r39743 | $ "$PYTHON" ../writelines.py b 2 'b\n' 10 'a\n' 2 'c\n' | ||
Adrian Buehlmann
|
r12324 | $ 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 | ||||
liscju
|
r29900 | (use '--prefix' to apply patch relative to the current directory) | ||
Adrian Buehlmann
|
r12324 | 2 out of 2 hunks FAILED -- saving rejects to file b.rej | ||
patch failed, unable to continue (try -v) | ||||
Yuya Nishihara
|
r24365 | patch failed, rejects left in working directory | ||
timeless@mozdev.org
|
r26780 | errors during apply, please fix and qrefresh changeb | ||
Adrian Buehlmann
|
r12324 | [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 | ||||
Patrick Mezard
|
r16813 | Test missing renamed file | ||
$ hg qpop | ||||
popping changeb | ||||
patch queue now empty | ||||
$ hg up -qC 0 | ||||
$ echo a > a | ||||
$ hg mv b bb | ||||
Matt Harbison
|
r39743 | $ "$PYTHON" ../writelines.py bb 2 'b\n' 10 'a\n' 2 'c\n' | ||
Patrick Mezard
|
r16813 | $ echo c > c | ||
$ hg add a c | ||||
$ hg qnew changebb | ||||
$ hg qpop | ||||
popping changebb | ||||
patch queue now empty | ||||
$ hg up -qC 1 | ||||
$ hg qpush | ||||
applying changebb | ||||
patching file bb | ||||
Hunk #1 FAILED at 0 | ||||
Hunk #2 FAILED at 7 | ||||
2 out of 2 hunks FAILED -- saving rejects to file bb.rej | ||||
b not tracked! | ||||
patch failed, unable to continue (try -v) | ||||
Yuya Nishihara
|
r24365 | patch failed, rejects left in working directory | ||
timeless@mozdev.org
|
r26780 | errors during apply, please fix and qrefresh changebb | ||
Patrick Mezard
|
r16813 | [2] | ||
$ cat a | ||||
a | ||||
$ cat c | ||||
c | ||||
$ cat bb.rej | ||||
--- bb | ||||
+++ bb | ||||
@@ -1,3 +1,5 @@ | ||||
+b | ||||
+b | ||||
a | ||||
a | ||||
a | ||||
@@ -8,3 +10,5 @@ | ||||
a | ||||
a | ||||
a | ||||
+c | ||||
+c | ||||
Adrian Buehlmann
|
r12324 | $ cd .. | ||
$ echo "[diff]" >> $HGRCPATH | ||||
$ echo "git=1" >> $HGRCPATH | ||||
$ hg init git | ||||
$ cd git | ||||
Matt Harbison
|
r39743 | $ "$PYTHON" ../writelines.py b 1 '\x00' | ||
Adrian Buehlmann
|
r12324 | $ hg ci -Am addb | ||
adding b | ||||
$ echo a > a | ||||
Matt Harbison
|
r39743 | $ "$PYTHON" ../writelines.py b 1 '\x01' 1 '\x00' | ||
Adrian Buehlmann
|
r12324 | $ 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 | ||||
liscju
|
r29900 | (use '--prefix' to apply patch relative to the current directory) | ||
Adrian Buehlmann
|
r12324 | 1 out of 1 hunks FAILED -- saving rejects to file b.rej | ||
patch failed, unable to continue (try -v) | ||||
Yuya Nishihara
|
r24365 | patch failed, rejects left in working directory | ||
timeless@mozdev.org
|
r26780 | errors during apply, please fix and qrefresh changeb | ||
Adrian Buehlmann
|
r12324 | [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 .. | ||||