test-run-tests.t
438 lines
| 10.8 KiB
| text/troff
|
Tads3Lexer
/ tests / test-run-tests.t
Pierre-Yves David
|
r21732 | This file tests the behavior of run-tests.py itself. | ||
Smoke test | ||||
============ | ||||
$ $TESTDIR/run-tests.py | ||||
# Ran 0 tests, 0 skipped, 0 warned, 0 failed. | ||||
Pierre-Yves David
|
r21734 | |||
a succesful test | ||||
======================= | ||||
$ cat > test-success.t << EOF | ||||
> $ echo babar | ||||
> babar | ||||
Augie Fackler
|
r21995 | > $ echo xyzzy | ||
> xyzzy | ||||
Pierre-Yves David
|
r21734 | > EOF | ||
$ $TESTDIR/run-tests.py --with-hg=`which hg` | ||||
. | ||||
# Ran 1 tests, 0 skipped, 0 warned, 0 failed. | ||||
Pierre-Yves David
|
r21738 | |||
failing test | ||||
================== | ||||
$ cat > test-failure.t << EOF | ||||
> $ echo babar | ||||
> rataxes | ||||
Augie Fackler
|
r21995 | > This is a noop statement so that | ||
> this test is still more bytes than success. | ||||
Pierre-Yves David
|
r21738 | > EOF | ||
$ $TESTDIR/run-tests.py --with-hg=`which hg` | ||||
Matt Harbison
|
r23348 | --- $TESTTMP/test-failure.t | ||
+++ $TESTTMP/test-failure.t.err | ||||
Augie Fackler
|
r21995 | @@ -1,4 +1,4 @@ | ||
Pierre-Yves David
|
r21738 | $ echo babar | ||
- rataxes | ||||
+ babar | ||||
Augie Fackler
|
r21995 | This is a noop statement so that | ||
this test is still more bytes than success. | ||||
Pierre-Yves David
|
r21738 | |||
ERROR: test-failure.t output changed | ||||
!. | ||||
Failed test-failure.t: output changed | ||||
# Ran 2 tests, 0 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
Augie Fackler
|
r22044 | test --xunit support | ||
$ $TESTDIR/run-tests.py --with-hg=`which hg` --xunit=xunit.xml | ||||
--- $TESTTMP/test-failure.t | ||||
+++ $TESTTMP/test-failure.t.err | ||||
@@ -1,4 +1,4 @@ | ||||
$ echo babar | ||||
- rataxes | ||||
+ babar | ||||
This is a noop statement so that | ||||
this test is still more bytes than success. | ||||
ERROR: test-failure.t output changed | ||||
!. | ||||
Failed test-failure.t: output changed | ||||
# Ran 2 tests, 0 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
$ cat xunit.xml | ||||
<?xml version="1.0" encoding="utf-8"?> | ||||
<testsuite errors="0" failures="1" name="run-tests" skipped="0" tests="2"> | ||||
<testcase name="test-success.t" time="*"/> (glob) | ||||
<testcase name="test-failure.t" time="*"> (glob) | ||||
<![CDATA[--- $TESTTMP/test-failure.t | ||||
+++ $TESTTMP/test-failure.t.err | ||||
@@ -1,4 +1,4 @@ | ||||
$ echo babar | ||||
- rataxes | ||||
+ babar | ||||
This is a noop statement so that | ||||
this test is still more bytes than success. | ||||
]]> </testcase> | ||||
</testsuite> | ||||
Pierre-Yves David
|
r21741 | |||
test for --retest | ||||
==================== | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` --retest | ||||
Matt Harbison
|
r23348 | --- $TESTTMP/test-failure.t | ||
+++ $TESTTMP/test-failure.t.err | ||||
Augie Fackler
|
r21995 | @@ -1,4 +1,4 @@ | ||
Pierre-Yves David
|
r21741 | $ echo babar | ||
- rataxes | ||||
+ babar | ||||
Augie Fackler
|
r21995 | This is a noop statement so that | ||
this test is still more bytes than success. | ||||
Pierre-Yves David
|
r21741 | |||
ERROR: test-failure.t output changed | ||||
! | ||||
Failed test-failure.t: output changed | ||||
Augie Fackler
|
r21997 | # Ran 2 tests, 1 skipped, 0 warned, 1 failed. | ||
Pierre-Yves David
|
r21741 | python hash seed: * (glob) | ||
[1] | ||||
Pierre-Yves David
|
r21742 | |||
Selecting Tests To Run | ||||
====================== | ||||
successful | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` test-success.t | ||||
. | ||||
# Ran 1 tests, 0 skipped, 0 warned, 0 failed. | ||||
Augie Fackler
|
r21997 | success w/ keyword | ||
$ $TESTDIR/run-tests.py --with-hg=`which hg` -k xyzzy | ||||
Matt Mackall
|
r22107 | . | ||
# Ran 2 tests, 1 skipped, 0 warned, 0 failed. | ||||
Augie Fackler
|
r21997 | |||
Pierre-Yves David
|
r21742 | failed | ||
$ $TESTDIR/run-tests.py --with-hg=`which hg` test-failure.t | ||||
Matt Harbison
|
r23348 | --- $TESTTMP/test-failure.t | ||
+++ $TESTTMP/test-failure.t.err | ||||
Augie Fackler
|
r21995 | @@ -1,4 +1,4 @@ | ||
Pierre-Yves David
|
r21742 | $ echo babar | ||
- rataxes | ||||
+ babar | ||||
Augie Fackler
|
r21995 | This is a noop statement so that | ||
this test is still more bytes than success. | ||||
Pierre-Yves David
|
r21742 | |||
ERROR: test-failure.t output changed | ||||
! | ||||
Failed test-failure.t: output changed | ||||
# Ran 1 tests, 0 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
Pierre-Yves David
|
r21743 | |||
Augie Fackler
|
r21997 | failure w/ keyword | ||
$ $TESTDIR/run-tests.py --with-hg=`which hg` -k rataxes | ||||
Matt Mackall
|
r22107 | |||
Augie Fackler
|
r21997 | --- $TESTTMP/test-failure.t | ||
+++ $TESTTMP/test-failure.t.err | ||||
@@ -1,4 +1,4 @@ | ||||
$ echo babar | ||||
- rataxes | ||||
+ babar | ||||
This is a noop statement so that | ||||
this test is still more bytes than success. | ||||
ERROR: test-failure.t output changed | ||||
! | ||||
Failed test-failure.t: output changed | ||||
Matt Mackall
|
r22107 | # Ran 2 tests, 1 skipped, 0 warned, 1 failed. | ||
Augie Fackler
|
r21997 | python hash seed: * (glob) | ||
[1] | ||||
Augie Fackler
|
r22840 | Verify that when a process fails to start we show a useful message | ||
================================================================== | ||||
NOTE: there is currently a bug where this shows "2 failed" even though | ||||
it's actually the same test being reported for failure twice. | ||||
$ cat > test-serve-fail.t <<EOF | ||||
> $ echo 'abort: child process failed to start blah' | ||||
> EOF | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` test-serve-fail.t | ||||
ERROR: test-serve-fail.t output changed | ||||
! | ||||
ERROR: test-serve-fail.t output changed | ||||
! | ||||
Failed test-serve-fail.t: server failed to start (HGPORT=*) (glob) | ||||
Failed test-serve-fail.t: output changed | ||||
# Ran 1 tests, 0 skipped, 0 warned, 2 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
$ rm test-serve-fail.t | ||||
Pierre-Yves David
|
r21743 | Running In Debug Mode | ||
====================== | ||||
Matt Mackall
|
r22134 | $ $TESTDIR/run-tests.py --with-hg=`which hg` --debug 2>&1 | grep -v pwd | ||
Pierre-Yves David
|
r21743 | + echo SALT* 0 0 (glob) | ||
SALT* 0 0 (glob) | ||||
+ echo babar | ||||
babar | ||||
Augie Fackler
|
r21995 | + echo SALT* 4 0 (glob) | ||
SALT* 4 0 (glob) | ||||
Pierre-Yves David
|
r21743 | .+ echo SALT* 0 0 (glob) | ||
SALT* 0 0 (glob) | ||||
+ echo babar | ||||
babar | ||||
+ echo SALT* 2 0 (glob) | ||||
SALT* 2 0 (glob) | ||||
Augie Fackler
|
r21995 | + echo xyzzy | ||
xyzzy | ||||
+ echo SALT* 4 0 (glob) | ||||
SALT* 4 0 (glob) | ||||
Pierre-Yves David
|
r21743 | . | ||
# Ran 2 tests, 0 skipped, 0 warned, 0 failed. | ||||
Pierre-Yves David
|
r21744 | |||
Parallel runs | ||||
============== | ||||
(duplicate the failing test to get predictable output) | ||||
$ cp test-failure.t test-failure-copy.t | ||||
Matt Mackall
|
r23107 | $ $TESTDIR/run-tests.py --with-hg=`which hg` --jobs 2 test-failure*.t -n | ||
!! | ||||
Pierre-Yves David
|
r21744 | Failed test-failure*.t: output changed (glob) | ||
Failed test-failure*.t: output changed (glob) | ||||
# Ran 2 tests, 0 skipped, 0 warned, 2 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
Augie Fackler
|
r22838 | failures in parallel with --first should only print one failure | ||
>>> f = open('test-nothing.t', 'w') | ||||
>>> f.write('foo\n' * 1024) | ||||
>>> f.write(' $ sleep 1') | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` --jobs 2 --first | ||||
--- $TESTTMP/test-failure*.t (glob) | ||||
+++ $TESTTMP/test-failure*.t.err (glob) | ||||
@@ -1,4 +1,4 @@ | ||||
$ echo babar | ||||
- rataxes | ||||
+ babar | ||||
This is a noop statement so that | ||||
this test is still more bytes than success. | ||||
Failed test-failure*.t: output changed (glob) | ||||
# Ran 2 tests, 0 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
Pierre-Yves David
|
r21744 | (delete the duplicated test file) | ||
Augie Fackler
|
r22838 | $ rm test-failure-copy.t test-nothing.t | ||
Pierre-Yves David
|
r21744 | |||
Pierre-Yves David
|
r21755 | |||
Interactive run | ||||
=============== | ||||
(backup the failing test) | ||||
$ cp test-failure.t backup | ||||
Refuse the fix | ||||
$ echo 'n' | $TESTDIR/run-tests.py --with-hg=`which hg` -i | ||||
--- $TESTTMP/test-failure.t | ||||
+++ $TESTTMP/test-failure.t.err | ||||
Augie Fackler
|
r21995 | @@ -1,4 +1,4 @@ | ||
Pierre-Yves David
|
r21755 | $ echo babar | ||
- rataxes | ||||
+ babar | ||||
Augie Fackler
|
r21995 | This is a noop statement so that | ||
this test is still more bytes than success. | ||||
Matt Mackall
|
r21763 | Accept this change? [n] | ||
Pierre-Yves David
|
r21755 | ERROR: test-failure.t output changed | ||
Matt Mackall
|
r21763 | !. | ||
Pierre-Yves David
|
r21755 | Failed test-failure.t: output changed | ||
# Ran 2 tests, 0 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
$ cat test-failure.t | ||||
$ echo babar | ||||
rataxes | ||||
Augie Fackler
|
r21995 | This is a noop statement so that | ||
this test is still more bytes than success. | ||||
Pierre-Yves David
|
r21755 | |||
Gregory Szorc
|
r22361 | Interactive with custom view | ||
$ echo 'n' | $TESTDIR/run-tests.py --with-hg=`which hg` -i --view echo | ||||
Matt Harbison
|
r23348 | $TESTTMP/test-failure.t $TESTTMP/test-failure.t.err (glob) | ||
Gregory Szorc
|
r22361 | Accept this change? [n]* (glob) | ||
ERROR: test-failure.t output changed | ||||
!. | ||||
Failed test-failure.t: output changed | ||||
# Ran 2 tests, 0 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
Matt Mackall
|
r22108 | View the fix | ||
$ echo 'y' | $TESTDIR/run-tests.py --with-hg=`which hg` --view echo | ||||
Matt Harbison
|
r23348 | $TESTTMP/test-failure.t $TESTTMP/test-failure.t.err (glob) | ||
Matt Mackall
|
r22108 | |||
ERROR: test-failure.t output changed | ||||
!. | ||||
Failed test-failure.t: output changed | ||||
# Ran 2 tests, 0 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
Pierre-Yves David
|
r21755 | |||
Accept the fix | ||||
$ echo 'y' | $TESTDIR/run-tests.py --with-hg=`which hg` -i | ||||
--- $TESTTMP/test-failure.t | ||||
+++ $TESTTMP/test-failure.t.err | ||||
Augie Fackler
|
r21995 | @@ -1,4 +1,4 @@ | ||
Pierre-Yves David
|
r21755 | $ echo babar | ||
- rataxes | ||||
+ babar | ||||
Augie Fackler
|
r21995 | This is a noop statement so that | ||
this test is still more bytes than success. | ||||
Pierre-Yves David
|
r21755 | Accept this change? [n] .. | ||
# Ran 2 tests, 0 skipped, 0 warned, 0 failed. | ||||
$ cat test-failure.t | ||||
$ echo babar | ||||
babar | ||||
Augie Fackler
|
r21995 | This is a noop statement so that | ||
this test is still more bytes than success. | ||||
Pierre-Yves David
|
r21755 | |||
(reinstall) | ||||
$ mv backup test-failure.t | ||||
Pierre-Yves David
|
r21756 | |||
No Diff | ||||
=============== | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` --nodiff | ||||
!. | ||||
Failed test-failure.t: output changed | ||||
# Ran 2 tests, 0 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
anuraggoel
|
r21977 | |||
test for --time | ||||
================== | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` test-success.t --time | ||||
. | ||||
# Ran 1 tests, 0 skipped, 0 warned, 0 failed. | ||||
# Producing time report | ||||
cuser csys real Test | ||||
\s*[\d\.]{5} \s*[\d\.]{5} \s*[\d\.]{5} test-success.t (re) | ||||
test for --time with --job enabled | ||||
==================================== | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` test-success.t --time --jobs 2 | ||||
. | ||||
# Ran 1 tests, 0 skipped, 0 warned, 0 failed. | ||||
# Producing time report | ||||
cuser csys real Test | ||||
\s*[\d\.]{5} \s*[\d\.]{5} \s*[\d\.]{5} test-success.t (re) | ||||
Augie Fackler
|
r21996 | |||
Skips | ||||
================ | ||||
$ cat > test-skip.t <<EOF | ||||
> $ echo xyzzy | ||||
Matt Mackall
|
r22045 | > #require false | ||
Augie Fackler
|
r21996 | > EOF | ||
$ $TESTDIR/run-tests.py --with-hg=`which hg` --nodiff | ||||
!.s | ||||
Mads Kiilerich
|
r22292 | Skipped test-skip.t: skipped | ||
Augie Fackler
|
r21996 | Failed test-failure.t: output changed | ||
# Ran 2 tests, 1 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
Augie Fackler
|
r21997 | $ $TESTDIR/run-tests.py --with-hg=`which hg` --keyword xyzzy | ||
Matt Mackall
|
r22107 | .s | ||
Mads Kiilerich
|
r22292 | Skipped test-skip.t: skipped | ||
Matt Mackall
|
r22107 | # Ran 2 tests, 2 skipped, 0 warned, 0 failed. | ||
Augie Fackler
|
r21997 | |||
Augie Fackler
|
r22044 | Skips with xml | ||
$ $TESTDIR/run-tests.py --with-hg=`which hg` --keyword xyzzy \ | ||||
> --xunit=xunit.xml | ||||
Matt Mackall
|
r22107 | .s | ||
Mads Kiilerich
|
r22292 | Skipped test-skip.t: skipped | ||
Matt Mackall
|
r22107 | # Ran 2 tests, 2 skipped, 0 warned, 0 failed. | ||
Augie Fackler
|
r22044 | $ cat xunit.xml | ||
<?xml version="1.0" encoding="utf-8"?> | ||||
Matt Mackall
|
r22107 | <testsuite errors="0" failures="0" name="run-tests" skipped="2" tests="2"> | ||
Augie Fackler
|
r22044 | <testcase name="test-success.t" time="*"/> (glob) | ||
</testsuite> | ||||
Augie Fackler
|
r21997 | Missing skips or blacklisted skips don't count as executed: | ||
$ echo test-failure.t > blacklist | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` --blacklist=blacklist \ | ||||
> test-failure.t test-bogus.t | ||||
ss | ||||
Skipped test-bogus.t: Doesn't exist | ||||
Skipped test-failure.t: blacklisted | ||||
# Ran 0 tests, 2 skipped, 0 warned, 0 failed. | ||||
Pierre-Yves David
|
r22579 | #if json | ||
anuraggoel
|
r22391 | test for --json | ||
================== | ||||
$ $TESTDIR/run-tests.py --with-hg=`which hg` --json | ||||
--- $TESTTMP/test-failure.t | ||||
+++ $TESTTMP/test-failure.t.err | ||||
@@ -1,4 +1,4 @@ | ||||
$ echo babar | ||||
- rataxes | ||||
+ babar | ||||
This is a noop statement so that | ||||
this test is still more bytes than success. | ||||
ERROR: test-failure.t output changed | ||||
!.s | ||||
Skipped test-skip.t: skipped | ||||
Failed test-failure.t: output changed | ||||
# Ran 2 tests, 1 skipped, 0 warned, 1 failed. | ||||
python hash seed: * (glob) | ||||
[1] | ||||
$ cat report.json | ||||
testreport ={ | ||||
"test-failure.t": [\{] (re) | ||||
Augie Fackler
|
r23245 | "csys": "\s*[\d\.]{4,5}", ? (re) | ||
"cuser": "\s*[\d\.]{4,5}", ? (re) | ||||
"result": "failure", ? (re) | ||||
"time": "\s*[\d\.]{4,5}" (re) | ||||
}, ? (re) | ||||
anuraggoel
|
r22391 | "test-skip.t": { | ||
Augie Fackler
|
r23245 | "csys": "\s*[\d\.]{4,5}", ? (re) | ||
"cuser": "\s*[\d\.]{4,5}", ? (re) | ||||
"result": "skip", ? (re) | ||||
"time": "\s*[\d\.]{4,5}" (re) | ||||
}, ? (re) | ||||
anuraggoel
|
r22391 | "test-success.t": [\{] (re) | ||
Augie Fackler
|
r23245 | "csys": "\s*[\d\.]{4,5}", ? (re) | ||
"cuser": "\s*[\d\.]{4,5}", ? (re) | ||||
"result": "success", ? (re) | ||||
"time": "\s*[\d\.]{4,5}" (re) | ||||
anuraggoel
|
r22391 | } | ||
} (no-eol) | ||||
Pierre-Yves David
|
r22579 | |||
#endif | ||||