sapling/eden/scm/tests/test-contrib-check-code.t
Mark Thomas 052e7c3877 check-code: convert to Python 3
Summary:
Update `contrib/check-code.py` to Python 3.

Mostly it was already compatible, however stricter regular expression parsing
revealed a case where one of our tests wasn't working, and as a result lots of
instances of `open(file).read()` existed that this test should have caught.

I have fixed up most of the instances in the code, although there are many
in the test suite that I have ignored for now.

Reviewed By: quark-zju

Differential Revision: D21427212

fbshipit-source-id: 7461a7c391e0ade947f779a2b476ca937fd24a8d
2020-05-07 09:07:50 -07:00

158 lines
4.8 KiB
Perl

#chg-compatible
$ run_check_code() {
> PYTHONPATH= "$TESTDIR"/../contrib/check-code.py "$@"
> }
$ cat > correct.py <<EOF
> def toto(arg1, arg2):
> del arg2
> return (5 + 6, 9)
> EOF
$ cat > wrong.py <<EOF
> def toto(arg1, arg2):
> del(arg2)
> return (5+6, 9)
> EOF
$ cat > quote.py <<EOF
> # 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"
> EOF
$ cat > classstyle.py <<EOF
> class newstyle_class(object):
> pass
>
> class oldstyle_class:
> pass
>
> class empty():
> pass
>
> no_class = 1:
> pass
> EOF
$ run_check_code ./wrong.py ./correct.py ./quote.py ./classstyle.py
./wrong.py:2: Python keyword is not a function --> del(arg2)
./classstyle.py:4: old-style class, use class foo(object) --> class oldstyle_class:
./classstyle.py:7: class foo() creates old style object, use class foo(object) --> class empty():
[1]
$ cat > python3-compat.py << EOF
> foo <> bar
> reduce(lambda a, b: a + b, [1, 2, 3, 4])
> dict(key=value)
> EOF
$ run_check_code python3-compat.py
python3-compat.py:1: <> operator is not available in Python 3+, use != --> foo <> bar
python3-compat.py:2: reduce is not available in Python 3+ --> reduce(lambda a, b: a + b, [1, 2, 3, 4])
python3-compat.py:3: dict constructor is different in Py2 and 3 and is slower than {} --> dict(key=value)
[1]
$ cat > is-op.py <<EOF
> # 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
> EOF
$ run_check_code ./is-op.py
./is-op.py:3: object comparison with literal --> y = x is 'foo'
./is-op.py:4: object comparison with literal --> y = x is "foo"
./is-op.py:5: object comparison with literal --> y = x is 5346
./is-op.py:6: object comparison with literal --> y = x is -6
./is-op.py:7: object comparison with literal --> y = x is not 'foo'
./is-op.py:8: object comparison with literal --> y = x is not "foo"
./is-op.py:9: object comparison with literal --> y = x is not 5346
./is-op.py:10: object comparison with literal --> y = x is not -6
[1]
$ cat > for-nolineno.py <<EOF
> except:
> EOF
$ run_check_code for-nolineno.py --nolineno
for-nolineno.py:0: naked except clause --> except:
[1]
$ cat > warning.t <<EOF
> $ function warnonly {
> > }
> $ diff -N aaa
> $ function onwarn {}
> EOF
$ run_check_code warning.t
$ run_check_code --warn warning.t
warning.t:1: warning: don't use 'function', use old style --> $ function warnonly {
warning.t:3: warning: don't use 'diff -N' --> $ diff -N aaa
warning.t:4: warning: don't use 'function', use old style --> $ function onwarn {}
[1]
$ cat > error.t <<EOF
> $ [ foo == bar ]
> EOF
$ run_check_code error.t
error.t:1: [ foo == bar ] is a bashism, use [ foo = bar ] instead --> $ [ foo == bar ]
[1]
$ rm error.t
$ cat > raise-format.py <<EOF
> raise SomeException, message
> # this next line is okay
> raise SomeException(arg1, arg2)
> EOF
$ run_check_code not-existing.py raise-format.py
Skipping*not-existing.py* (glob)
raise-format.py:1: don't use old-style two-argument raise, use Exception(message) --> raise SomeException, message
[1]
$ cat <<EOF > tab.t
> indent
> > heredoc
> EOF
$ run_check_code tab.t
tab.t:1: don't use tabs to indent --> indent
[1]
$ rm tab.t
$ cat > ./map-inside-gettext.py <<EOF
> print(_("map inside gettext %s" % v))
>
> print(_("concatenating " " by " " space %s" % v))
> print(_("concatenating " + " by " + " '+' %s" % v))
>
> print(_("mapping operation in different line %s"
> % v))
>
> print(_(
> "leading spaces inside of '(' %s" % v))
> EOF
$ run_check_code ./map-inside-gettext.py
./map-inside-gettext.py:1: don't use % inside _() --> print(_("map inside gettext %s" % v))
./map-inside-gettext.py:3: don't use % inside _() --> print(_("concatenating " " by " " space %s" % v))
./map-inside-gettext.py:4: don't use % inside _() --> print(_("concatenating " + " by " + " '+' %s" % v))
./map-inside-gettext.py:6: don't use % inside _() --> print(_("mapping operation in different line %s"
./map-inside-gettext.py:9: don't use % inside _() --> print(_(
[1]
web templates
$ mkdir -p mercurial/templates
$ cat > mercurial/templates/example.tmpl <<EOF
> {desc}
> {desc|escape}
> {desc|firstline}
> {desc|websub}
> EOF
$ run_check_code --warnings mercurial/templates/example.tmpl
mercurial/templates/example.tmpl:2: warning: follow desc keyword with either firstline or websub --> {desc|escape}
[1]