-
Notifications
You must be signed in to change notification settings - Fork 3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Adopt linrtunner as the linting tool #14306
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
CodeQL found more than 10 potential problems in the proposed changes. Check the Files changed tab for more details.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thanks.
Todo: the rest of the lints; ort training import order |
from opgen.ast import * | ||
from typing import List, Tuple, Union, Optional | ||
from opgen.lexer import * |
Check notice
Code scanning / CodeQL
'import *' may pollute namespace
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Existing error I didn't have the bandwidth fixing
orttraining/orttraining/test/python/orttraining_test_orttrainer_bert_toy_onnx.py
Fixed
Show fixed
Hide fixed
...est_data/bert_squad_tensorflow2.1_keras2onnx_opset11/generate_tiny_keras2onnx_bert_models.py
Fixed
Show fixed
Hide fixed
@@ -600,7 +600,7 @@ | |||
# Use no past state for these models | |||
if config.use_cache: | |||
config.use_cache = False | |||
except: | |||
except Exception: |
Check notice
Code scanning / CodeQL
Empty except
@@ -102,15 +102,15 @@ | |||
|
|||
try: | |||
from .build_and_package_info import cuda_version | |||
except: # noqa | |||
except Exception: |
Check notice
Code scanning / CodeQL
Empty except
Signed-off-by: Justin Chu <[email protected]>
I'll be back at this after the release to cause less disruption |
Replaced by #15085 |
### Description `lintrunner` is a linter runner successfully used by pytorch, onnx and onnx-script. It provides a uniform experience running linters locally and in CI. It supports all major dev systems: Windows, Linux and MacOs. The checks are enforced by the `Python format` workflow. This PR adopts `lintrunner` to onnxruntime and fixed ~2000 flake8 errors in Python code. `lintrunner` now runs all required python lints including `ruff`(replacing `flake8`), `black` and `isort`. Future lints like `clang-format` can be added. Most errors are auto-fixed by `ruff` and the fixes should be considered robust. Lints that are more complicated to fix are applied `# noqa` for now and should be fixed in follow up PRs. ### Notable changes 1. This PR **removed some suboptimal patterns**: - `not xxx in` -> `xxx not in` membership checks - bare excepts (`except:` -> `except Exception`) - unused imports The follow up PR will remove: - `import *` - mutable values as default in function definitions (`def func(a=[])`) - more unused imports - unused local variables 2. Use `ruff` to replace `flake8`. `ruff` is much (40x) faster than flake8 and is more robust. We are using it successfully in onnx and onnx-script. It also supports auto-fixing many flake8 errors. 3. Removed the legacy flake8 ci flow and updated docs. 4. The added workflow supports SARIF code scanning reports on github, example snapshot: ![image](https://user-images.githubusercontent.com/11205048/212598953-d60ce8a9-f242-4fa8-8674-8696b704604a.png) 5. Removed `onnxruntime-python-checks-ci-pipeline` as redundant ### Motivation and Context <!-- - Why is this change required? What problem does it solve? - If it fixes an open issue, please link to the issue here. --> Unified linting experience in CI and local. Replacing #14306 --------- Signed-off-by: Justin Chu <[email protected]>
Description
lintrunner
is a linter runner successfully used by pytorch, onnx and onnx-script. This PR adoptslintrunner
to onnxruntime and hand fixed ~2000 flake8 errors in Python code.lintrunner
now runs all required python lints includingflake8
,black
andisort
. Future lints likeclang-format
can be added.In particular, this PR removed some very suboptimal patterns:
import *
def func(a=[])
)not xxx in
->xxx not in
membership checksexcept:
->except Exception
)The added workflow supports SARIF code scanning reports on github, example snapshot:
Motivation and Context
Unified linting experience in CI and local.