##// END OF EJS Templates
run-tests: mechanism to report exceptions during test execution...
run-tests: mechanism to report exceptions during test execution Sometimes when running tests you introduce a ton of exceptions. The most extreme example of this is running Mercurial with Python 3, which currently spews thousands of exceptions when running the test harness. This commit adds an opt-in feature to run-tests.py to aggregate exceptions encountered by `hg` when running tests. When --exceptions is used, the test harness enables the "logexceptions" extension in the test environment. This extension wraps the Mercurial function to handle exceptions and writes information about the exception to a random filename in a directory defined by the test harness via an environment variable. At the end of the test harness, these files are parsed, aggregated, and a list of all unique Mercurial frames triggering exceptions is printed in order of frequency. This feature is intended to aid Python 3 development. I've only really tested it on Python 3. There is no shortage of improvements that could be made. e.g. we could write a separate file containing the exception report - maybe even an HTML report. We also don't capture which tests demonstrate the exceptions, so there's no turnkey way to test whether a code change made an exception disappear. Perfect is the enemy of good. I think the current patch is useful enough to land. Whoever uses it can send patches to imprve its usefulness. Differential Revision: https://phab.mercurial-scm.org/D1477

File last commit:

r34691:54efbbec default
r35191:bd8875b6 default
Show More
test-extdata.t
97 lines | 2.3 KiB | text/troff | Tads3Lexer
Yuya Nishihara
revset: add experimental support for extdata...
r34458 $ hg init repo
$ cd repo
Yuya Nishihara
extdata: ignore ambiguous identifier as well
r34460 $ for n in 0 1 2 3 4 5 6 7 8 9 10 11; do
Yuya Nishihara
revset: add experimental support for extdata...
r34458 > echo $n > $n
> hg ci -qAm $n
> done
test revset support
$ cat <<'EOF' >> .hg/hgrc
> [extdata]
> filedata = file:extdata.txt
Yuya Nishihara
templater: add experimental support for extdata...
r34459 > notes = notes.txt
Yuya Nishihara
revset: add experimental support for extdata...
r34458 > shelldata = shell:cat extdata.txt | grep 2
Yuya Nishihara
extdata: show debug message if external command exits with non-zero status...
r34543 > emptygrep = shell:cat extdata.txt | grep empty
Yuya Nishihara
revset: add experimental support for extdata...
r34458 > EOF
$ cat <<'EOF' > extdata.txt
Yuya Nishihara
templater: add experimental support for extdata...
r34459 > 2 another comment on 2
Yuya Nishihara
revset: add experimental support for extdata...
r34458 > 3
> EOF
Yuya Nishihara
templater: add experimental support for extdata...
r34459 $ cat <<'EOF' > notes.txt
> f6ed this change is great!
> e834 this is buggy :(
> 0625 first post
> bogusnode gives no error
Yuya Nishihara
extdata: ignore ambiguous identifier as well
r34460 > a ambiguous node gives no error
Yuya Nishihara
templater: add experimental support for extdata...
r34459 > EOF
Yuya Nishihara
revset: add experimental support for extdata...
r34458
$ hg log -qr "extdata(filedata)"
2:f6ed99a58333
3:9de260b1e88e
$ hg log -qr "extdata(shelldata)"
2:f6ed99a58333
test weight of extdata() revset
$ hg debugrevspec -p optimized "extdata(filedata) & 3"
* optimized:
(andsmally
(func
(symbol 'extdata')
(symbol 'filedata'))
(symbol '3'))
3
Yuya Nishihara
extdata: show debug message if external command exits with non-zero status...
r34543 test non-zero exit of shell command
$ hg log -qr "extdata(emptygrep)"
$ hg log -qr "extdata(emptygrep)" --debug
extdata command 'cat extdata.txt | grep empty' exited with status * (glob)
Yuya Nishihara
revset: add experimental support for extdata...
r34458 test bad extdata() revset source
$ hg log -qr "extdata()"
hg: parse error: extdata takes at least 1 string argument
[255]
$ hg log -qr "extdata(unknown)"
abort: unknown extdata source 'unknown'
[255]
Yuya Nishihara
templater: add experimental support for extdata...
r34459 test template support:
$ hg log -r:3 -T "{node|short}{if(extdata('notes'), ' # {extdata('notes')}')}\n"
06254b906311 # first post
e8342c9a2ed1 # this is buggy :(
f6ed99a58333 # this change is great!
9de260b1e88e
test template cache:
$ hg log -r:3 -T '{rev} "{extdata("notes")}" "{extdata("shelldata")}"\n'
0 "first post" ""
1 "this is buggy :(" ""
2 "this change is great!" "another comment on 2"
3 "" ""
test bad extdata() template source
$ hg log -T "{extdata()}\n"
hg: parse error: extdata expects one argument
[255]
$ hg log -T "{extdata('unknown')}\n"
abort: unknown extdata source 'unknown'
[255]
Yuya Nishihara
revset: add experimental support for extdata...
r34458 we don't fix up relative file URLs, but we do run shell commands in repo root
$ mkdir sub
$ cd sub
$ hg log -qr "extdata(filedata)"
Matt Harbison
test-extdata: conditonalize error message for Windows
r34691 abort: error: The system cannot find the file specified (windows !)
abort: error: No such file or directory (no-windows !)
Yuya Nishihara
revset: add experimental support for extdata...
r34458 [255]
$ hg log -qr "extdata(shelldata)"
2:f6ed99a58333
$ cd ..