From f4a91df30bbc538c59f94e04b9e1aef6e41783a8 Mon Sep 17 00:00:00 2001 From: Henry Schreiner Date: Tue, 5 Nov 2024 08:50:41 -0500 Subject: [PATCH] fix: warning about __main__ already being imported (#884) --- nox/__init__.py | 2 +- nox/__main__.py | 51 +++----------------------------------- nox/_cli.py | 66 +++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 70 insertions(+), 49 deletions(-) create mode 100644 nox/_cli.py diff --git a/nox/__init__.py b/nox/__init__.py index 4664edca..8121e62a 100644 --- a/nox/__init__.py +++ b/nox/__init__.py @@ -15,7 +15,7 @@ from __future__ import annotations from nox import project -from nox.__main__ import main +from nox._cli import main from nox._options import noxfile_options as options from nox._parametrize import Param as param from nox._parametrize import parametrize_decorator as parametrize diff --git a/nox/__main__.py b/nox/__main__.py index 96f51280..ac183d6a 100644 --- a/nox/__main__.py +++ b/nox/__main__.py @@ -19,56 +19,11 @@ control to :meth:``nox.workflow.execute``. """ -from __future__ import annotations +from __future__ import annotations # pragma: no cover -import sys -from typing import Any +from nox._cli import main # pragma: no cover -from nox import _options, tasks, workflow -from nox._version import get_nox_version -from nox.logger import setup_logging - - -def execute_workflow(args: Any) -> int: - """ - Execute the appropriate tasks. - """ - - return workflow.execute( - global_config=args, - workflow=( - tasks.load_nox_module, - tasks.merge_noxfile_options, - tasks.discover_manifest, - tasks.filter_manifest, - tasks.honor_list_request, - tasks.run_manifest, - tasks.print_summary, - tasks.create_report, - tasks.final_reduce, - ), - ) - - -def main() -> None: - args = _options.options.parse_args() - - if args.help: - _options.options.print_help() - return - - if args.version: - print(get_nox_version(), file=sys.stderr) - return - - setup_logging( - color=args.color, verbose=args.verbose, add_timestamp=args.add_timestamp - ) - - exit_code = execute_workflow(args) - - # Done; exit. - sys.exit(exit_code) +__all__ = ["main"] # pragma: no cover if __name__ == "__main__": # pragma: no cover diff --git a/nox/_cli.py b/nox/_cli.py new file mode 100644 index 00000000..f25dad2a --- /dev/null +++ b/nox/_cli.py @@ -0,0 +1,66 @@ +# Copyright 2016 Alethea Katherine Flowers +# +# 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. + +"""The Nox `main` function and helpers.""" + +from __future__ import annotations + +import sys +from typing import Any + +from nox import _options, tasks, workflow +from nox._version import get_nox_version +from nox.logger import setup_logging + + +def execute_workflow(args: Any) -> int: + """ + Execute the appropriate tasks. + """ + + return workflow.execute( + global_config=args, + workflow=( + tasks.load_nox_module, + tasks.merge_noxfile_options, + tasks.discover_manifest, + tasks.filter_manifest, + tasks.honor_list_request, + tasks.run_manifest, + tasks.print_summary, + tasks.create_report, + tasks.final_reduce, + ), + ) + + +def main() -> None: + args = _options.options.parse_args() + + if args.help: + _options.options.print_help() + return + + if args.version: + print(get_nox_version(), file=sys.stderr) + return + + setup_logging( + color=args.color, verbose=args.verbose, add_timestamp=args.add_timestamp + ) + + exit_code = execute_workflow(args) + + # Done; exit. + sys.exit(exit_code)