From 1e407d84a515342260ffb287ddf2c61817774c2e Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 15:21:53 -0600 Subject: [PATCH 01/20] rearrange pyproject for easier sync between packages --- .github/workflows/lint.yml | 2 +- Makefile | 33 ++++-- poetry.lock | 5 +- pyproject.toml | 211 ++++++++++++++++++------------------- 4 files changed, 130 insertions(+), 121 deletions(-) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 9507910..a579204 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -28,7 +28,7 @@ jobs: shell: bash run: | python -m pip install --upgrade pip - pip install -e .[dev-all] + pip install -e .[dev] - name: Lint with black run: | black --check --diff screenpy_selenium diff --git a/Makefile b/Makefile index b47e564..5b6a012 100644 --- a/Makefile +++ b/Makefile @@ -1,24 +1,17 @@ -# shortcuts +# shortcuts to help manage flipping between branches with different dependencies sync: - poetry install --extras dev_all --sync + poetry install --extras dev --sync update_lock_only: poetry update --lock update: update_lock_only - poetry install --extras dev_all + poetry install --extras dev check: poetry check -trunk_screenpy: - poetry add screenpy git+ssh://git@github.com:ScreenPyHQ/screenpy.git#trunk - -local_screenpy: - pip uninstall screenpy - pip install -e ~/projects/screenpy - -.PHONY: sync update trunk_screenpy local_screenpy +.PHONY: sync update_lock_only update check black-check: black --check . @@ -42,3 +35,21 @@ pre-check-in: black-check ruff-check mypy pre-check-in-fix: black-fix ruff-fix mypy .PHONY: pre-check-in pre-check-in-fix + +# requires poetry-plugin-export +requirements: + poetry export --without-hashes --extras dev -f requirements.txt > requirements.txt + +.PHONY: requirements + +################################################################################ +# sub-package specific + +trunk_screenpy: + poetry add screenpy git+ssh://git@github.com:ScreenPyHQ/screenpy.git#trunk + +local_screenpy: + pip uninstall screenpy + pip install -e ~/projects/screenpy + +.PHONY: trunk_screenpy local_screenpy diff --git a/poetry.lock b/poetry.lock index 5313bf9..6512e1a 100644 --- a/poetry.lock +++ b/poetry.lock @@ -1529,11 +1529,10 @@ docs = ["furo", "jaraco.packaging (>=9.3)", "jaraco.tidelift (>=1.4)", "rst.link testing = ["big-O", "jaraco.functools", "jaraco.itertools", "more-itertools", "pytest (>=6)", "pytest-black (>=0.3.7)", "pytest-checkdocs (>=2.4)", "pytest-cov", "pytest-enabler (>=2.2)", "pytest-ignore-flaky", "pytest-mypy (>=0.9.1)", "pytest-ruff"] [extras] -dev = ["pre-commit", "pytest", "tox"] -dev-all = ["black", "coverage", "mypy", "pre-commit", "pytest", "ruff", "sphinx", "tox"] +dev = ["black", "coverage", "mypy", "pre-commit", "pytest", "ruff", "sphinx", "tox"] test = ["coverage", "pytest"] [metadata] lock-version = "2.0" python-versions = "^3.8" -content-hash = "58d914781efe541f9a8b6411a11276d3bcc2817e464a000da361624ff28d5034" +content-hash = "11e295386bfc306fbbc02b2612fa571eaa6e30fdee1f2c5b6f403d34c3fb3b9e" diff --git a/pyproject.toml b/pyproject.toml index 16d87d2..759d4cf 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,24 @@ +# This pyproject.toml is setup so it can be used with or without poetry and also +# supports editable installs (PEP 660) without breaking IDE and linter inspection. + +# DEVELOPER INSTALL INSTRUCTIONS (assuming current directory is at the top of the project) : +# Poetry: +# poetry install --extras dev +# PIP: +# pip install -e .[dev] + +################################################################################ +# the following sections do not contain unique configurations to this package. +################################################################################ + + +[build-system] +requires = ["poetry-core>=1.2.0"] +build-backend = "poetry.core.masonry.api" + + [tool.black] target-version = ['py312'] - extend-exclude = ''' # A regex preceded with ^/ will apply only to files and directories # in the root of the project. @@ -15,107 +33,20 @@ extend-exclude = ''' ''' -# This pyproject.toml is setup so it can be used with or without poetry and also -# supports editable installs (PEP 660) without breaking IDE and linter inspection. - -# DEVELOPER INSTALL INSTRUCTIONS (assuming current directory is at the top of the project) : -# Poetry: -# poetry install --extras dev -# PIP: -# pip install -e .[dev] - -[tool.poetry] -name = "screenpy_selenium" -version = "4.0.4" -description = "ScreenPy extension to enable interacting with Selenium." -authors = ["Perry Goy "] -maintainers = ["Gabe Langton", "Marcel Wilson"] -license = "MIT" -repository = "https://github.com/ScreenPyHQ/screenpy_selenium" -documentation = "https://screenpy-selenium-docs.readthedocs.io" -readme = "README.md" -classifiers = [ - "Operating System :: OS Independent", - "Programming Language :: Python :: 3 :: Only", - "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", - "Development Status :: 5 - Production/Stable", - "Intended Audience :: Developers", - "Topic :: Software Development :: Quality Assurance", - "Topic :: Software Development :: Testing", - "Topic :: Software Development :: Testing :: BDD", - "Natural Language :: English", - "License :: OSI Approved :: MIT License", -] - -# It's possible to add optional dependencies with the poetry CLI tool using: -# poetry add --optional some_dev_pkg -# This will set `optional = true` flag in [tool.poetry.dependencies], as seen below -# But then you need to remember to manually edit the [tool.poetry.extras] dev section -# and declare the package. This allows `pip install .[dev]` to work as expected -# Poetry users will need to use the `--extras dev` option rather than the `--with dev` -# so we dont have two different sets of package versions to update. - -[tool.poetry.dependencies] -python = "^3.8" -screenpy = ">=4.0.2" -screenpy_pyotp = ">=4.0.0" -selenium = ">=4.1.0" -importlib_metadata = {version = "*", python = "3.8.*"} - -# convenience packages for development of screenpy only -black = {version = "*", optional = true} -coverage = {version = "*", optional = true} -mypy = {version = "*", optional = true} -pre-commit = {version = "*", optional = true} -pytest = {version = "*", optional = true} -ruff = {version = ">=0.2.0", optional = true} -sphinx = {version = "*", optional = true} -tox = {version = "*", optional = true} - -[tool.poetry.extras] -dev = [ - "pre-commit", - "pytest", - "tox", -] -dev_all = [ - "black", - "coverage", - "mypy", - "pre-commit", - "pytest", - "ruff", - "sphinx", - "tox", -] -test = [ - "coverage", - "pytest", -] - -[build-system] -requires = ["poetry-core>=1.2.0"] -build-backend = "poetry.core.masonry.api" - [tool.ruff] target-version = "py38" # minimum supported version line-length = 88 # same as Black. - extend-exclude = [ - "screenpy_selenium/__init__.py", - "screenpy_selenium/__version__.py", + "__init__.py", + "__version__.py", "docs", ] [tool.ruff.lint] select = [ "A", # flake8-builtins - "ANN", # flake8-annotations # coming back to this one later to compare against mypy + "ANN", # flake8-annotations "ARG", # flake8-unused-arguments "B", # flake8-bugbear "BLE", # flake8-blind-except @@ -161,8 +92,7 @@ ignore = [ ] extend-safe-fixes = [ - "EM101", - "EM102", + "EM101", "EM102", "TCH001", "TCH002", "TCH003", "TCH004", "C419", "D200", "D205", "D415", @@ -171,6 +101,22 @@ extend-safe-fixes = [ "UP006", "UP007", ] +[tool.ruff.lint.flake8-pytest-style] +mark-parentheses = false + +[tool.ruff.lint.pycodestyle] +ignore-overlong-task-comments = true + +[tool.ruff.lint.pydocstyle] +convention = "google" + +[tool.ruff.lint.flake8-type-checking] +strict = true + +[tool.ruff.lint.isort] +combine-as-imports = true +split-on-trailing-comma = false + [tool.ruff.lint.per-file-ignores] "tests/**" = [ "D", # we don't need public-API-polished docstrings in tests. @@ -178,23 +124,76 @@ extend-safe-fixes = [ "PLR", # likewise using specific numbers and strings in tests. ] -[tool.ruff.lint.isort] -combine-as-imports = true -split-on-trailing-comma = false -known-first-party = ["screenpy_selenium", "tests"] - -[tool.ruff.lint.flake8-pytest-style] -mark-parentheses = false +################################################################################ +# the following sections contain unique configurations to this package. +################################################################################ +[tool.poetry] +name = "screenpy_selenium" +version = "4.0.4" +description = "ScreenPy extension to enable interacting with Selenium." +authors = ["Perry Goy "] +maintainers = ["Gabe Langton", "Marcel Wilson"] +license = "MIT" +repository = "https://github.com/ScreenPyHQ/screenpy_selenium" +documentation = "https://screenpy-selenium-docs.readthedocs.io" +readme = "README.md" +classifiers = [ + "Operating System :: OS Independent", + "Programming Language :: Python :: 3 :: Only", + "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", + "Development Status :: 5 - Production/Stable", + "Intended Audience :: Developers", + "Topic :: Software Development :: Quality Assurance", + "Topic :: Software Development :: Testing", + "Topic :: Software Development :: Testing :: BDD", + "Natural Language :: English", + "License :: OSI Approved :: MIT License", +] -[tool.ruff.lint.pycodestyle] -ignore-overlong-task-comments = true +# It's possible to add optional dependencies with the poetry CLI tool using: +# poetry add --optional some_dev_pkg +# This will set `optional = true` flag in [tool.poetry.dependencies], as seen below +# But then you need to remember to manually edit the [tool.poetry.extras] dev section +# and declare the package. This allows `pip install .[dev]` to work as expected +# Poetry users will need to use the `--extras dev` option rather than the `--with dev` +# so we dont have two different sets of package versions to update. +[tool.poetry.dependencies] +python = "^3.8" -[tool.ruff.lint.pydocstyle] -convention = "google" +screenpy = ">=4.0.2" +screenpy_pyotp = ">=4.0.0" +selenium = ">=4.1.0" +importlib_metadata = {version = "*", python = "3.8.*"} +# convenience packages for development +black = {version = "*", optional = true} +coverage = {version = "*", optional = true} +mypy = {version = "*", optional = true} +pre-commit = {version = "*", optional = true} +pytest = {version = "*", optional = true} +ruff = {version = ">=0.2.0", optional = true} +sphinx = {version = "*", optional = true} +tox = {version = "*", optional = true} -[tool.ruff.lint.flake8-type-checking] -strict = true +[tool.poetry.extras] +dev = [ + "black", + "coverage", + "mypy", + "pre-commit", + "pytest", + "ruff", + "sphinx", + "tox", +] +test = [ + "coverage", + "pytest", +] From 4150837b0c32b21c21ee3e50f62abda41bf9c762 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 15:57:31 -0600 Subject: [PATCH 02/20] sync tox.ini --- tox.ini | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/tox.ini b/tox.ini index 1999d4b..0eedef2 100644 --- a/tox.ini +++ b/tox.ini @@ -9,7 +9,9 @@ envlist = py39 py310 py311 + py312 isolated_build = True +skip_missing_interpreters = False [gh-actions] python = @@ -17,8 +19,11 @@ python = 3.9: py39 3.10: py310 3.11: py311 + 3.12: py312 [testenv] +whitelist_externals = + coverage extras = test commands = From 3f1dfb796f9ed3666cc8d3cb236f0240b0ab1573 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 16:03:19 -0600 Subject: [PATCH 03/20] sync mypy.ini --- mypy.ini | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mypy.ini b/mypy.ini index ff3681c..8a39d78 100644 --- a/mypy.ini +++ b/mypy.ini @@ -2,7 +2,6 @@ show_error_codes = True exclude = (?x)( setup\.py -; | tests/ | docs/ ) @@ -10,4 +9,5 @@ exclude = (?x)( disallow_untyped_defs = True [mypy-tests.*] +disallow_untyped_defs = True ignore_missing_imports = True From f3566e753dacf86510d704177dad55c3dc6cdd00 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 16:50:49 -0600 Subject: [PATCH 04/20] sync lint.yaml --- .github/workflows/lint.yml | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index a579204..5577de5 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -31,12 +31,10 @@ jobs: pip install -e .[dev] - name: Lint with black run: | - black --check --diff screenpy_selenium - black --check --diff tests + black --check --diff . - name: Lint with ruff run: | ruff check . - name: Lint with mypy run: | - mypy screenpy_selenium - mypy tests + mypy . From c499a8563bf5e7b6ddbb8594befe0924d6ab48bd Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 16:51:55 -0600 Subject: [PATCH 05/20] sync poetry.yml --- .github/workflows/poetry.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/poetry.yml b/.github/workflows/poetry.yml index 05bd919..6d0f8e5 100644 --- a/.github/workflows/poetry.yml +++ b/.github/workflows/poetry.yml @@ -34,6 +34,6 @@ jobs: - name: Check toml structure run: poetry check - + - name: Check lock file run: poetry lock --check From a92a8d50c71cda51b83ebaae4f2a4e2617587e23 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 17:17:46 -0600 Subject: [PATCH 06/20] sync .gitignore --- .gitignore | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.gitignore b/.gitignore index 9b6c533..577b667 100644 --- a/.gitignore +++ b/.gitignore @@ -144,3 +144,6 @@ dmypy.json # Pyre type checker .pyre/ + +# ruff linter +.ruff_cache/ From f89be0b50fd7110a75b8080eef5dd949e266722e Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 17:38:17 -0600 Subject: [PATCH 07/20] test__version__.py --- screenpy_selenium/__version__.py | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/screenpy_selenium/__version__.py b/screenpy_selenium/__version__.py index 8d7be54..57497e6 100644 --- a/screenpy_selenium/__version__.py +++ b/screenpy_selenium/__version__.py @@ -4,12 +4,7 @@ ░█▄▄▄█ ▀▀▀ ▀ ▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ░█ ▄▄▄█ ░█▄▄▄█ ▀▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ▀▀▀ ▀▀▀ ▀ ▀ """ -try: - # importlib.metadata is present in Python 3.8 and later - import importlib.metadata as importlib_metadata # type: ignore -except ImportError: - # use the shim package importlib-metadata pre-3.8 - import importlib_metadata # type: ignore +import importlib.metadata as importlib_metadata metadata = importlib_metadata.metadata("screenpy_selenium") @@ -20,4 +15,4 @@ __author__ = metadata["Author"] __author_email__ = metadata["Author-email"] __license__ = metadata["License"] -__copyright__ = f"2022-2023 {__author__}" +__copyright__ = f"2019-2024 {__author__}" From 2cc5aaad3ea245b032e4ccdcd321e9a5346515d2 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 17:50:12 -0600 Subject: [PATCH 08/20] avoiding https://github.com/ScreenPyHQ/screenpy_selenium/issues/36 --- pyproject.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyproject.toml b/pyproject.toml index 759d4cf..1bc66b8 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -13,7 +13,7 @@ [build-system] -requires = ["poetry-core>=1.2.0"] +requires = ["poetry-core>=1.6.1"] build-backend = "poetry.core.masonry.api" From bee113738a244433ce5327a285870edc5ce8778b Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 17:59:33 -0600 Subject: [PATCH 09/20] adding copyright year test --- tests/test__version__.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/tests/test__version__.py b/tests/test__version__.py index 41540f4..5e6b794 100644 --- a/tests/test__version__.py +++ b/tests/test__version__.py @@ -1,5 +1,7 @@ from __future__ import annotations +from datetime import datetime + from screenpy_selenium import __version__ @@ -7,3 +9,8 @@ def test_metadata() -> None: assert __version__.__title__ == "screenpy_selenium" assert __version__.__license__ == "MIT" assert __version__.__author__ == "Perry Goy" + + +def test_copyright_year() -> None: + current = datetime.now().year + assert f"{current}" in __version__.__copyright__ From 1d3a56994ea761b51216ac9732cf943f7ba3c086 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Wed, 14 Feb 2024 18:12:11 -0600 Subject: [PATCH 10/20] sync conf.py --- docs/conf.py | 21 +++++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/docs/conf.py b/docs/conf.py index 94dcc1a..a325016 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -13,18 +13,21 @@ import os import sys - sys.path.insert(0, os.path.abspath("./ext")) sys.path.insert(0, os.path.abspath("../")) -from screenpy_selenium.__version__ import __version__, __author__, __copyright__ # noqa: need the path first +from screenpy_selenium.__version__ import ( + __version__, + __author__, + __copyright__, +) # noqa: need the path first autodoc_mock_imports = ["selenium", "screenpy", "screenpy_pyotp"] # -- Project information ----------------------------------------------------- -project = 'screenpy_selenium' +project = "screenpy_selenium" copyright = __copyright__ author = __author__ @@ -62,10 +65,16 @@ .. |ActionChains| replace:: :external+selenium:class:`~selenium.webdriver.common.action_chains.ActionChains` """ + + + # List of patterns, relative to source directory, that match files and # directories to ignore when looking for source files. # This pattern also affects html_static_path and html_extra_path. -exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store'] +exclude_patterns = ["_build", "Thumbs.db", ".DS_Store"] + + + # -- Options for HTML output ------------------------------------------------- @@ -73,12 +82,12 @@ # The theme to use for HTML and HTML Help pages. See the documentation for # a list of builtin themes. # -html_theme = 'default' +html_theme = "default" # Add any paths that contain custom static files (such as style sheets) here, # relative to this directory. They are copied after the builtin static files, # so a file named "default.css" will overwrite the builtin "default.css". -html_static_path = ['_static'] +html_static_path = ["_static"] # Other HTML settings autodoc_member_order = "bysource" From 7eea2c689f47a2a27af636b19f74d330a3dae874 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Thu, 15 Feb 2024 09:47:53 -0600 Subject: [PATCH 11/20] setting up docs installation via pyproject.toml --- .readthedocs.yaml | 7 +++++-- pyproject.toml | 6 ++++++ 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/.readthedocs.yaml b/.readthedocs.yaml index e572217..04d4682 100644 --- a/.readthedocs.yaml +++ b/.readthedocs.yaml @@ -3,11 +3,14 @@ version: 2 build: os: "ubuntu-20.04" tools: - python: "3.11" + python: "3.12" sphinx: configuration: docs/conf.py python: install: - - requirements: docs/rtd-requirements.txt + - method: pip + path: . + extra_requirements: + - docs diff --git a/pyproject.toml b/pyproject.toml index 1bc66b8..0ef8661 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -180,6 +180,7 @@ pre-commit = {version = "*", optional = true} pytest = {version = "*", optional = true} ruff = {version = ">=0.2.0", optional = true} sphinx = {version = "*", optional = true} +sphinx-rtd-theme = {version = "*", optional = true} tox = {version = "*", optional = true} [tool.poetry.extras] @@ -191,9 +192,14 @@ dev = [ "pytest", "ruff", "sphinx", + "sphinx-rtd-theme", "tox", ] test = [ "coverage", "pytest", ] +docs = [ + "sphinx", + "sphinx-rtd-theme", +] From 440c2a77b64f311c2c063eabe4fa71d99029bc41 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Thu, 15 Feb 2024 09:58:00 -0600 Subject: [PATCH 12/20] update lock --- poetry.lock | 38 ++++++++++++++++++++++++++++++++++++-- 1 file changed, 36 insertions(+), 2 deletions(-) diff --git a/poetry.lock b/poetry.lock index 6512e1a..0136b4d 100644 --- a/poetry.lock +++ b/poetry.lock @@ -1285,6 +1285,25 @@ docs = ["sphinxcontrib-websupport"] lint = ["docutils-stubs", "flake8 (>=3.5.0)", "flake8-simplify", "isort", "mypy (>=0.990)", "ruff", "sphinx-lint", "types-requests"] test = ["cython", "filelock", "html5lib", "pytest (>=4.6)"] +[[package]] +name = "sphinx-rtd-theme" +version = "2.0.0" +description = "Read the Docs theme for Sphinx" +optional = true +python-versions = ">=3.6" +files = [ + {file = "sphinx_rtd_theme-2.0.0-py2.py3-none-any.whl", hash = "sha256:ec93d0856dc280cf3aee9a4c9807c60e027c7f7b461b77aeffed682e68f0e586"}, + {file = "sphinx_rtd_theme-2.0.0.tar.gz", hash = "sha256:bd5d7b80622406762073a04ef8fadc5f9151261563d47027de09910ce03afe6b"}, +] + +[package.dependencies] +docutils = "<0.21" +sphinx = ">=5,<8" +sphinxcontrib-jquery = ">=4,<5" + +[package.extras] +dev = ["bump2version", "sphinxcontrib-httpdomain", "transifex-client", "wheel"] + [[package]] name = "sphinxcontrib-applehelp" version = "1.0.4" @@ -1330,6 +1349,20 @@ files = [ lint = ["docutils-stubs", "flake8", "mypy"] test = ["html5lib", "pytest"] +[[package]] +name = "sphinxcontrib-jquery" +version = "4.1" +description = "Extension to include jQuery on newer Sphinx releases" +optional = true +python-versions = ">=2.7" +files = [ + {file = "sphinxcontrib-jquery-4.1.tar.gz", hash = "sha256:1620739f04e36a2c779f1a131a2dfd49b2fd07351bf1968ced074365933abc7a"}, + {file = "sphinxcontrib_jquery-4.1-py2.py3-none-any.whl", hash = "sha256:f936030d7d0147dd026a4f2b5a57343d233f1fc7b363f68b3d4f1cb0993878ae"}, +] + +[package.dependencies] +Sphinx = ">=1.8" + [[package]] name = "sphinxcontrib-jsmath" version = "1.0.1" @@ -1529,10 +1562,11 @@ docs = ["furo", "jaraco.packaging (>=9.3)", "jaraco.tidelift (>=1.4)", "rst.link testing = ["big-O", "jaraco.functools", "jaraco.itertools", "more-itertools", "pytest (>=6)", "pytest-black (>=0.3.7)", "pytest-checkdocs (>=2.4)", "pytest-cov", "pytest-enabler (>=2.2)", "pytest-ignore-flaky", "pytest-mypy (>=0.9.1)", "pytest-ruff"] [extras] -dev = ["black", "coverage", "mypy", "pre-commit", "pytest", "ruff", "sphinx", "tox"] +dev = ["black", "coverage", "mypy", "pre-commit", "pytest", "ruff", "sphinx", "sphinx-rtd-theme", "tox"] +docs = ["sphinx", "sphinx-rtd-theme"] test = ["coverage", "pytest"] [metadata] lock-version = "2.0" python-versions = "^3.8" -content-hash = "11e295386bfc306fbbc02b2612fa571eaa6e30fdee1f2c5b6f403d34c3fb3b9e" +content-hash = "c0d2a1ed45a89c7d474720e5a8075f4cb4d3cbd286caaafb9061884b4dd73c65" From 62d84fa79450588f78b9eb96c3a004400bb14d7d Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Thu, 15 Feb 2024 13:36:24 -0600 Subject: [PATCH 13/20] centering ascii art --- screenpy_selenium/__version__.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/screenpy_selenium/__version__.py b/screenpy_selenium/__version__.py index 57497e6..f758839 100644 --- a/screenpy_selenium/__version__.py +++ b/screenpy_selenium/__version__.py @@ -1,7 +1,7 @@ """ - ░█▀▀▀█ █▀▀ █▀▀█ █▀▀ █▀▀ █▀▀▄ ░█▀▀█ █ █ ░█▀▀▀█ █▀▀ █ █▀▀ █▀▀▄ ▀ █ █ █▀▄▀█ - ▀▀▀▄▄ █ █▄▄▀ █▀▀ █▀▀ █ █ ░█▄▄█ █▄▄█ ▀▀▀▄▄ █▀▀ █ █▀▀ █ █ ▀█▀ █ █ █ ▀ █ - ░█▄▄▄█ ▀▀▀ ▀ ▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ░█ ▄▄▄█ ░█▄▄▄█ ▀▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ▀▀▀ ▀▀▀ ▀ ▀ + ░█▀▀▀█ █▀▀ █▀▀█ █▀▀ █▀▀ █▀▀▄ ░█▀▀█ █ █ ░█▀▀▀█ █▀▀ █ █▀▀ █▀▀▄ ▀ █ █ █▀▄▀█ + ▀▀▀▄▄ █ █▄▄▀ █▀▀ █▀▀ █ █ ░█▄▄█ █▄▄█ ▀▀▀▄▄ █▀▀ █ █▀▀ █ █ ▀█▀ █ █ █ ▀ █ + ░█▄▄▄█ ▀▀▀ ▀ ▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ░█ ▄▄▄█ ░█▄▄▄█ ▀▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ▀▀▀ ▀▀▀ ▀ ▀ """ import importlib.metadata as importlib_metadata From a7e16c0a3ba2483787311b5ad96f3cd073c2c89f Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Thu, 15 Feb 2024 13:45:21 -0600 Subject: [PATCH 14/20] adjusting boilerplate pyproject.toml --- pyproject.toml | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 0ef8661..8da41fd 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -7,8 +7,9 @@ # PIP: # pip install -e .[dev] +# everything in the boilerplate *SHOULD* match between the ScreenPyHQ packages. ################################################################################ -# the following sections do not contain unique configurations to this package. +# START OF BOILERPLATE ScreenPyHQ CONFIGURATIONS # ################################################################################ @@ -126,7 +127,7 @@ split-on-trailing-comma = false ################################################################################ -# the following sections contain unique configurations to this package. +# END OF BOILERPLATE ScreenPyHQ CONFIGURATIONS # ################################################################################ [tool.poetry] From fe81954921c060fcd73400758b62dc04874f9999 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Thu, 15 Feb 2024 16:05:35 -0600 Subject: [PATCH 15/20] cleaner test format --- tests/test__version__.py | 1 + 1 file changed, 1 insertion(+) diff --git a/tests/test__version__.py b/tests/test__version__.py index 5e6b794..7d9ea92 100644 --- a/tests/test__version__.py +++ b/tests/test__version__.py @@ -13,4 +13,5 @@ def test_metadata() -> None: def test_copyright_year() -> None: current = datetime.now().year + assert f"{current}" in __version__.__copyright__ From 693a4516f2169ade51d04449f2f5d9cd2d3b0fa7 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Fri, 16 Feb 2024 11:04:13 -0600 Subject: [PATCH 16/20] sync conf.py --- docs/conf.py | 66 ++++++++++++++++++---------------------------------- 1 file changed, 22 insertions(+), 44 deletions(-) diff --git a/docs/conf.py b/docs/conf.py index a325016..0b02a68 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -1,7 +1,6 @@ # Configuration file for the Sphinx documentation builder. # -# This file only contains a selection of the most common options. For a full -# list see the documentation: +# For the full list of built-in configuration values, see the documentation: # https://www.sphinx-doc.org/en/master/usage/configuration.html # -- Path setup -------------------------------------------------------------- @@ -9,52 +8,40 @@ # If extensions (or modules to document with autodoc) are in another directory, # add these directories to sys.path here. If the directory is relative to the # documentation root, use os.path.abspath to make it absolute, like shown here. - +# import os import sys sys.path.insert(0, os.path.abspath("./ext")) sys.path.insert(0, os.path.abspath("../")) -from screenpy_selenium.__version__ import ( - __version__, - __author__, - __copyright__, -) # noqa: need the path first +from screenpy_selenium.__version__ import __version__, __author__, __copyright__ autodoc_mock_imports = ["selenium", "screenpy", "screenpy_pyotp"] # -- Project information ----------------------------------------------------- +# https://www.sphinx-doc.org/en/master/usage/configuration.html#project-information project = "screenpy_selenium" copyright = __copyright__ author = __author__ - -# The full version, including alpha/beta/rc tags release = __version__ # -- General configuration --------------------------------------------------- +# https://www.sphinx-doc.org/en/master/usage/configuration.html#general-configuration -# Add any Sphinx extension module names here, as strings. They can be -# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom -# ones. extensions = [ - "sphinx.ext.intersphinx", "sphinx.ext.autodoc", "sphinx.ext.autosectionlabel", + "sphinx.ext.intersphinx", + "sphinx_rtd_theme", "autodoc_skip_protocols", ] -intersphinx_mapping = { - "screenpy": ("https://screenpy-docs.readthedocs.io/en/latest/", None), - "selenium": ("https://selenium-python.readthedocs.io/", None), - "screenpy_pyotp": ("https://screenpy-pyotp-docs.readthedocs.io/en/latest/", None), -} - -# Add any paths that contain templates here, relative to this directory. -templates_path = ["_templates"] +templates_path = ['_templates'] +exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store'] rst_prolog = """.. Substitutions @@ -65,30 +52,21 @@ .. |ActionChains| replace:: :external+selenium:class:`~selenium.webdriver.common.action_chains.ActionChains` """ - - - -# List of patterns, relative to source directory, that match files and -# directories to ignore when looking for source files. -# This pattern also affects html_static_path and html_extra_path. -exclude_patterns = ["_build", "Thumbs.db", ".DS_Store"] - - - - - # -- Options for HTML output ------------------------------------------------- +# https://www.sphinx-doc.org/en/master/usage/configuration.html#options-for-html-output -# The theme to use for HTML and HTML Help pages. See the documentation for -# a list of builtin themes. -# -html_theme = "default" - -# Add any paths that contain custom static files (such as style sheets) here, -# relative to this directory. They are copied after the builtin static files, -# so a file named "default.css" will overwrite the builtin "default.css". -html_static_path = ["_static"] +html_theme = "sphinx_rtd_theme" +html_static_path = [] -# Other HTML settings autodoc_member_order = "bysource" add_module_names = False + + +# -- Options for intersphinx extension --------------------------------------- + +# Example configuration for intersphinx: refer to the Python standard library. +intersphinx_mapping = { + "screenpy": ("https://screenpy-docs.readthedocs.io/en/latest/", None), + "selenium": ("https://selenium-python.readthedocs.io/", None), + "screenpy_pyotp": ("https://screenpy-pyotp-docs.readthedocs.io/en/latest/", None), +} From ab25e33d495446027d0f2e2b5f697835f59019cd Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Fri, 16 Feb 2024 11:04:31 -0600 Subject: [PATCH 17/20] adding license copyright test --- tests/test__version__.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/tests/test__version__.py b/tests/test__version__.py index 7d9ea92..c6358c0 100644 --- a/tests/test__version__.py +++ b/tests/test__version__.py @@ -1,6 +1,7 @@ from __future__ import annotations from datetime import datetime +from pathlib import Path from screenpy_selenium import __version__ @@ -15,3 +16,12 @@ def test_copyright_year() -> None: current = datetime.now().year assert f"{current}" in __version__.__copyright__ + + +def test_copyright_year_in_license() -> None: + current = datetime.now().year + license_path = Path(__file__).parent / ".." / "LICENSE" + with open(license_path) as fp: + license_text = fp.read() + + assert f"{current}" in license_text From 7a7eb6765fc0171453e1f4294249825e6b1e51d2 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Fri, 16 Feb 2024 11:14:11 -0600 Subject: [PATCH 18/20] update license copyright year --- LICENSE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/LICENSE b/LICENSE index d8edffb..799975a 100644 --- a/LICENSE +++ b/LICENSE @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2022-2023 Perry Goy +Copyright (c) 2022-2024 Perry Goy Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal From 3cc514d0b05531a2d519f3ebe013c7b8584438c3 Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Sat, 17 Feb 2024 12:57:46 -0600 Subject: [PATCH 19/20] sync pyproject.toml --- pyproject.toml | 3 +-- screenpy_selenium/__init__.py | 18 +++++++++--------- screenpy_selenium/__version__.py | 4 ++-- 3 files changed, 12 insertions(+), 13 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 8da41fd..c44b8c3 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -39,8 +39,6 @@ extend-exclude = ''' target-version = "py38" # minimum supported version line-length = 88 # same as Black. extend-exclude = [ - "__init__.py", - "__version__.py", "docs", ] @@ -124,6 +122,7 @@ split-on-trailing-comma = false "FBT", # using a boolean as a test object is useful! "PLR", # likewise using specific numbers and strings in tests. ] +"__version__.py" = ["D"] ################################################################################ diff --git a/screenpy_selenium/__init__.py b/screenpy_selenium/__init__.py index 43e4413..6599584 100644 --- a/screenpy_selenium/__init__.py +++ b/screenpy_selenium/__init__.py @@ -1,28 +1,28 @@ -# -*- coding: utf-8 -*- - # ░█▀▀▀█ █▀▀ █▀▀█ █▀▀ █▀▀ █▀▀▄ ░█▀▀█ █ █ ░█▀▀▀█ █▀▀ █ █▀▀ █▀▀▄ ▀ █ █ █▀▄▀█ # ▀▀▀▄▄ █ █▄▄▀ █▀▀ █▀▀ █ █ ░█▄▄█ █▄▄█ ▀▀▀▄▄ █▀▀ █ █▀▀ █ █ ▀█▀ █ █ █ ▀ █ # ░█▄▄▄█ ▀▀▀ ▀ ▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ░█ ▄▄▄█ ░█▄▄▄█ ▀▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ▀▀▀ ▀▀▀ ▀ ▀ """ - ScreenPy Selenium + ScreenPy Selenium. + FADE IN: -INT. SITEPACKAGES DIRECTORY + +INT. SITEPACKAGES DIRECTORY. ScreenPy Selenium is an extension for ScreenPy, enabling interaction with Selenium. -:copyright: (c) 2022–2023, Perry Goy. +:copyright: (c) 2022-2024, Perry Goy. :license: MIT, see LICENSE for more details. """ from . import abilities, actions, questions, resolutions -from .abilities import * # noqa: F401, F403 -from .actions import * # noqa: F401, F403 +from .abilities import * # noqa: F403 +from .actions import * # noqa: F403 from .exceptions import BrowsingError, TargetingError from .protocols import Chainable -from .questions import * # noqa: F401, F403 -from .resolutions import * # noqa: F401, F403 +from .questions import * # noqa: F403 +from .resolutions import * # noqa: F403 from .target import Target __all__ = [ diff --git a/screenpy_selenium/__version__.py b/screenpy_selenium/__version__.py index f758839..956301e 100644 --- a/screenpy_selenium/__version__.py +++ b/screenpy_selenium/__version__.py @@ -4,9 +4,9 @@ ░█▄▄▄█ ▀▀▀ ▀ ▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ░█ ▄▄▄█ ░█▄▄▄█ ▀▀▀ ▀▀▀ ▀▀▀ ▀ ▀ ▀▀▀ ▀▀▀ ▀ ▀ """ -import importlib.metadata as importlib_metadata +import importlib.metadata -metadata = importlib_metadata.metadata("screenpy_selenium") +metadata = importlib.metadata.metadata("screenpy_selenium") __title__ = metadata["Name"] __description__ = metadata["Summary"] From 6aabe8ca80ff699c2c5a34b1c7636e99b960a79c Mon Sep 17 00:00:00 2001 From: Marcel Wilson Date: Sat, 17 Feb 2024 13:55:52 -0600 Subject: [PATCH 20/20] adding test for copyright in `__init__.py` --- tests/test__version__.py | 18 ------------------ tests/test_copyright.py | 27 +++++++++++++++++++++++++++ 2 files changed, 27 insertions(+), 18 deletions(-) create mode 100644 tests/test_copyright.py diff --git a/tests/test__version__.py b/tests/test__version__.py index c6358c0..41540f4 100644 --- a/tests/test__version__.py +++ b/tests/test__version__.py @@ -1,8 +1,5 @@ from __future__ import annotations -from datetime import datetime -from pathlib import Path - from screenpy_selenium import __version__ @@ -10,18 +7,3 @@ def test_metadata() -> None: assert __version__.__title__ == "screenpy_selenium" assert __version__.__license__ == "MIT" assert __version__.__author__ == "Perry Goy" - - -def test_copyright_year() -> None: - current = datetime.now().year - - assert f"{current}" in __version__.__copyright__ - - -def test_copyright_year_in_license() -> None: - current = datetime.now().year - license_path = Path(__file__).parent / ".." / "LICENSE" - with open(license_path) as fp: - license_text = fp.read() - - assert f"{current}" in license_text diff --git a/tests/test_copyright.py b/tests/test_copyright.py new file mode 100644 index 0000000..f3b0784 --- /dev/null +++ b/tests/test_copyright.py @@ -0,0 +1,27 @@ +from __future__ import annotations + +from datetime import datetime +from pathlib import Path + +import pytest + +from screenpy_selenium import __doc__, __version__ + + +class TestCopyrightYear: + @pytest.fixture(autouse=True) + def _setup(self) -> None: + self.current_year = datetime.now().year + + def test_version(self) -> None: + assert f"{self.current_year}" in __version__.__copyright__ + + def test_license(self) -> None: + license_path = Path(__file__).parent / ".." / "LICENSE" + with open(license_path) as fp: + license_text = fp.read() + + assert f"{self.current_year}" in license_text + + def test_init(self) -> None: + assert f"{self.current_year}" in __doc__