##// END OF EJS Templates
issue6528: add a config option to control the fixing on the fly...
issue6528: add a config option to control the fixing on the fly This will allow people who know to be safe to avoid any performance overhead (and other potential issue). Differential Revision: https://phab.mercurial-scm.org/D11271

File last commit:

r46507:fc4fb2f1 default
r48630:2813d406 5.9rc1 stable
Show More
test-extdata.t
120 lines | 2.9 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
Augie Fackler
extdata: demonstrate bad behavior when a subprocess emits garbage...
r42775 > badparse = shell:cat badparse.txt
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)"
Yuya Nishihara
extdata: abort if external command exits with non-zero status (BC)...
r35413 abort: extdata command 'cat extdata.txt | grep empty' failed: exited with status 1
[255]
Yuya Nishihara
extdata: show debug message if external command exits with non-zero status...
r34543
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
Martin von Zweigbergk
errors: use exit code 10 for parse errors...
r46507 [10]
Yuya Nishihara
revset: add experimental support for extdata...
r34458 $ hg log -qr "extdata(unknown)"
abort: unknown extdata source 'unknown'
[255]
Augie Fackler
extdata: demonstrate bad behavior when a subprocess emits garbage...
r42775 test a zero-exiting source that emits garbage to confuse the revset parser
$ cat > badparse.txt <<'EOF'
> +---------------------------------------+
> 9de260b1e88e
> EOF
Augie Fackler
extdata: avoid crashing inside subprocess when we get a revset parse error...
r42776 It might be nice if this error message mentioned where the bad string
came from (eg line X of extdata source S), but the important thing is
that we don't crash before we can print the parse error.
$ hg log -qr "extdata(badparse)"
hg: parse error at 0: not a prefix: +
(+---------------------------------------+
^ here)
Martin von Zweigbergk
errors: use exit code 10 for parse errors...
r46507 [10]
Augie Fackler
extdata: demonstrate bad behavior when a subprocess emits garbage...
r42775
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
Martin von Zweigbergk
errors: use exit code 10 for parse errors...
r46507 [10]
Yuya Nishihara
templater: add experimental support for extdata...
r34459 $ hg log -T "{extdata('unknown')}\n"
abort: unknown extdata source 'unknown'
[255]
Yuya Nishihara
templatefuncs: show hint if extdata source is evaluated to empty (issue5843)
r37950 $ hg log -T "{extdata(unknown)}\n"
hg: parse error: empty data source specified
(did you mean extdata('unknown')?)
Martin von Zweigbergk
errors: use exit code 10 for parse errors...
r46507 [10]
Yuya Nishihara
templatefuncs: show hint if extdata source is evaluated to empty (issue5843)
r37950 $ hg log -T "{extdata('{unknown}')}\n"
hg: parse error: empty data source specified
Martin von Zweigbergk
errors: use exit code 10 for parse errors...
r46507 [10]
Yuya Nishihara
templater: add experimental support for extdata...
r34459
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
tests: add a substitution for ENOENT/ERROR_FILE_NOT_FOUND messages...
r35230 abort: error: $ENOENT$
Martin von Zweigbergk
errors: set detailed exit code to 100 for some remote errors...
r46443 [100]
Yuya Nishihara
revset: add experimental support for extdata...
r34458 $ hg log -qr "extdata(shelldata)"
2:f6ed99a58333
$ cd ..