| # 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() |
| |
| BLACK_VERSION = "black==19.3b0" |
| BLACK_PATHS = [ |
| "google", |
| "tests", |
| "tests_async", |
| "noxfile.py", |
| "setup.py", |
| "docs/conf.py", |
| ] |
| |
| |
| @nox.session(python="3.7") |
| def lint(session): |
| session.install("flake8", "flake8-import-order", "docutils", 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="3.8") |
| 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(BLACK_VERSION) |
| session.run("black", *BLACK_PATHS) |
| |
| |
| @nox.session(python=["3.6", "3.7", "3.8", "3.9", "3.10"]) |
| def unit(session): |
| constraints_path = str( |
| CURRENT_DIRECTORY / "testing" / f"constraints-{session.python}.txt" |
| ) |
| session.install("-r", "testing/requirements.txt", "-c", constraints_path) |
| session.install("-e", ".", "-c", constraints_path) |
| session.run( |
| "pytest", |
| f"--junitxml=unit_{session.python}_sponge_log.xml", |
| "--cov=google.auth", |
| "--cov=google.oauth2", |
| "--cov=tests", |
| "--cov-report=term-missing", |
| "tests", |
| "tests_async", |
| ) |
| |
| |
| @nox.session(python=["2.7"]) |
| def unit_prev_versions(session): |
| constraints_path = str( |
| CURRENT_DIRECTORY / "testing" / f"constraints-{session.python}.txt" |
| ) |
| session.install("-r", "testing/requirements.txt", "-c", constraints_path) |
| session.install("-e", ".", "-c", constraints_path) |
| session.run( |
| "pytest", |
| f"--junitxml=unit_{session.python}_sponge_log.xml", |
| "--cov=google.auth", |
| "--cov=google.oauth2", |
| "--cov=tests", |
| "tests", |
| ) |
| |
| |
| @nox.session(python="3.7") |
| def cover(session): |
| session.install("-r", "testing/requirements.txt") |
| session.install("-e", ".") |
| session.run( |
| "pytest", |
| "--cov=google.auth", |
| "--cov=google.oauth2", |
| "--cov=tests", |
| "--cov=tests_async", |
| "--cov-report=term-missing", |
| "tests", |
| "tests_async", |
| ) |
| session.run("coverage", "report", "--show-missing", "--fail-under=100") |
| |
| |
| @nox.session(python="3.7") |
| def docgen(session): |
| session.env["SPHINX_APIDOC_OPTIONS"] = "members,inherited-members,show-inheritance" |
| session.install("-r", "testing/requirements.txt") |
| session.install("sphinx") |
| session.install("-e", ".") |
| session.run("rm", "-r", "docs/reference") |
| session.run( |
| "sphinx-apidoc", |
| "--output-dir", |
| "docs/reference", |
| "--separate", |
| "--module-first", |
| "google", |
| ) |
| |
| |
| @nox.session(python="3.8") |
| def docs(session): |
| """Build the docs for this library.""" |
| |
| session.install("-e", ".[aiohttp]") |
| session.install( |
| "sphinx<3.0.0", "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("-r", "test/requirements.txt") |
| session.install("-e", ".") |
| session.run( |
| "pytest", |
| f"--junitxml=unit_{session.python}_sponge_log.xml", |
| "--cov=google.auth", |
| "--cov=google.oauth2", |
| "--cov=tests", |
| "tests", |
| "tests_async", |
| ) |