mirror of
https://github.com/facebook/sapling.git
synced 2024-10-09 16:31:02 +03:00
effa0da8de
Summary: The helper could be used in individual tests to enable chg if chg exists. This allows us to have more precise control on what tests to use chg instead of using a global flag in run-tests.py. This makes certain tests containing many hg commands much faster. For example, `test-revset.t` took 99 seconds before: % ./run-tests.py test-revset.t --time . # Ran 1 tests, 0 skipped, 0 failed. # Producing time report start end cuser csys real Test 0.000 99.990 86.410 12.000 99.990 test-revset.t And 10 seconds after: % ./run-tests.py test-revset.t --time . # Ran 1 tests, 0 skipped, 0 failed. # Producing time report start end cuser csys real Test 0.000 10.080 0.380 0.130 10.080 test-revset.t Also enable it for some other tests. Note the whitelist is not complete. We probably want to whitelist more tests in the future. The feature could be opted out by deleting `contrib/chg/chg`. Reviewed By: phillco Differential Revision: D6767036 fbshipit-source-id: 8220cf408aa198d5d8e2ca5127ca60e2070d3444
199 lines
3.4 KiB
Perl
199 lines
3.4 KiB
Perl
$ . helpers-usechg.sh
|
|
|
|
Issue835: qpush fails immediately when patching a missing file, but
|
|
remaining added files are still created empty which will trick a
|
|
future qrefresh.
|
|
|
|
$ 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
|
|
(use '--prefix' to apply patch relative to the current directory)
|
|
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 directory
|
|
errors during apply, please fix and qrefresh 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
|
|
|
|
Test missing renamed file
|
|
|
|
$ hg qpop
|
|
popping changeb
|
|
patch queue now empty
|
|
$ hg up -qC 0
|
|
$ echo a > a
|
|
$ hg mv b bb
|
|
$ $PYTHON ../writelines.py bb 2 'b\n' 10 'a\n' 2 'c\n'
|
|
$ 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)
|
|
patch failed, rejects left in working directory
|
|
errors during apply, please fix and qrefresh changebb
|
|
[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
|
|
|
|
$ 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
|
|
(use '--prefix' to apply patch relative to the current directory)
|
|
1 out of 1 hunks FAILED -- saving rejects to file b.rej
|
|
patch failed, unable to continue (try -v)
|
|
patch failed, rejects left in working directory
|
|
errors during apply, please fix and qrefresh 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 ..
|
|
|