| # Copyright 2019 Google LLC |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| import os |
| import pathlib |
| import shutil |
| |
| import nox |
| |
| CURRENT_DIRECTORY = pathlib.Path(__file__).parent.absolute() |
| |
| CLICK_VERSION = "click" |
| BLACK_VERSION = "black==23.7.0" |
| BLACK_PATHS = [ |
| "google", |
| "tests", |
| "tests_async", |
| "noxfile.py", |
| "setup.py", |
| "docs/conf.py", |
| ] |
| |
| DEFAULT_PYTHON_VERSION = "3.14" |
| UNIT_TEST_PYTHON_VERSIONS = [ |
| "3.7", |
| "3.8", |
| "3.9", |
| "3.10", |
| "3.11", |
| "3.12", |
| "3.13", |
| "3.14", |
| ] |
| |
| # Error if a python version is missing |
| nox.options.error_on_missing_interpreters = True |
| |
| # pypy will be run as a github action instead of through Kokoro |
| nox.options.sessions = [ |
| "lint", |
| "blacken", |
| "mypy", |
| "unit-3.9", |
| "unit-3.10", |
| "unit-3.11", |
| "unit-3.12", |
| "unit-3.13", |
| "unit-3.14", |
| # cover must be last to avoid error `No data to report` |
| "cover", |
| "docs", |
| ] |
| |
| |
| @nox.session(python=DEFAULT_PYTHON_VERSION) |
| def lint(session): |
| session.install( |
| "flake8", "flake8-import-order", "docutils", CLICK_VERSION, BLACK_VERSION |
| ) |
| session.install("-e", ".") |
| session.run("black", "--check", *BLACK_PATHS) |
| session.run( |
| "flake8", |
| "--import-order-style=google", |
| "--application-import-names=google,tests,system_tests", |
| "google", |
| "tests", |
| "tests_async", |
| ) |
| session.run( |
| "python", "setup.py", "check", "--metadata", "--restructuredtext", "--strict" |
| ) |
| |
| |
| @nox.session(python=DEFAULT_PYTHON_VERSION) |
| def blacken(session): |
| """Run black. |
| Format code to uniform standard. |
| The Python version should be consistent with what is |
| supplied in the Python Owlbot postprocessor. |
| |
| https://github.com/googleapis/synthtool/blob/master/docker/owlbot/python/Dockerfile |
| """ |
| session.install(CLICK_VERSION, BLACK_VERSION) |
| session.run("black", *BLACK_PATHS) |
| |
| |
| @nox.session(python=DEFAULT_PYTHON_VERSION) |
| def mypy(session): |
| """Verify type hints are mypy compatible.""" |
| session.install("-e", ".") |
| session.install( |
| "mypy", |
| "types-certifi", |
| "types-freezegun", |
| "types-pyOpenSSL", |
| "types-requests", |
| "types-setuptools", |
| "types-mock", |
| "pytest<8.0.0", |
| ) |
| session.run("mypy", "-p", "google", "-p", "tests", "-p", "tests_async") |
| |
| |
| @nox.session(python=UNIT_TEST_PYTHON_VERSIONS) |
| def unit(session): |
| constraints_path = str( |
| CURRENT_DIRECTORY / "testing" / f"constraints-{session.python}.txt" |
| ) |
| session.install("-e", ".[testing]", "-c", constraints_path) |
| session.run( |
| "pytest", |
| f"--junitxml=unit_{session.python}_sponge_log.xml", |
| "--cov-append", |
| "--cov=google.auth", |
| "--cov=google.oauth2", |
| "--cov=tests", |
| "--cov-report=term-missing", |
| "tests", |
| "tests_async", |
| *session.posargs, |
| ) |
| |
| |
| @nox.session(python=DEFAULT_PYTHON_VERSION) |
| def cover(session): |
| """Run the final coverage report. |
| |
| This outputs the coverage report aggregating coverage from the unit |
| test runs (not system test runs), and then erases coverage data. |
| """ |
| session.install("coverage", "pytest-cov") |
| session.run("coverage", "report", "--show-missing", "--fail-under=100") |
| session.run("coverage", "erase") |
| |
| |
| @nox.session(python="3.10") |
| def docs(session): |
| """Build the docs for this library.""" |
| |
| session.install("-e", ".[aiohttp]") |
| session.install("sphinx", "alabaster", "recommonmark", "sphinx-docstring-typing") |
| |
| shutil.rmtree(os.path.join("docs", "_build"), ignore_errors=True) |
| session.run( |
| "sphinx-build", |
| "-T", # show full traceback on exception |
| "-W", # warnings as errors |
| "-N", # no colors |
| "-b", |
| "html", |
| "-d", |
| os.path.join("docs", "_build", "doctrees", ""), |
| os.path.join("docs", ""), |
| os.path.join("docs", "_build", "html", ""), |
| ) |
| |
| |
| @nox.session(python="pypy") |
| def pypy(session): |
| session.install("-e", ".[testing]") |
| session.run( |
| "pytest", |
| f"--junitxml=unit_{session.python}_sponge_log.xml", |
| "--cov=google.auth", |
| "--cov=google.oauth2", |
| "--cov=tests", |
| "tests", |
| "tests_async", |
| ) |