##// END OF EJS Templates
bisect: avoid adding irrelevant revisions to bisect state...
bisect: avoid adding irrelevant revisions to bisect state When adding new revisions to the bisect state, it only makes sense to add information about revisions that are under consideration (i.e., those that are topologically between the known good and bad revisions). However, if the user passes in a revset (e.g., '!merge()' to exclude merge commits), hg will resolve the revset first and add all matching revisions to the bisect state (which in this case would likely be the majority of revisions in the repo). To avoid this, revisions should only be added to the bisect state if they are between the good and bad revisions (and therefore relevant to the bisection). -- Here are the results of some performance tests using the `mozilla-central` repo (since it is one of the largest freely-available hg repositories in the wild). These tests compare the performance of a locally-built `hg` before and after application of this series. Note that `--noupdate` is passed to avoid including update time (which should not vary across cases). Setup (run between each test): $ hg bisect --reset $ hg bisect --noupdate --bad 56c3ad4bde5c70714b784ccf15d099e0df0f5bde $ hg bisect --noupdate --good 57426696adaf08298af3027fa77486fee0633b13 Test using a revset that returns a very large number of revisions: $ time hg bisect --noupdate --skip '!merge()' > /dev/null Before: real 0m9.398s user 0m9.233s sys 0m0.120s After: real 0m1.513s user 0m1.425s sys 0m0.052s Test using a revset that is expensive to compute: $ time hg bisect --noupdate --skip 'desc("Bug")' > /dev/null Before: real 0m49.853s user 0m49.580s sys 0m0.243s After: real 0m4.120s user 0m4.036s sys 0m0.048s

File last commit:

