From ceb90b8e09d85efa0f51b436b7a634886948c385 Mon Sep 17 00:00:00 2001 From: Tianlei Wu Date: Tue, 10 Dec 2024 11:34:08 -0800 Subject: [PATCH 1/4] update python verison metadata --- pyproject.toml | 3 ++- setup.py | 8 +++----- 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 6429df2722b2d..40e6eb96dff94 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -2,7 +2,8 @@ line-length = 120 # NOTE: Do not extend the exclude list. Edit .lintrunner.toml instead extend-exclude = "cmake|onnxruntime/core/flatbuffers/" -target-version = ["py37", "py38", "py39", "py310", "py311"] +# NOTE: use the minimum supported python version as target-version +target-version = ["py310"] [tool.isort] # NOTE: Do not extend the exclude list. Edit .lintrunner.toml instead diff --git a/setup.py b/setup.py index 1ca31cb0019f0..c1580eeb9e8f9 100644 --- a/setup.py +++ b/setup.py @@ -529,6 +529,8 @@ def finalize_options(self): "Intended Audience :: Developers", "License :: OSI Approved :: MIT License", "Operating System :: POSIX :: Linux", + "Operating System :: Microsoft :: Windows", + "Operating System :: MacOS", "Topic :: Scientific/Engineering", "Topic :: Scientific/Engineering :: Mathematics", "Topic :: Scientific/Engineering :: Artificial Intelligence", @@ -537,14 +539,10 @@ def finalize_options(self): "Topic :: Software Development :: Libraries :: Python Modules", "Programming Language :: Python", "Programming Language :: Python :: 3 :: Only", - "Programming Language :: Python :: 3.7", - "Programming Language :: Python :: 3.8", - "Programming Language :: Python :: 3.9", "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: 3.12", - "Operating System :: Microsoft :: Windows", - "Operating System :: MacOS", + "Programming Language :: Python :: 3.13", ] if enable_training or enable_training_apis: From 660e1e27b59289b6e1c78540f359ac1340ceb72e Mon Sep 17 00:00:00 2001 From: Tianlei Wu Date: Tue, 10 Dec 2024 15:26:48 -0800 Subject: [PATCH 2/4] comment of lintrunner workflow --- .github/workflows/lint.yml | 5 ++--- .lintrunner.toml | 18 +++++------------- docs/Coding_Conventions_and_Standards.md | 14 ++++---------- 3 files changed, 11 insertions(+), 26 deletions(-) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 64785574c7728..3883f4c644bb1 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -45,7 +45,7 @@ jobs: - name: Setup Python uses: actions/setup-python@v5 with: - # Version range or exact version of Python to use, using SemVer's version range syntax. Reads from .python-version if unset. + # Use the version configured in target-version of [tool.black] section in pyproject.toml. python-version: "3.10" - name: Setup Rust uses: actions-rs/toolchain@v1 @@ -55,12 +55,11 @@ jobs: - name: Update PATH run: | echo "$HOME/.local/bin" >> "$GITHUB_PATH" - - name: Install dependencies run: | set -e -x python -m pip install --user -r requirements-dev.txt - python -m pip install --user lintrunner lintrunner-adapters + python -m pip install --user -r lintrunner lintrunner init - name: Run lintrunner on all files run: | diff --git a/.lintrunner.toml b/.lintrunner.toml index be46ba0baabdb..43478a02bea7a 100644 --- a/.lintrunner.toml +++ b/.lintrunner.toml @@ -2,31 +2,23 @@ # You can install the dependencies and initialize with # # ```sh -# pip install lintrunner lintrunner-adapters +# pip install lintrunner # lintrunner init # ``` # # This will install lintrunner on your system and download all the necessary # dependencies to run linters locally. -# If you want to see what lintrunner init will install, run -# `lintrunner init --dry-run`. # -# To lint local changes: +# To format local changes: # # ```bash -# lintrunner +# lintrunner -a # ``` # -# To lint all files: +# To format all files: # # ```bash -# lintrunner --all-files -# ``` -# -# To format files: -# -# ```bash -# lintrunner f --all-files +# lintrunner -a --all-files # ``` # # To read more about lintrunner, see [wiki](https://github.com/pytorch/pytorch/wiki/lintrunner). diff --git a/docs/Coding_Conventions_and_Standards.md b/docs/Coding_Conventions_and_Standards.md index f18f1036efee8..4c19a54636d58 100644 --- a/docs/Coding_Conventions_and_Standards.md +++ b/docs/Coding_Conventions_and_Standards.md @@ -155,7 +155,7 @@ Using `Show Code Coverage Coloring` will allow you to visually inspect which lin This project uses [lintrunner](https://github.com/suo/lintrunner) for linting. It provides a consistent linting experience locally and in CI. You can install the dependencies and initialize with ```sh -pip install -r requirements-lintrunner.txt +pip install lintrunner lintrunner init ``` @@ -164,22 +164,16 @@ dependencies to run linters locally. If you want to see what lintrunner init will install, run `lintrunner init --dry-run`. -To lint local changes: - -```bash -lintrunner -``` - -To format files and apply suggestions: +To format local changes: ```bash lintrunner -a ``` -To lint all files: +To format all files: ```bash -lintrunner --all-files +lintrunner -a --all-files ``` To show help text: From 0c5bf2aa5f803bd3a9b3cf8f0cf7eea7f9d11331 Mon Sep 17 00:00:00 2001 From: Tianlei Wu Date: Tue, 10 Dec 2024 15:30:11 -0800 Subject: [PATCH 3/4] lintrunner -a --- .github/workflows/lint.yml | 2 +- orttraining/orttraining/python/training/artifacts.py | 11 +++++++---- .../training/ortmodule/_graph_transition_manager.py | 5 +++-- 3 files changed, 11 insertions(+), 7 deletions(-) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 3883f4c644bb1..79ea7d19cc8b3 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -59,7 +59,7 @@ jobs: run: | set -e -x python -m pip install --user -r requirements-dev.txt - python -m pip install --user -r lintrunner + python -m pip install --user lintrunner lintrunner init - name: Run lintrunner on all files run: | diff --git a/orttraining/orttraining/python/training/artifacts.py b/orttraining/orttraining/python/training/artifacts.py index c98e5bcd97092..31591c0156b14 100644 --- a/orttraining/orttraining/python/training/artifacts.py +++ b/orttraining/orttraining/python/training/artifacts.py @@ -185,10 +185,13 @@ def build(self, *inputs_to_loss): logging.info("Custom op library provided: %s", custom_op_library) custom_op_library_path = pathlib.Path(custom_op_library) - with onnxblock.base(loaded_model, model_path), ( - onnxblock.custom_op_library(custom_op_library_path) - if custom_op_library is not None - else contextlib.nullcontext() + with ( + onnxblock.base(loaded_model, model_path), + ( + onnxblock.custom_op_library(custom_op_library_path) + if custom_op_library is not None + else contextlib.nullcontext() + ), ): _ = training_block(*[output.name for output in loaded_model.graph.output]) training_model, eval_model = training_block.to_model_proto() diff --git a/orttraining/orttraining/python/training/ortmodule/_graph_transition_manager.py b/orttraining/orttraining/python/training/ortmodule/_graph_transition_manager.py index 22627749c316c..d9cae8e1f99e8 100755 --- a/orttraining/orttraining/python/training/ortmodule/_graph_transition_manager.py +++ b/orttraining/orttraining/python/training/ortmodule/_graph_transition_manager.py @@ -867,8 +867,9 @@ def _get_exported_model( assert model_info_for_export.export_mode is not None, "Please use a concrete instance of ExecutionManager" try: - with torch.no_grad(), stage3_export_context( - enable_zero_stage3_support, stage3_param_handle, flattened_module + with ( + torch.no_grad(), + stage3_export_context(enable_zero_stage3_support, stage3_param_handle, flattened_module), ): required_export_kwargs = { "input_names": model_info_for_export.onnx_graph_input_names, # did not contains parameters as its input yet From ced64e45d1ab461f04d6c2e04c4da1b3b7d5e15e Mon Sep 17 00:00:00 2001 From: Tianlei Wu Date: Tue, 10 Dec 2024 15:50:33 -0800 Subject: [PATCH 4/4] add requirements-lintrunner.txt to requirements-dev.txt --- .github/workflows/lint.yml | 1 - .lintrunner.toml | 2 +- docs/Coding_Conventions_and_Standards.md | 2 +- requirements-dev.txt | 3 +-- 4 files changed, 3 insertions(+), 5 deletions(-) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 79ea7d19cc8b3..8d966d358de01 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -59,7 +59,6 @@ jobs: run: | set -e -x python -m pip install --user -r requirements-dev.txt - python -m pip install --user lintrunner lintrunner init - name: Run lintrunner on all files run: | diff --git a/.lintrunner.toml b/.lintrunner.toml index 43478a02bea7a..5ef9ad9337f57 100644 --- a/.lintrunner.toml +++ b/.lintrunner.toml @@ -2,7 +2,7 @@ # You can install the dependencies and initialize with # # ```sh -# pip install lintrunner +# pip install -r requirements-lintrunner.txt # lintrunner init # ``` # diff --git a/docs/Coding_Conventions_and_Standards.md b/docs/Coding_Conventions_and_Standards.md index 4c19a54636d58..02af7ddaa49be 100644 --- a/docs/Coding_Conventions_and_Standards.md +++ b/docs/Coding_Conventions_and_Standards.md @@ -155,7 +155,7 @@ Using `Show Code Coverage Coloring` will allow you to visually inspect which lin This project uses [lintrunner](https://github.com/suo/lintrunner) for linting. It provides a consistent linting experience locally and in CI. You can install the dependencies and initialize with ```sh -pip install lintrunner +pip install -r requirements-lintrunner.txt lintrunner init ``` diff --git a/requirements-dev.txt b/requirements-dev.txt index 1b5ca65cf8037..b95b85781a398 100644 --- a/requirements-dev.txt +++ b/requirements-dev.txt @@ -1,7 +1,6 @@ -black>=22.3 +-r requirements-lintrunner.txt cerberus flatbuffers -isort jinja2 numpy onnx