r49800:55d13252 default
r50337:81623652 default
Show More
test-contrib-check-code.t
423 lines | 9.8 KiB | text/troff | Tads3Lexer
/ tests / test-contrib-check-code.t
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > correct.py <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > def toto(arg1, arg2):
> del arg2
> return (5 + 6, 9)
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
$ cat > wrong.py <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > def toto( arg1, arg2):
> del(arg2)
> return ( 5+6, 9)
Augie Fackler
contrib: enforce wrapping too-long lines with () instead of \...
r41927 > def badwrap():
> return 1 + \\
> 2
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
$ cat > quote.py <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > # let's use quote in comments
> (''' ( 4x5 )
> but """\\''' and finally''',
> """let's fool checkpatch""", '1+2',
> '"""', 42+1, """and
> ( 4-1 ) """, "( 1+1 )\" and ")
> a, '\\\\\\\\', "\\\\\\" x-2", "c-1"
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
$ cat > classstyle.py <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > class newstyle_class(object):
> pass
>
> class oldstyle_class:
> pass
>
> class empty():
> pass
>
> no_class = 1:
> pass
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 $ check_code="$TESTDIR"/../contrib/check-code.py
$ "$check_code" ./wrong.py ./correct.py ./quote.py ./classstyle.py
./wrong.py:1:
> def toto( arg1, arg2):
gratuitous whitespace in () or []
./wrong.py:2:
> del(arg2)
Python keyword is not a function
./wrong.py:3:
> return ( 5+6, 9)
gratuitous whitespace in () or []
missing whitespace in expression
Augie Fackler
contrib: enforce wrapping too-long lines with () instead of \...
r41927 ./wrong.py:5:
> return 1 + \
Use () to wrap long lines in Python, not \
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 ./quote.py:5:
> '"""', 42+1, """and
missing whitespace in expression
[1]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > python3-compat.py << NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > foo <> bar
> reduce(lambda a, b: a + b, [1, 2, 3, 4])
> dict(key=value)
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 $ "$check_code" python3-compat.py
python3-compat.py:1:
> foo <> bar
<> operator is not available in Python 3+, use !=
python3-compat.py:2:
> reduce(lambda a, b: a + b, [1, 2, 3, 4])
reduce is not available in Python 3+
python3-compat.py:3:
> dict(key=value)
dict() is different in Py2 and 3 and is slower than {}
[1]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > foo.c <<NO_CHECK_EOF
Augie Fackler
check-code: prevent use of strcpy
r28594 > void narf() {
> strcpy(foo, bar);
> // strcpy_s is okay, but this comment is not
> strcpy_s(foo, bar);
> }
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Augie Fackler
check-code: prevent use of strcpy
r28594 $ "$check_code" ./foo.c
./foo.c:2:
> strcpy(foo, bar);
don't use strcpy, use strlcpy or memcpy
./foo.c:3:
> // strcpy_s is okay, but this comment is not
don't use //-style comments
[1]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > is-op.py <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > # is-operator comparing number or string literal
> x = None
> y = x is 'foo'
> y = x is "foo"
> y = x is 5346
> y = x is -6
> y = x is not 'foo'
> y = x is not "foo"
> y = x is not 5346
> y = x is not -6
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367
$ "$check_code" ./is-op.py
./is-op.py:3:
> y = x is 'foo'
object comparison with literal
./is-op.py:4:
> y = x is "foo"
object comparison with literal
./is-op.py:5:
> y = x is 5346
object comparison with literal
./is-op.py:6:
> y = x is -6
object comparison with literal
./is-op.py:7:
> y = x is not 'foo'
object comparison with literal
./is-op.py:8:
> y = x is not "foo"
object comparison with literal
./is-op.py:9:
> y = x is not 5346
object comparison with literal
./is-op.py:10:
> y = x is not -6
object comparison with literal
[1]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > for-nolineno.py <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > except:
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 $ "$check_code" for-nolineno.py --nolineno
for-nolineno.py:0:
> except:
naked except clause
[1]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > warning.t <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > $ function warnonly {
> > }
> $ diff -N aaa
> $ function onwarn {}
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 $ "$check_code" warning.t
$ "$check_code" --warn warning.t
warning.t:1:
> $ function warnonly {
warning: don't use 'function', use old style
warning.t:3:
> $ diff -N aaa
warning: don't use 'diff -N'
warning.t:4:
> $ function onwarn {}
warning: don't use 'function', use old style
[1]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > error.t <<NO_CHECK_EOF
Augie Fackler
style: ban [ foo == bar] bashism in tests
r32293 > $ [ foo == bar ]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Augie Fackler
style: ban [ foo == bar] bashism in tests
r32293 $ "$check_code" error.t
error.t:1:
> $ [ foo == bar ]
[ foo == bar ] is a bashism, use [ foo = bar ] instead
[1]
$ rm error.t
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > raise-format.py <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > raise SomeException, message
> # this next line is okay
> raise SomeException(arg1, arg2)
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 $ "$check_code" not-existing.py raise-format.py
Skipping*not-existing.py* (glob)
raise-format.py:1:
> raise SomeException, message
don't use old-style two-argument raise, use Exception(message)
[1]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat <<NO_CHECK_EOF > tab.t
Yuya Nishihara
check-code: allow tabs in heredoc
r35316 > indent
> > heredoc
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Yuya Nishihara
check-code: allow tabs in heredoc
r35316 $ "$check_code" tab.t
tab.t:1:
> indent
don't use tabs to indent
[1]
$ rm tab.t
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > rst.py <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > """problematic rst text
>
> .. note::
> wrong
> """
>
> '''
>
> .. note::
>
> valid
>
> new text
>
> .. note::
>
> also valid
> '''
>
> """mixed
>
> .. note::
>
> good
>
> .. note::
> plus bad
> """
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 $ $check_code -w rst.py
rst.py:3:
> .. note::
warning: add two newlines after '.. note::'
rst.py:26:
> .. note::
warning: add two newlines after '.. note::'
[1]
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > ./map-inside-gettext.py <<NO_CHECK_EOF
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_("map inside gettext %s" % v))
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 >
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_("concatenating " " by " " space %s" % v))
> print(_("concatenating " + " by " + " '+' %s" % v))
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 >
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_("mapping operation in different line %s"
> % v))
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 >
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_(
> "leading spaces inside of '(' %s" % v))
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 $ "$check_code" ./map-inside-gettext.py
./map-inside-gettext.py:1:
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_("map inside gettext %s" % v))
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 don't use % inside _()
./map-inside-gettext.py:3:
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_("concatenating " " by " " space %s" % v))
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 don't use % inside _()
./map-inside-gettext.py:4:
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_("concatenating " + " by " + " '+' %s" % v))
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 don't use % inside _()
./map-inside-gettext.py:6:
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_("mapping operation in different line %s"
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 don't use % inside _()
./map-inside-gettext.py:9:
Augie Fackler
tests: clean up many print statements to be print functions instead...
r33687 > print(_(
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 don't use % inside _()
[1]
web templates
$ mkdir -p mercurial/templates
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > mercurial/templates/example.tmpl <<NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367 > {desc}
> {desc|escape}
> {desc|firstline}
> {desc|websub}
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Pierre-Yves David
test: rename 'check-code' own test to 'test-contrib-check-code.t'...
r27367
$ "$check_code" --warnings mercurial/templates/example.tmpl
mercurial/templates/example.tmpl:2:
> {desc|escape}
warning: follow desc keyword with either firstline or websub
[1]
FUJIWARA Katsunori
check-code: replace quoted characters correctly...
r29276
'string join across lines with no space' detection
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > stringjoin.py <<NO_CHECK_EOF
FUJIWARA Katsunori
check-code: replace quoted characters correctly...
r29276 > foo = (' foo'
> 'bar foo.'
> 'bar foo:'
> 'bar foo@'
FUJIWARA Katsunori
check-code: make repquote distinguish more characters for exact detection...
r29279 > 'bar foo%'
> 'bar foo*'
> 'bar foo+'
> 'bar foo-'
FUJIWARA Katsunori
check-code: replace quoted characters correctly...
r29276 > 'bar')
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
FUJIWARA Katsunori
check-code: detect "missing _() in ui message" more exactly...
r29397
'missing _() in ui message' detection
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > uigettext.py <<NO_CHECK_EOF
FUJIWARA Katsunori
check-code: detect "missing _() in ui message" more exactly...
r29397 > ui.status("% 10s %05d % -3.2f %*s %%"
> # this use '\\\\' instead of '\\', because the latter in
> # heredoc on shell becomes just '\'
> '\\\\ \n \t \0'
> """12345
> """
> '''.:*+-=
> ''' "%-6d \n 123456 .:*+-= foobar")
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
FUJIWARA Katsunori
check-code: detect "missing _() in ui message" more exactly...
r29397
Augie Fackler
contrib: add a check to check-code to ban superfluous pass statements...
r34383 superfluous pass
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 $ cat > superfluous_pass.py <<NO_CHECK_EOF
Augie Fackler
contrib: add a check to check-code to ban superfluous pass statements...
r34383 > # correct examples
> if foo:
> pass
> else:
> # comment-only line means still need pass
> pass
> def nothing():
> pass
> class empty(object):
> pass
> if whatever:
> passvalue(value)
> # bad examples
> if foo:
> "foo"
> pass
> else: # trailing comment doesn't fool checker
> wat()
> pass
> def nothing():
> "docstring means no pass"
> pass
> class empty(object):
> """multiline
> docstring also
> means no pass"""
> pass
FUJIWARA Katsunori
tests: use NO_CHECK_EOF as heredoc limit mark to omit checking code fragments...
r40130 > NO_CHECK_EOF
Augie Fackler
contrib: add a check to check-code to ban superfluous pass statements...
r34383
FUJIWARA Katsunori
check-code: build translation table for repquote in global for efficiency...
r29398 (Checking multiple invalid files at once examines whether caching
translation table for repquote() works as expected or not. All files
should break rules depending on result of repquote(), in this case)
Augie Fackler
contrib: add a check to check-code to ban superfluous pass statements...
r34383 $ "$check_code" stringjoin.py uigettext.py superfluous_pass.py
FUJIWARA Katsunori
check-code: replace quoted characters correctly...
r29276 stringjoin.py:1:
> foo = (' foo'
string join across lines with no space
stringjoin.py:2:
> 'bar foo.'
string join across lines with no space
stringjoin.py:3:
> 'bar foo:'
string join across lines with no space
stringjoin.py:4:
> 'bar foo@'
string join across lines with no space
FUJIWARA Katsunori
check-code: make repquote distinguish more characters for exact detection...
r29279 stringjoin.py:5:
> 'bar foo%'
string join across lines with no space
stringjoin.py:6:
> 'bar foo*'
string join across lines with no space
stringjoin.py:7:
> 'bar foo+'
string join across lines with no space
stringjoin.py:8:
> 'bar foo-'
string join across lines with no space
FUJIWARA Katsunori
check-code: detect "missing _() in ui message" more exactly...
r29397 uigettext.py:1:
> ui.status("% 10s %05d % -3.2f %*s %%"
missing _() in ui message (use () to hide false-positives)
Augie Fackler
contrib: add a check to check-code to ban superfluous pass statements...
r34383 superfluous_pass.py:14:
> if foo:
omit superfluous pass
superfluous_pass.py:17:
> else: # trailing comment doesn't fool checker
omit superfluous pass
superfluous_pass.py:20:
> def nothing():
omit superfluous pass
superfluous_pass.py:23:
> class empty(object):
omit superfluous pass
FUJIWARA Katsunori
check-code: detect "missing _() in ui message" more exactly...
r29397 [1]
FUJIWARA Katsunori
contrib: make check-code.py check code fragments embedded in test scripts
r41992
Check code fragments embedded in test script
$ cat > embedded-code.t <<NO_CHECK_EOF
> code fragment in doctest style
> >>> x = (1,2)
> ...
> ... x = (1,2)
>
> code fragment in heredoc style
> $ python <<EOF
> > x = (1,2)
> > EOF
>
> code fragment in file heredoc style
> $ python > file.py <<EOF
> > x = (1,2)
> > EOF
> NO_CHECK_EOF
$ "$check_code" embedded-code.t
embedded-code.t:2:
> x = (1,2)
missing whitespace after ,
embedded-code.t:4:
> x = (1,2)
missing whitespace after ,
embedded-code.t:8:
> x = (1,2)
missing whitespace after ,
embedded-code.t:13:
> x = (1,2)
missing whitespace after ,
[1]
"max warnings per file" is shared by all embedded code fragments
$ "$check_code" --per-file=3 embedded-code.t
embedded-code.t:2:
> x = (1,2)
missing whitespace after ,
embedded-code.t:4:
> x = (1,2)
missing whitespace after ,
embedded-code.t:8:
> x = (1,2)
missing whitespace after ,
(too many errors, giving up)
[1]