From 0b640601322c51bbd2f0c66a4a2d6a93a7fbc6d5 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 14:02:01 +0100 Subject: [PATCH 01/48] #61 Added cli params to the pytest-extension --- pytest-extension/README.md | 4 + .../exasol/pytest_extension/__init__.py | 145 ++++++++++----- pytest-extension/poetry.lock | 169 +++++++++++++----- pytest-extension/pyproject.toml | 2 + .../test/integration/pytest_extension_test.py | 55 +++++- 5 files changed, 281 insertions(+), 94 deletions(-) diff --git a/pytest-extension/README.md b/pytest-extension/README.md index c8a0382..61d8665 100644 --- a/pytest-extension/README.md +++ b/pytest-extension/README.md @@ -36,4 +36,8 @@ def test_something_else(bucketfs_connection_factory): ... ``` +The next two fixtures are used to test various deployment scenarios. The first one collects the CLI parameters +required to open a database connection. + + Note, that by default the tests will run twice - once for each backend. diff --git a/pytest-extension/exasol/pytest_extension/__init__.py b/pytest-extension/exasol/pytest_extension/__init__.py index f70c983..4059118 100644 --- a/pytest-extension/exasol/pytest_extension/__init__.py +++ b/pytest-extension/exasol/pytest_extension/__init__.py @@ -1,54 +1,15 @@ from __future__ import annotations from typing import Any, Callable -import json import random import string +from urllib.parse import urlparse import pyexasol import pytest from exasol.pytest_backend import BACKEND_ONPREM, BACKEND_SAAS - - -def _to_json_str(bucketfs_params: dict[str, Any], selected: list[str]) -> str: - filtered_kwargs = {k: v for k, v in bucketfs_params.items() - if (k in selected) and (v is not None)} - return json.dumps(filtered_kwargs) - - -def _create_bucketfs_connection(pyexasol_connection: pyexasol.ExaConnection, - conn_name: str, - conn_to: str, - conn_user: str, - conn_password: str) -> None: - - query = (f"CREATE OR REPLACE CONNECTION {conn_name} " - f"TO '{conn_to}' " - f"USER '{conn_user}' " - f"IDENTIFIED BY '{conn_password}'") - pyexasol_connection.execute(query) - - -def _create_bucketfs_connection_onprem(pyexasol_connection: pyexasol.ExaConnection, - conn_name: str, - bucketfs_params: dict[str, Any]) -> None: - conn_to = _to_json_str(bucketfs_params, [ - 'backend', 'url', 'service_name', 'bucket_name', 'path', 'verify']) - conn_user = _to_json_str(bucketfs_params, ['username']) - conn_password = _to_json_str(bucketfs_params, ['password']) - - _create_bucketfs_connection(pyexasol_connection, conn_name, - conn_to, conn_user, conn_password) - - -def _create_bucketfs_connection_saas(pyexasol_connection: pyexasol.ExaConnection, - conn_name: str, - bucketfs_params: dict[str, Any]) -> None: - conn_to = _to_json_str(bucketfs_params, ['backend', 'url', 'path']) - conn_user = _to_json_str(bucketfs_params, ['account_id', 'database_id']) - conn_password = _to_json_str(bucketfs_params, ['pat']) - - _create_bucketfs_connection(pyexasol_connection, conn_name, - conn_to, conn_user, conn_password) +from exasol.python_extension_common.cli.std_options import StdParams +from exasol.python_extension_common.connections.bucketfs_location import ( + create_bucketfs_conn_object_onprem, create_bucketfs_conn_object_saas) @pytest.fixture(scope="session") @@ -105,10 +66,104 @@ def func(conn_name: str, path_in_bucket: str | None = None) -> None: else: bucketfs_params = backend_aware_bucketfs_params if backend == BACKEND_ONPREM: - _create_bucketfs_connection_onprem(pyexasol_connection, conn_name, bucketfs_params) + create_bucketfs_conn_object_onprem(pyexasol_connection, conn_name, bucketfs_params) elif backend == BACKEND_SAAS: - _create_bucketfs_connection_saas(pyexasol_connection, conn_name, bucketfs_params) + create_bucketfs_conn_object_saas(pyexasol_connection, conn_name, bucketfs_params) else: raise ValueError(f'Unsupported backend {backend}') return func + + +@pytest.fixture(scope="session") +def onprem_database_std_params(use_onprem, + backend_aware_onprem_database, + exasol_config) -> dict[str, Any]: + if use_onprem: + return { + StdParams.dsn.name: f'{exasol_config.host}:{exasol_config.port}', + StdParams.db_user.name: exasol_config.username, + StdParams.db_password.name: exasol_config.password, + StdParams.use_ssl_cert_validation.name: False + } + return {} + + +@pytest.fixture(scope="session") +def onprem_bucketfs_std_params(use_onprem, + backend_aware_onprem_database, + bucketfs_config) -> dict[str, Any]: + if use_onprem: + parsed_url = urlparse(bucketfs_config.url) + host, port = parsed_url.netloc.split(":") + return { + StdParams.bucketfs_host.name: host, + StdParams.bucketfs_port.name: port, + StdParams.bucketfs_use_https.name: parsed_url.scheme.lower() == 'https', + StdParams.bucketfs_user.name: bucketfs_config.username, + StdParams.bucketfs_password.name: bucketfs_config.password, + StdParams.bucketfs_name.name: 'bfsdefault', + StdParams.bucket.name: 'default', + StdParams.use_ssl_cert_validation.name: False + } + return {} + + +@pytest.fixture(scope="session") +def saas_std_params(use_saas, + saas_host, + saas_pat, + saas_account_id, + backend_aware_saas_database_id) -> dict[str, Any]: + if use_saas: + return { + StdParams.saas_url.name: saas_host, + StdParams.saas_account_id.name: saas_account_id, + StdParams.saas_database_id.name: backend_aware_saas_database_id, + StdParams.saas_token.name: saas_pat + } + return {} + + +@pytest.fixture(scope="session") +def database_std_params(backend, + onprem_database_std_params, + saas_std_params) -> dict[str, Any]: + if backend == BACKEND_ONPREM: + return onprem_database_std_params + elif backend == BACKEND_SAAS: + return saas_std_params + else: + ValueError(f'Unknown backend {backend}') + + +@pytest.fixture(scope="session") +def bucketfs_std_params(backend, + onprem_bucketfs_std_params, + saas_std_params) -> dict[str, Any]: + if backend == BACKEND_ONPREM: + return onprem_bucketfs_std_params + elif backend == BACKEND_SAAS: + return saas_std_params + else: + ValueError(f'Unknown backend {backend}') + + +def _params_to_args(**kwargs) -> str: + def arg_string(k: str, v: Any): + k = k.replace("_", "-") + if isinstance(v, bool): + return f'--{k}' if v else f'--no-{k}' + return f'--{k} "{v}"' + + return ' '.join(arg_string(k, v) for k, v in kwargs.items()) + + +@pytest.fixture(scope='session') +def database_cli_args(database_std_params) -> str: + return _params_to_args(database_std_params) + + +@pytest.fixture(scope='session') +def bucketfs_cli_args(bucketfs_std_params) -> str: + return _params_to_args(bucketfs_std_params) diff --git a/pytest-extension/poetry.lock b/pytest-extension/poetry.lock index 338370a..3f9bf80 100644 --- a/pytest-extension/poetry.lock +++ b/pytest-extension/poetry.lock @@ -1,4 +1,4 @@ -# This file is automatically @generated by Poetry 1.8.3 and should not be changed by hand. +# This file is automatically @generated by Poetry 1.8.2 and should not be changed by hand. [[package]] name = "alabaster" @@ -50,13 +50,13 @@ test = ["coverage", "flake8", "mypy", "pexpect", "wheel"] [[package]] name = "astroid" -version = "3.3.4" +version = "3.3.5" description = "An abstract syntax tree for Python with inference support." optional = false python-versions = ">=3.9.0" files = [ - {file = "astroid-3.3.4-py3-none-any.whl", hash = "sha256:5eba185467253501b62a9f113c263524b4f5d55e1b30456370eed4cdbd6438fd"}, - {file = "astroid-3.3.4.tar.gz", hash = "sha256:e73d0b62dd680a7c07cb2cd0ce3c22570b044dd01bd994bc3a2dd16c6cbba162"}, + {file = "astroid-3.3.5-py3-none-any.whl", hash = "sha256:a9d1c946ada25098d790e079ba2a1b112157278f3fb7e718ae6a9252f5835dc8"}, + {file = "astroid-3.3.5.tar.gz", hash = "sha256:5cfc40ae9f68311075d27ef68a4841bdc5cc7f6cf86671b49f00607d30188e2d"}, ] [package.dependencies] @@ -607,13 +607,13 @@ dev = ["PyTest", "PyTest-Cov", "bump2version (<1)", "sphinx (<2)", "tox"] [[package]] name = "dill" -version = "0.3.8" +version = "0.3.9" description = "serialize all of Python" optional = false python-versions = ">=3.8" files = [ - {file = "dill-0.3.8-py3-none-any.whl", hash = "sha256:c36ca9ffb54365bdd2f8eb3eff7d2a21237f8452b57ace88b1ac615b7e815bd7"}, - {file = "dill-0.3.8.tar.gz", hash = "sha256:3ebe3c479ad625c4553aca177444d89b486b1d84982eeacded644afc0cf797ca"}, + {file = "dill-0.3.9-py3-none-any.whl", hash = "sha256:468dff3b89520b474c0397703366b7b95eebe6303f108adf9b19da1f702be87a"}, + {file = "dill-0.3.9.tar.gz", hash = "sha256:81aa267dddf68cbfe8029c42ca9ec6a4ab3b22371d1c450abc54422577b4512c"}, ] [package.extras] @@ -725,6 +725,26 @@ requests = ">=2.21.0" simplejson = ">=3.16.0" "stopwatch.py" = ">=1.0.0" +[[package]] +name = "exasol-python-extension-common" +version = "0.7.0" +description = "A collection of common utilities for Exasol extensions." +optional = false +python-versions = "<4.0.0,>=3.10.0" +files = [ + {file = "exasol_python_extension_common-0.7.0-py3-none-any.whl", hash = "sha256:ee4b77263648ca97716ccb372c2257b61141d5ce35d75b30bda63e788c214801"}, + {file = "exasol_python_extension_common-0.7.0.tar.gz", hash = "sha256:7e6b10dc5593d63a1333e57d8d5b8ceb0f5eec632b8a31740f1a03fbc0c3eabc"}, +] + +[package.dependencies] +click = ">=8.1.7,<9.0.0" +exasol-bucketfs = ">=0.10.0" +exasol-saas-api = ">=0.7.0,<1.0.0" +exasol-script-languages-container-tool = ">=1.0.0,<2.0.0" +pyexasol = ">=0.25.0,<1.0.0" +requests = ">=2.32.0" +tenacity = ">=8.3.0,<9.0.0" + [[package]] name = "exasol-saas-api" version = "0.10.0" @@ -745,6 +765,24 @@ requests = ">=2.31.0,<3.0.0" tenacity = ">=8.2.3,<9.0.0" types-requests = ">=2.31.0.6,<3.0.0.0" +[[package]] +name = "exasol-script-languages-container-tool" +version = "1.0.0" +description = "Script Languages Container Tool" +optional = false +python-versions = "<4,>=3.10" +files = [ + {file = "exasol_script_languages_container_tool-1.0.0-py3-none-any.whl", hash = "sha256:8b87243782266f55b1bd6c153275cba1f55a8406bca99c2d4d37934b3e8bcad4"}, + {file = "exasol_script_languages_container_tool-1.0.0.tar.gz", hash = "sha256:39f0da9e8a55bc0fec1477f5d6c03761ef0abbd841bfc5909253e12e1ae0bcc1"}, +] + +[package.dependencies] +exasol-bucketfs = ">=0.13.0,<0.14.0" +exasol-integration-test-docker-environment = ">=3.1.0,<4.0.0" +importlib_metadata = ">=4.6.0" +importlib-resources = ">=6.4.0" +networkx = ">=3.3.0,<4.0.0" + [[package]] name = "exasol-toolbox" version = "0.9.0" @@ -887,13 +925,13 @@ files = [ [[package]] name = "httpcore" -version = "1.0.5" +version = "1.0.6" description = "A minimal low-level HTTP client." optional = false python-versions = ">=3.8" files = [ - {file = "httpcore-1.0.5-py3-none-any.whl", hash = "sha256:421f18bac248b25d310f3cacd198d55b8e6125c107797b609ff9b7a6ba7991b5"}, - {file = "httpcore-1.0.5.tar.gz", hash = "sha256:34a38e2f9291467ee3b44e89dd52615370e152954ba21721378a87b2960f7a61"}, + {file = "httpcore-1.0.6-py3-none-any.whl", hash = "sha256:27b59625743b85577a8c0e10e55b50b5368a4f2cfe8cc7bcfa9cf00829c2682f"}, + {file = "httpcore-1.0.6.tar.gz", hash = "sha256:73f6dbd6eb8c21bbf7ef8efad555481853f5f6acdeaff1edb0694289269ee17f"}, ] [package.dependencies] @@ -904,7 +942,7 @@ h11 = ">=0.13,<0.15" asyncio = ["anyio (>=4.0,<5.0)"] http2 = ["h2 (>=3,<5)"] socks = ["socksio (==1.*)"] -trio = ["trio (>=0.22.0,<0.26.0)"] +trio = ["trio (>=0.22.0,<1.0)"] [[package]] name = "httpx" @@ -995,6 +1033,29 @@ files = [ {file = "imagesize-1.4.1.tar.gz", hash = "sha256:69150444affb9cb0d5cc5a92b3676f0b2fb7cd9ae39e947a5e11a36b4497cd4a"}, ] +[[package]] +name = "importlib-metadata" +version = "8.5.0" +description = "Read metadata from Python packages" +optional = false +python-versions = ">=3.8" +files = [ + {file = "importlib_metadata-8.5.0-py3-none-any.whl", hash = "sha256:45e54197d28b7a7f1559e60b95e7c567032b602131fbd588f1497f47880aa68b"}, + {file = "importlib_metadata-8.5.0.tar.gz", hash = "sha256:71522656f0abace1d072b9e5481a48f07c138e00f079c38c8f883823f9c26bd7"}, +] + +[package.dependencies] +zipp = ">=3.20" + +[package.extras] +check = ["pytest-checkdocs (>=2.4)", "pytest-ruff (>=0.2.1)"] +cover = ["pytest-cov"] +doc = ["furo", "jaraco.packaging (>=9.3)", "jaraco.tidelift (>=1.4)", "rst.linker (>=1.9)", "sphinx (>=3.5)", "sphinx-lint"] +enabler = ["pytest-enabler (>=2.2)"] +perf = ["ipython"] +test = ["flufl.flake8", "importlib-resources (>=1.3)", "jaraco.test (>=5.4)", "packaging", "pyfakefs", "pytest (>=6,!=8.1.*)", "pytest-perf (>=0.9.2)"] +type = ["pytest-mypy"] + [[package]] name = "importlib-resources" version = "6.4.5" @@ -1560,13 +1621,13 @@ files = [ [[package]] name = "pydot" -version = "3.0.1" +version = "3.0.2" description = "Python interface to Graphviz's Dot" optional = false python-versions = ">=3.8" files = [ - {file = "pydot-3.0.1-py3-none-any.whl", hash = "sha256:43f1e878dc1ff7c1c2e3470a6999d4e9e97771c5c862440c2f0af0ba844c231f"}, - {file = "pydot-3.0.1.tar.gz", hash = "sha256:e18cf7f287c497d77b536a3d20a46284568fea390776dface6eabbdf1b1b5efc"}, + {file = "pydot-3.0.2-py3-none-any.whl", hash = "sha256:99cedaa55d04abb0b2bc56d9981a6da781053dd5ac75c428e8dd53db53f90b14"}, + {file = "pydot-3.0.2.tar.gz", hash = "sha256:9180da540b51b3aa09fbf81140b3edfbe2315d778e8589a7d0a4a69c41332bae"}, ] [package.dependencies] @@ -1575,7 +1636,7 @@ pyparsing = ">=3.0.9" [package.extras] dev = ["chardet", "parameterized", "ruff"] release = ["zest.releaser[recommended]"] -tests = ["chardet", "parameterized", "ruff", "tox", "unittest-parallel"] +tests = ["chardet", "parameterized", "pytest", "pytest-cov", "pytest-xdist[psutil]", "ruff", "tox"] [[package]] name = "pyexasol" @@ -1820,25 +1881,29 @@ tokenize-rt = ">=5.2.0" [[package]] name = "pywin32" -version = "306" +version = "307" description = "Python for Window Extensions" optional = false python-versions = "*" files = [ - {file = "pywin32-306-cp310-cp310-win32.whl", hash = "sha256:06d3420a5155ba65f0b72f2699b5bacf3109f36acbe8923765c22938a69dfc8d"}, - {file = "pywin32-306-cp310-cp310-win_amd64.whl", hash = "sha256:84f4471dbca1887ea3803d8848a1616429ac94a4a8d05f4bc9c5dcfd42ca99c8"}, - {file = "pywin32-306-cp311-cp311-win32.whl", hash = "sha256:e65028133d15b64d2ed8f06dd9fbc268352478d4f9289e69c190ecd6818b6407"}, - {file = "pywin32-306-cp311-cp311-win_amd64.whl", hash = "sha256:a7639f51c184c0272e93f244eb24dafca9b1855707d94c192d4a0b4c01e1100e"}, - {file = "pywin32-306-cp311-cp311-win_arm64.whl", hash = "sha256:70dba0c913d19f942a2db25217d9a1b726c278f483a919f1abfed79c9cf64d3a"}, - {file = "pywin32-306-cp312-cp312-win32.whl", hash = "sha256:383229d515657f4e3ed1343da8be101000562bf514591ff383ae940cad65458b"}, - {file = "pywin32-306-cp312-cp312-win_amd64.whl", hash = "sha256:37257794c1ad39ee9be652da0462dc2e394c8159dfd913a8a4e8eb6fd346da0e"}, - {file = "pywin32-306-cp312-cp312-win_arm64.whl", hash = "sha256:5821ec52f6d321aa59e2db7e0a35b997de60c201943557d108af9d4ae1ec7040"}, - {file = "pywin32-306-cp37-cp37m-win32.whl", hash = "sha256:1c73ea9a0d2283d889001998059f5eaaba3b6238f767c9cf2833b13e6a685f65"}, - {file = "pywin32-306-cp37-cp37m-win_amd64.whl", hash = "sha256:72c5f621542d7bdd4fdb716227be0dd3f8565c11b280be6315b06ace35487d36"}, - {file = "pywin32-306-cp38-cp38-win32.whl", hash = "sha256:e4c092e2589b5cf0d365849e73e02c391c1349958c5ac3e9d5ccb9a28e017b3a"}, - {file = "pywin32-306-cp38-cp38-win_amd64.whl", hash = "sha256:e8ac1ae3601bee6ca9f7cb4b5363bf1c0badb935ef243c4733ff9a393b1690c0"}, - {file = "pywin32-306-cp39-cp39-win32.whl", hash = "sha256:e25fd5b485b55ac9c057f67d94bc203f3f6595078d1fb3b458c9c28b7153a802"}, - {file = "pywin32-306-cp39-cp39-win_amd64.whl", hash = "sha256:39b61c15272833b5c329a2989999dcae836b1eed650252ab1b7bfbe1d59f30f4"}, + {file = "pywin32-307-cp310-cp310-win32.whl", hash = "sha256:f8f25d893c1e1ce2d685ef6d0a481e87c6f510d0f3f117932781f412e0eba31b"}, + {file = "pywin32-307-cp310-cp310-win_amd64.whl", hash = "sha256:36e650c5e5e6b29b5d317385b02d20803ddbac5d1031e1f88d20d76676dd103d"}, + {file = "pywin32-307-cp310-cp310-win_arm64.whl", hash = "sha256:0c12d61e0274e0c62acee79e3e503c312426ddd0e8d4899c626cddc1cafe0ff4"}, + {file = "pywin32-307-cp311-cp311-win32.whl", hash = "sha256:fec5d27cc893178fab299de911b8e4d12c5954e1baf83e8a664311e56a272b75"}, + {file = "pywin32-307-cp311-cp311-win_amd64.whl", hash = "sha256:987a86971753ed7fdd52a7fb5747aba955b2c7fbbc3d8b76ec850358c1cc28c3"}, + {file = "pywin32-307-cp311-cp311-win_arm64.whl", hash = "sha256:fd436897c186a2e693cd0437386ed79f989f4d13d6f353f8787ecbb0ae719398"}, + {file = "pywin32-307-cp312-cp312-win32.whl", hash = "sha256:07649ec6b01712f36debf39fc94f3d696a46579e852f60157a729ac039df0815"}, + {file = "pywin32-307-cp312-cp312-win_amd64.whl", hash = "sha256:00d047992bb5dcf79f8b9b7c81f72e0130f9fe4b22df613f755ab1cc021d8347"}, + {file = "pywin32-307-cp312-cp312-win_arm64.whl", hash = "sha256:b53658acbfc6a8241d72cc09e9d1d666be4e6c99376bc59e26cdb6223c4554d2"}, + {file = "pywin32-307-cp313-cp313-win32.whl", hash = "sha256:ea4d56e48dc1ab2aa0a5e3c0741ad6e926529510516db7a3b6981a1ae74405e5"}, + {file = "pywin32-307-cp313-cp313-win_amd64.whl", hash = "sha256:576d09813eaf4c8168d0bfd66fb7cb3b15a61041cf41598c2db4a4583bf832d2"}, + {file = "pywin32-307-cp313-cp313-win_arm64.whl", hash = "sha256:b30c9bdbffda6a260beb2919f918daced23d32c79109412c2085cbc513338a0a"}, + {file = "pywin32-307-cp37-cp37m-win32.whl", hash = "sha256:5101472f5180c647d4525a0ed289ec723a26231550dbfd369ec19d5faf60e511"}, + {file = "pywin32-307-cp37-cp37m-win_amd64.whl", hash = "sha256:05de55a7c110478dc4b202230e98af5e0720855360d2b31a44bb4e296d795fba"}, + {file = "pywin32-307-cp38-cp38-win32.whl", hash = "sha256:13d059fb7f10792542082f5731d5d3d9645320fc38814759313e5ee97c3fac01"}, + {file = "pywin32-307-cp38-cp38-win_amd64.whl", hash = "sha256:7e0b2f93769d450a98ac7a31a087e07b126b6d571e8b4386a5762eb85325270b"}, + {file = "pywin32-307-cp39-cp39-win32.whl", hash = "sha256:55ee87f2f8c294e72ad9d4261ca423022310a6e79fb314a8ca76ab3f493854c6"}, + {file = "pywin32-307-cp39-cp39-win_amd64.whl", hash = "sha256:e9d5202922e74985b037c9ef46778335c102b74b95cec70f629453dbe7235d87"}, ] [[package]] @@ -1926,18 +1991,19 @@ use-chardet-on-py3 = ["chardet (>=3.0.2,<6)"] [[package]] name = "rich" -version = "13.8.1" +version = "13.9.2" description = "Render rich text, tables, progress bars, syntax highlighting, markdown and more to the terminal" optional = false -python-versions = ">=3.7.0" +python-versions = ">=3.8.0" files = [ - {file = "rich-13.8.1-py3-none-any.whl", hash = "sha256:1760a3c0848469b97b558fc61c85233e3dafb69c7a071b4d60c38099d3cd4c06"}, - {file = "rich-13.8.1.tar.gz", hash = "sha256:8260cda28e3db6bf04d2d1ef4dbc03ba80a824c88b0e7668a0f23126a424844a"}, + {file = "rich-13.9.2-py3-none-any.whl", hash = "sha256:8c82a3d3f8dcfe9e734771313e606b39d8247bb6b826e196f4914b333b743cf1"}, + {file = "rich-13.9.2.tar.gz", hash = "sha256:51a2c62057461aaf7152b4d611168f93a9fc73068f8ded2790f29fe2b5366d0c"}, ] [package.dependencies] markdown-it-py = ">=2.2.0" pygments = ">=2.13.0,<3.0.0" +typing-extensions = {version = ">=4.0.0,<5.0", markers = "python_version < \"3.11\""} [package.extras] jupyter = ["ipywidgets (>=7.5.1,<9)"] @@ -2363,13 +2429,13 @@ files = [ [[package]] name = "tomli" -version = "2.0.1" +version = "2.0.2" description = "A lil' TOML parser" optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "tomli-2.0.1-py3-none-any.whl", hash = "sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc"}, - {file = "tomli-2.0.1.tar.gz", hash = "sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f"}, + {file = "tomli-2.0.2-py3-none-any.whl", hash = "sha256:2ebe24485c53d303f690b0ec092806a085f07af5a5aa1464f3931eec36caaa38"}, + {file = "tomli-2.0.2.tar.gz", hash = "sha256:d46d457a85337051c36524bc5349dd91b1877838e2979ac5ced3e710ed8a60ed"}, ] [[package]] @@ -2482,13 +2548,13 @@ zstd = ["zstandard (>=0.18.0)"] [[package]] name = "virtualenv" -version = "20.26.5" +version = "20.26.6" description = "Virtual Python Environment builder" optional = false python-versions = ">=3.7" files = [ - {file = "virtualenv-20.26.5-py3-none-any.whl", hash = "sha256:4f3ac17b81fba3ce3bd6f4ead2749a72da5929c01774948e243db9ba41df4ff6"}, - {file = "virtualenv-20.26.5.tar.gz", hash = "sha256:ce489cac131aa58f4b25e321d6d186171f78e6cb13fafbf32a840cee67733ff4"}, + {file = "virtualenv-20.26.6-py3-none-any.whl", hash = "sha256:7345cc5b25405607a624d8418154577459c3e0277f5466dd79c49d5e492995f2"}, + {file = "virtualenv-20.26.6.tar.gz", hash = "sha256:280aede09a2a5c317e409a00102e7077c6432c5a38f0ef938e643805a7ad2c48"}, ] [package.dependencies] @@ -2595,7 +2661,26 @@ files = [ {file = "wrapt-1.16.0.tar.gz", hash = "sha256:5f370f952971e7d17c7d1ead40e49f32345a7f7a5373571ef44d800d06b1899d"}, ] +[[package]] +name = "zipp" +version = "3.20.2" +description = "Backport of pathlib-compatible object wrapper for zip files" +optional = false +python-versions = ">=3.8" +files = [ + {file = "zipp-3.20.2-py3-none-any.whl", hash = "sha256:a817ac80d6cf4b23bf7f2828b7cabf326f15a001bea8b1f9b49631780ba28350"}, + {file = "zipp-3.20.2.tar.gz", hash = "sha256:bc9eb26f4506fda01b81bcde0ca78103b6e62f991b381fec825435c836edbc29"}, +] + +[package.extras] +check = ["pytest-checkdocs (>=2.4)", "pytest-ruff (>=0.2.1)"] +cover = ["pytest-cov"] +doc = ["furo", "jaraco.packaging (>=9.3)", "jaraco.tidelift (>=1.4)", "rst.linker (>=1.9)", "sphinx (>=3.5)", "sphinx-lint"] +enabler = ["pytest-enabler (>=2.2)"] +test = ["big-O", "importlib-resources", "jaraco.functools", "jaraco.itertools", "jaraco.test", "more-itertools", "pytest (>=6,!=8.1.*)", "pytest-ignore-flaky"] +type = ["pytest-mypy"] + [metadata] lock-version = "2.0" python-versions = ">=3.10,<4" -content-hash = "752af8728551e419c3991a2aa3de5f952a78c6ddbc9b8e30dba4302b0f77071f" +content-hash = "a02cd1c68a38920eab6386dc4ff78d458b3dc17c3b35a6c54fcc6a1781b653bb" diff --git a/pytest-extension/pyproject.toml b/pytest-extension/pyproject.toml index 982fb5a..7d502d4 100644 --- a/pytest-extension/pyproject.toml +++ b/pytest-extension/pyproject.toml @@ -11,6 +11,7 @@ python = ">=3.10,<4" pytest = ">=7,<9" pytest-exasol-backend = ">=0.2.0" pyexasol = ">=0.26.0,<1" +exasol-python-extension-common = ">=0.7.0,<1" [tool.poetry.plugins.pytest11] ext = "exasol.pytest_extension" @@ -18,6 +19,7 @@ ext = "exasol.pytest_extension" [tool.poetry.group.dev.dependencies] exasol-toolbox = "0.9.0" exasol-bucketfs = ">=0.12.0" +click = "^8.1.7" [build-system] requires = ["poetry-core"] diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index d5755c7..4af3dbe 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -1,7 +1,7 @@ from textwrap import dedent import pytest -from exasol.pytest_backend import (BACKEND_OPTION, BACKEND_ALL) +from exasol.pytest_backend import (BACKEND_OPTION, BACKEND_ALL, BACKEND_ONPREM) pytest_plugins = ["pytester"] @@ -10,9 +10,16 @@ def test_extension_all_backends(pytester): test_code = dedent(r""" import json import pytest + import click + from click.testing import CliRunner import exasol.bucketfs as bfs + from exasol.python_extension_common.connections.pyexasol_connection import open_pyexasol_connection + from exasol.python_extension_common.connections.bucketfs_location import create_bucketfs_location + from exasol.python_extension_common.cli.std_options import StdParams, (StdTags, select_std_options) + from exasol.pytest_backend import (BACKEND_ONPREM, BACKEND_SAAS) TEST_SCHEMA = 'PYTEXT_TEST_SCHEMA' + TEST_FILE_CONTENT = b'Gravity Sucks' @pytest.fixture(scope="session") def db_schema_name() -> str: @@ -29,9 +36,8 @@ def test_bucketfs_connection_factory(bucketfs_connection_factory, udf_name = 'EXTRACT_CONNECTION_OBJECT' # Write something to the bucket - file_content = b'Gravity Sucks' bfs_path = bfs.path.build_path(**backend_aware_bucketfs_params, path=path_in_bucket) - bfs_path.write(file_content) + bfs_path.write(TEST_FILE_CONTENT) # Create a connection object bucketfs_connection_factory(conn_name, path_in_bucket) @@ -56,11 +62,46 @@ def test_bucketfs_connection_factory(bucketfs_connection_factory, # Read from the bucket using data in the connection object bfs_params = json.loads(bfs_params_str) bfs_path = bfs.path.build_path(**bfs_params) - file_content_back = b"".join(bfs_path.read()) + file_content = b"".join(bfs_path.read()) - assert file_content_back == file_content + assert file_content == TEST_FILE_CONTENT + + def validate_database_std_params(**kwargs): + with open_pyexasol_connection(**kwargs) as conn: + res = conn.execute('SELECT SESSION_ID FROM SYS.EXA_ALL_SESSIONS;').fetchall() + assert res + + def validate_bucketfs_std_params(**kwargs): + bfs_path = create_bucketfs_location(**kwargs) + bfs_path.write(TEST_FILE_CONTENT) + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT + + def validate_cli_args(backend, cli_args, base_tag, callback): + if backend == BACKEND_ONPREM: + tags = base_tag | StdTags.ONPREM + elif backend == BACKEND_SAAS: + tags = base_tag | StdTags.SAAS + else: + ValueError(f'Unknown backend {backend}') + opts = select_std_options(tags) + cmd = click.Command('whatever', params=opts, callback=callback) + runner = CliRunner() + runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=False) + + def test_database_std_params(database_std_params): + validate_database_std_params(**database_std_params) + + def test_bucketfs_std_params(bucketfs_std_params): + validate_bucketfs_std_params(**bucketfs_std_params, path_in_bucket='test_bucketfs_std_params') + + def test_database_cli_args(backend, database_cli_args): + validate_cli_args(backend, database_cli_args, StdTags.DB, validate_database_std_params) + + def test_bucketfs_cli_args(backend, bucketfs_cli_args) + validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) """) pytester.makepyfile(test_code) - result = pytester.runpytest(BACKEND_OPTION, BACKEND_ALL) + result = pytester.runpytest(BACKEND_OPTION, BACKEND_ONPREM) assert result.ret == pytest.ExitCode.OK - result.assert_outcomes(passed=4, skipped=0) + result.assert_outcomes(passed=6, skipped=6) From 7f1402341d1663d78fe97f02201357293a27ced9 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 14:05:34 +0100 Subject: [PATCH 02/48] #61 Added cli params to the pytest-extension --- justfile | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/justfile b/justfile index 75228fc..83a3fe9 100644 --- a/justfile +++ b/justfile @@ -1,4 +1,5 @@ -PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" +# PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" +PROJECTS := "pytest-extension" # Default target default: From 32981f58dab6ae6f16ac1defd871adebfde8cfad Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 14:09:50 +0100 Subject: [PATCH 03/48] #61 Fixed the pytest_extension_test.py --- pytest-extension/test/integration/pytest_extension_test.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 4af3dbe..7c12d87 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -15,7 +15,7 @@ def test_extension_all_backends(pytester): import exasol.bucketfs as bfs from exasol.python_extension_common.connections.pyexasol_connection import open_pyexasol_connection from exasol.python_extension_common.connections.bucketfs_location import create_bucketfs_location - from exasol.python_extension_common.cli.std_options import StdParams, (StdTags, select_std_options) + from exasol.python_extension_common.cli.std_options import (StdParams, StdTags, select_std_options) from exasol.pytest_backend import (BACKEND_ONPREM, BACKEND_SAAS) TEST_SCHEMA = 'PYTEXT_TEST_SCHEMA' From 2b321aa402d89b8d0baec100c4fea45230ed99e2 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 14:11:49 +0100 Subject: [PATCH 04/48] #61 Fixed the pytest_extension_test.py --- pytest-extension/test/integration/pytest_extension_test.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 7c12d87..2031b03 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -98,7 +98,7 @@ def test_bucketfs_std_params(bucketfs_std_params): def test_database_cli_args(backend, database_cli_args): validate_cli_args(backend, database_cli_args, StdTags.DB, validate_database_std_params) - def test_bucketfs_cli_args(backend, bucketfs_cli_args) + def test_bucketfs_cli_args(backend, bucketfs_cli_args): validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) """) pytester.makepyfile(test_code) From e359f8e4e397f4d958ea01fbb1646e28cfaec0bc Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 14:20:02 +0100 Subject: [PATCH 05/48] #61 Fixed _cli_params_to_args() --- pytest-extension/exasol/pytest_extension/__init__.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/pytest-extension/exasol/pytest_extension/__init__.py b/pytest-extension/exasol/pytest_extension/__init__.py index 4059118..7a61f47 100644 --- a/pytest-extension/exasol/pytest_extension/__init__.py +++ b/pytest-extension/exasol/pytest_extension/__init__.py @@ -149,21 +149,21 @@ def bucketfs_std_params(backend, ValueError(f'Unknown backend {backend}') -def _params_to_args(**kwargs) -> str: +def _cli_params_to_args(cli_params) -> str: def arg_string(k: str, v: Any): k = k.replace("_", "-") if isinstance(v, bool): return f'--{k}' if v else f'--no-{k}' return f'--{k} "{v}"' - return ' '.join(arg_string(k, v) for k, v in kwargs.items()) + return ' '.join(arg_string(k, v) for k, v in cli_params.items()) @pytest.fixture(scope='session') def database_cli_args(database_std_params) -> str: - return _params_to_args(database_std_params) + return _cli_params_to_args(database_std_params) @pytest.fixture(scope='session') def bucketfs_cli_args(bucketfs_std_params) -> str: - return _params_to_args(bucketfs_std_params) + return _cli_params_to_args(bucketfs_std_params) From 1628f4f6401322709ff1809c2601577c85d2981f Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 14:43:46 +0100 Subject: [PATCH 06/48] #61 Fixed _cli_params_to_args() --- pytest-extension/exasol/pytest_extension/__init__.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/pytest-extension/exasol/pytest_extension/__init__.py b/pytest-extension/exasol/pytest_extension/__init__.py index 7a61f47..da28faf 100644 --- a/pytest-extension/exasol/pytest_extension/__init__.py +++ b/pytest-extension/exasol/pytest_extension/__init__.py @@ -166,4 +166,8 @@ def database_cli_args(database_std_params) -> str: @pytest.fixture(scope='session') def bucketfs_cli_args(bucketfs_std_params) -> str: - return _cli_params_to_args(bucketfs_std_params) + cli_args = _cli_params_to_args(bucketfs_std_params) + # Work around for the bug in PEC, the StdParams.path_in_bucket not having a default value. + if StdParams.path_in_bucket not in bucketfs_std_params: + cli_args += f' -{StdParams.path_in_bucket.name.replace("_", "-")} ""' + return cli_args From c53c2ceecda286b370b32826ad5c3186a1ece9ce Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 14:50:19 +0100 Subject: [PATCH 07/48] #61 Fixed _cli_params_to_args() --- pytest-extension/exasol/pytest_extension/__init__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pytest-extension/exasol/pytest_extension/__init__.py b/pytest-extension/exasol/pytest_extension/__init__.py index da28faf..d4a00cd 100644 --- a/pytest-extension/exasol/pytest_extension/__init__.py +++ b/pytest-extension/exasol/pytest_extension/__init__.py @@ -169,5 +169,5 @@ def bucketfs_cli_args(bucketfs_std_params) -> str: cli_args = _cli_params_to_args(bucketfs_std_params) # Work around for the bug in PEC, the StdParams.path_in_bucket not having a default value. if StdParams.path_in_bucket not in bucketfs_std_params: - cli_args += f' -{StdParams.path_in_bucket.name.replace("_", "-")} ""' + cli_args += f' --{StdParams.path_in_bucket.name.replace("_", "-")} ""' return cli_args From e52e09ef86149adc473498a8bb81fc7c8f5a2445 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 15:09:31 +0100 Subject: [PATCH 08/48] #61 Fixed the pytest-extension integration test --- pytest-extension/test/integration/pytest_extension_test.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 2031b03..2850860 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -37,6 +37,7 @@ def test_bucketfs_connection_factory(bucketfs_connection_factory, # Write something to the bucket bfs_path = bfs.path.build_path(**backend_aware_bucketfs_params, path=path_in_bucket) + bfs_path = bfs_path / 'test_file1.txt' bfs_path.write(TEST_FILE_CONTENT) # Create a connection object @@ -72,7 +73,7 @@ def validate_database_std_params(**kwargs): assert res def validate_bucketfs_std_params(**kwargs): - bfs_path = create_bucketfs_location(**kwargs) + bfs_path = create_bucketfs_location(**kwargs) / 'test_file2.txt' bfs_path.write(TEST_FILE_CONTENT) file_content = b"".join(bfs_path.read()) assert file_content == TEST_FILE_CONTENT From 49646dbb36f7322a65ff24a6261075d6f3e0535a Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 15:43:39 +0100 Subject: [PATCH 09/48] #61 Fixed the pytest-extension integration test --- pytest-extension/test/integration/pytest_extension_test.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 2850860..bfde9e5 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -37,7 +37,6 @@ def test_bucketfs_connection_factory(bucketfs_connection_factory, # Write something to the bucket bfs_path = bfs.path.build_path(**backend_aware_bucketfs_params, path=path_in_bucket) - bfs_path = bfs_path / 'test_file1.txt' bfs_path.write(TEST_FILE_CONTENT) # Create a connection object @@ -73,7 +72,7 @@ def validate_database_std_params(**kwargs): assert res def validate_bucketfs_std_params(**kwargs): - bfs_path = create_bucketfs_location(**kwargs) / 'test_file2.txt' + bfs_path = create_bucketfs_location(**kwargs) / 'test_file.txt' bfs_path.write(TEST_FILE_CONTENT) file_content = b"".join(bfs_path.read()) assert file_content == TEST_FILE_CONTENT From 46f6f9d979b21277766384d6b98f5b37338da344 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 16:23:11 +0100 Subject: [PATCH 10/48] #61 Fixed the pytest-extension integration test --- .../exasol/pytest_extension/__init__.py | 16 +++++++++++++++- .../test/integration/pytest_extension_test.py | 4 ++-- 2 files changed, 17 insertions(+), 3 deletions(-) diff --git a/pytest-extension/exasol/pytest_extension/__init__.py b/pytest-extension/exasol/pytest_extension/__init__.py index d4a00cd..5367300 100644 --- a/pytest-extension/exasol/pytest_extension/__init__.py +++ b/pytest-extension/exasol/pytest_extension/__init__.py @@ -129,6 +129,10 @@ def saas_std_params(use_saas, def database_std_params(backend, onprem_database_std_params, saas_std_params) -> dict[str, Any]: + """ + This is a collection of StdParams parameters required to open a + database connection for either DockerDB or SaaS test database. + """ if backend == BACKEND_ONPREM: return onprem_database_std_params elif backend == BACKEND_SAAS: @@ -141,6 +145,10 @@ def database_std_params(backend, def bucketfs_std_params(backend, onprem_bucketfs_std_params, saas_std_params) -> dict[str, Any]: + """ + This is a collection of StdParams parameters required to connect + to the BucketFS on either DockerDB or SaaS test database. + """ if backend == BACKEND_ONPREM: return onprem_bucketfs_std_params elif backend == BACKEND_SAAS: @@ -161,13 +169,19 @@ def arg_string(k: str, v: Any): @pytest.fixture(scope='session') def database_cli_args(database_std_params) -> str: + """ + CLI argument string for testing a command that involves connecting to the database. + """ return _cli_params_to_args(database_std_params) @pytest.fixture(scope='session') def bucketfs_cli_args(bucketfs_std_params) -> str: + """ + CLI argument string for testing a command that involves connecting to the BucketFS . + """ cli_args = _cli_params_to_args(bucketfs_std_params) - # Work around for the bug in PEC, the StdParams.path_in_bucket not having a default value. + # Work around for the bug in PEC (Issue#78 - no default for the StdParams.path_in_bucket) if StdParams.path_in_bucket not in bucketfs_std_params: cli_args += f' --{StdParams.path_in_bucket.name.replace("_", "-")} ""' return cli_args diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index bfde9e5..1a49cb4 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -74,8 +74,8 @@ def validate_database_std_params(**kwargs): def validate_bucketfs_std_params(**kwargs): bfs_path = create_bucketfs_location(**kwargs) / 'test_file.txt' bfs_path.write(TEST_FILE_CONTENT) - file_content = b"".join(bfs_path.read()) - assert file_content == TEST_FILE_CONTENT + # file_content = b"".join(bfs_path.read()) + # assert file_content == TEST_FILE_CONTENT def validate_cli_args(backend, cli_args, base_tag, callback): if backend == BACKEND_ONPREM: From 961fd0c1bc610f6a891b586b5af35b05ca7b39ca Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 16:32:12 +0100 Subject: [PATCH 11/48] #61 Fixed the pytest-extension integration test --- pytest-extension/test/integration/pytest_extension_test.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 1a49cb4..5ba7d1b 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -74,8 +74,8 @@ def validate_database_std_params(**kwargs): def validate_bucketfs_std_params(**kwargs): bfs_path = create_bucketfs_location(**kwargs) / 'test_file.txt' bfs_path.write(TEST_FILE_CONTENT) - # file_content = b"".join(bfs_path.read()) - # assert file_content == TEST_FILE_CONTENT + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT def validate_cli_args(backend, cli_args, base_tag, callback): if backend == BACKEND_ONPREM: @@ -103,5 +103,8 @@ def test_bucketfs_cli_args(backend, bucketfs_cli_args): """) pytester.makepyfile(test_code) result = pytester.runpytest(BACKEND_OPTION, BACKEND_ONPREM) + if result.ret != pytest.ExitCode.OK: + print(result.stderr) + print(result.stdout) assert result.ret == pytest.ExitCode.OK result.assert_outcomes(passed=6, skipped=6) From 59d1bd63d841d6dcbd75e9f10156812df3ab85a9 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 16:38:47 +0100 Subject: [PATCH 12/48] #61 Fixed the pytest-extension integration test --- .../test/integration/pytest_extension_test.py | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 5ba7d1b..9580445 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -72,10 +72,11 @@ def validate_database_std_params(**kwargs): assert res def validate_bucketfs_std_params(**kwargs): - bfs_path = create_bucketfs_location(**kwargs) / 'test_file.txt' - bfs_path.write(TEST_FILE_CONTENT) - file_content = b"".join(bfs_path.read()) - assert file_content == TEST_FILE_CONTENT + pass + # bfs_path = create_bucketfs_location(**kwargs) / 'test_file.txt' + # bfs_path.write(TEST_FILE_CONTENT) + # file_content = b"".join(bfs_path.read()) + # assert file_content == TEST_FILE_CONTENT def validate_cli_args(backend, cli_args, base_tag, callback): if backend == BACKEND_ONPREM: From d8c79c355e98f3968aff6f5d05650009dab98216 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 16:42:38 +0100 Subject: [PATCH 13/48] #61 Fixed the pytest-extension integration test --- pytest-extension/test/integration/pytest_extension_test.py | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 9580445..c368447 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -72,8 +72,8 @@ def validate_database_std_params(**kwargs): assert res def validate_bucketfs_std_params(**kwargs): - pass - # bfs_path = create_bucketfs_location(**kwargs) / 'test_file.txt' + bfs_path = create_bucketfs_location(**kwargs) + # bfs_path = bfs_path / 'test_file.txt' # bfs_path.write(TEST_FILE_CONTENT) # file_content = b"".join(bfs_path.read()) # assert file_content == TEST_FILE_CONTENT @@ -104,8 +104,5 @@ def test_bucketfs_cli_args(backend, bucketfs_cli_args): """) pytester.makepyfile(test_code) result = pytester.runpytest(BACKEND_OPTION, BACKEND_ONPREM) - if result.ret != pytest.ExitCode.OK: - print(result.stderr) - print(result.stdout) assert result.ret == pytest.ExitCode.OK result.assert_outcomes(passed=6, skipped=6) From 9ec47a6a595ab79a5564b410fac7e98eba5043a4 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 17:13:41 +0100 Subject: [PATCH 14/48] #61 Fixed the pytest-extension integration test --- .github/workflows/ci.yml | 3 +- pytest-extension/test/integration/tmp_test.py | 103 ++++++++++++++++++ 2 files changed, 105 insertions(+), 1 deletion(-) create mode 100644 pytest-extension/test/integration/tmp_test.py diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 22fe0db..ff53902 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -34,7 +34,8 @@ jobs: - name: Run Tests of All Plugins run: | echo "PYTEST_ADDOPTS = $PYTEST_ADDOPTS" - just test + # just test + poetry run pytest -s -backend=onprem pytest-extension/test/integration/tmp_test.py env: SAAS_HOST: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_HOST }} SAAS_ACCOUNT_ID: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_ACCOUNT_ID }} diff --git a/pytest-extension/test/integration/tmp_test.py b/pytest-extension/test/integration/tmp_test.py new file mode 100644 index 0000000..8dec9c7 --- /dev/null +++ b/pytest-extension/test/integration/tmp_test.py @@ -0,0 +1,103 @@ +import json +import pytest +import click +from click.testing import CliRunner +import exasol.bucketfs as bfs +from exasol.python_extension_common.connections.pyexasol_connection import open_pyexasol_connection +from exasol.python_extension_common.connections.bucketfs_location import create_bucketfs_location +from exasol.python_extension_common.cli.std_options import (StdParams, StdTags, select_std_options) +from exasol.pytest_backend import (BACKEND_ONPREM, BACKEND_SAAS) + +TEST_SCHEMA = 'PYTEXT_TEST_SCHEMA' +TEST_FILE_CONTENT = b'Gravity Sucks' + + +@pytest.fixture(scope="session") +def db_schema_name() -> str: + return TEST_SCHEMA + + +def test_pyexasol_connection(pyexasol_connection): + assert pyexasol_connection.execute(f"SELECT CURRENT_SCHEMA;").fetchval() == TEST_SCHEMA + + +def test_bucketfs_connection_factory(bucketfs_connection_factory, + pyexasol_connection, + backend_aware_bucketfs_params): + conn_name = 'test_connection' + path_in_bucket = 'test_path' + udf_name = 'EXTRACT_CONNECTION_OBJECT' + + # Write something to the bucket + bfs_path = bfs.path.build_path(**backend_aware_bucketfs_params, path=path_in_bucket) + bfs_path.write(TEST_FILE_CONTENT) + + # Create a connection object + bucketfs_connection_factory(conn_name, path_in_bucket) + + # Extract the content of this connection object + sql = ( + f'CREATE OR REPLACE PYTHON3 SCALAR SCRIPT "{udf_name}"()\n' + 'RETURNS VARCHAR(1024) AS\n' + 'import json\n' + 'def run(ctx):\n' + f' conn_obj = exa.get_connection("{conn_name}")\n' + ' bfs_params = json.loads(conn_obj.address)\n' + ' bfs_params.update(json.loads(conn_obj.user))\n' + ' bfs_params.update(json.loads(conn_obj.password))\n' + ' return json.dumps(bfs_params)\n' + '/' + ) + pyexasol_connection.execute(sql) + sql = f'SELECT "{udf_name}"();' + bfs_params_str = pyexasol_connection.execute(sql).fetchval() + + # Read from the bucket using data in the connection object + bfs_params = json.loads(bfs_params_str) + bfs_path = bfs.path.build_path(**bfs_params) + file_content = b"".join(bfs_path.read()) + + assert file_content == TEST_FILE_CONTENT + + +def validate_database_std_params(**kwargs): + with open_pyexasol_connection(**kwargs) as conn: + res = conn.execute('SELECT SESSION_ID FROM SYS.EXA_ALL_SESSIONS;').fetchall() + assert res + + +def validate_bucketfs_std_params(**kwargs): + bfs_path = create_bucketfs_location(**kwargs) + bfs_path = bfs_path / 'test_file.txt' + bfs_path.write(TEST_FILE_CONTENT) + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT + + +def validate_cli_args(backend, cli_args, base_tag, callback): + if backend == BACKEND_ONPREM: + tags = base_tag | StdTags.ONPREM + elif backend == BACKEND_SAAS: + tags = base_tag | StdTags.SAAS + else: + ValueError(f'Unknown backend {backend}') + opts = select_std_options(tags) + cmd = click.Command('whatever', params=opts, callback=callback) + runner = CliRunner() + runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=False) + + +def test_database_std_params(database_std_params): + validate_database_std_params(**database_std_params) + + +def test_bucketfs_std_params(bucketfs_std_params): + validate_bucketfs_std_params(**bucketfs_std_params, path_in_bucket='test_bucketfs_std_params') + + +def test_database_cli_args(backend, database_cli_args): + validate_cli_args(backend, database_cli_args, StdTags.DB, validate_database_std_params) + + +def test_bucketfs_cli_args(backend, bucketfs_cli_args): + validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) From def426918d965ba98e1db0a2c5da98cd4562ae6e Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 17:27:14 +0100 Subject: [PATCH 15/48] #61 Fixed the pytest-extension integration test --- .github/workflows/ci.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index ff53902..f8e2566 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -35,9 +35,9 @@ jobs: run: | echo "PYTEST_ADDOPTS = $PYTEST_ADDOPTS" # just test - poetry run pytest -s -backend=onprem pytest-extension/test/integration/tmp_test.py + pytest -s --backend=onprem pytest-extension/test/integration/tmp_test.py env: SAAS_HOST: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_HOST }} SAAS_ACCOUNT_ID: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_ACCOUNT_ID }} SAAS_PAT: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_PAT }} - PYTEST_ADDOPTS: '-o log_cli=true -o log_cli_level=INFO ${{ steps.pytest-markers.outputs.slow-tests }}' + # PYTEST_ADDOPTS: '-o log_cli=true -o log_cli_level=INFO ${{ steps.pytest-markers.outputs.slow-tests }}' From 0cd611bef57bd8f756af4d9aa727158e740088d1 Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 17:36:52 +0100 Subject: [PATCH 16/48] #61 Fixed the pytest-extension integration test --- .github/workflows/ci.yml | 5 ++--- justfile | 3 ++- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index f8e2566..22fe0db 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -34,10 +34,9 @@ jobs: - name: Run Tests of All Plugins run: | echo "PYTEST_ADDOPTS = $PYTEST_ADDOPTS" - # just test - pytest -s --backend=onprem pytest-extension/test/integration/tmp_test.py + just test env: SAAS_HOST: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_HOST }} SAAS_ACCOUNT_ID: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_ACCOUNT_ID }} SAAS_PAT: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_PAT }} - # PYTEST_ADDOPTS: '-o log_cli=true -o log_cli_level=INFO ${{ steps.pytest-markers.outputs.slow-tests }}' + PYTEST_ADDOPTS: '-o log_cli=true -o log_cli_level=INFO ${{ steps.pytest-markers.outputs.slow-tests }}' diff --git a/justfile b/justfile index 83a3fe9..4b4dd75 100644 --- a/justfile +++ b/justfile @@ -17,7 +17,8 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") - run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") + # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") + run(f"poetry -C {p}/ run pytest -s --backend=onprem test/integration/tmp_test.py") sys.exit(rc) relock +projects=PROJECTS: From 642cc6cc08e9dbff0570bf452e0a7ff7565ce1da Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 17:46:03 +0100 Subject: [PATCH 17/48] #61 Fixed the pytest-extension integration test --- justfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/justfile b/justfile index 4b4dd75..1eabbed 100644 --- a/justfile +++ b/justfile @@ -18,7 +18,7 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - run(f"poetry -C {p}/ run pytest -s --backend=onprem test/integration/tmp_test.py") + run(f"poetry -C {p}/ run pytest -s --backend=onprem {p}/test/integration/tmp_test.py") sys.exit(rc) relock +projects=PROJECTS: From 847dfe75bfe875553066fcedd1e3e14a987cac7a Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 17:58:14 +0100 Subject: [PATCH 18/48] #61 Fixed the pytest-extension integration test --- justfile | 2 +- .../test/integration/pytest_extension_test.py | 16 ++++++++++------ 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/justfile b/justfile index 1eabbed..e6ee06e 100644 --- a/justfile +++ b/justfile @@ -18,7 +18,7 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - run(f"poetry -C {p}/ run pytest -s --backend=onprem {p}/test/integration/tmp_test.py") + run(f"poetry -C {p}/ run pytest -s --backend=onprem {p}/test/integration/pytest_extension_test.py") sys.exit(rc) relock +projects=PROJECTS: diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index c368447..af08661 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -72,11 +72,15 @@ def validate_database_std_params(**kwargs): assert res def validate_bucketfs_std_params(**kwargs): - bfs_path = create_bucketfs_location(**kwargs) - # bfs_path = bfs_path / 'test_file.txt' - # bfs_path.write(TEST_FILE_CONTENT) - # file_content = b"".join(bfs_path.read()) - # assert file_content == TEST_FILE_CONTENT + try: + bfs_path = create_bucketfs_location(**kwargs) + bfs_path = bfs_path / 'test_file.txt' + bfs_path.write(TEST_FILE_CONTENT) + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT + except Exception ex: + print(ex) + raise ex def validate_cli_args(backend, cli_args, base_tag, callback): if backend == BACKEND_ONPREM: @@ -103,6 +107,6 @@ def test_bucketfs_cli_args(backend, bucketfs_cli_args): validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) """) pytester.makepyfile(test_code) - result = pytester.runpytest(BACKEND_OPTION, BACKEND_ONPREM) + result = pytester.runpytest('-s', BACKEND_OPTION, BACKEND_ONPREM) assert result.ret == pytest.ExitCode.OK result.assert_outcomes(passed=6, skipped=6) From fc681a299e973bdc2e2adf8f8c29dd540f15193a Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 18:02:06 +0100 Subject: [PATCH 19/48] #61 Fixed the pytest-extension integration test --- pytest-extension/test/integration/pytest_extension_test.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index af08661..d4c2727 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -78,7 +78,7 @@ def validate_bucketfs_std_params(**kwargs): bfs_path.write(TEST_FILE_CONTENT) file_content = b"".join(bfs_path.read()) assert file_content == TEST_FILE_CONTENT - except Exception ex: + except Exception as ex: print(ex) raise ex From 613d55b2f1f60c31dc6d635c0355c900634d663d Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 18:12:29 +0100 Subject: [PATCH 20/48] #61 Fixed the pytest-extension integration test --- .../test/integration/pytest_extension_test.py | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index d4c2727..d3e80a0 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -72,15 +72,11 @@ def validate_database_std_params(**kwargs): assert res def validate_bucketfs_std_params(**kwargs): - try: - bfs_path = create_bucketfs_location(**kwargs) - bfs_path = bfs_path / 'test_file.txt' - bfs_path.write(TEST_FILE_CONTENT) - file_content = b"".join(bfs_path.read()) - assert file_content == TEST_FILE_CONTENT - except Exception as ex: - print(ex) - raise ex + bfs_path = create_bucketfs_location(**kwargs) + bfs_path = bfs_path / 'test_file.txt' + bfs_path.write(TEST_FILE_CONTENT) + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT def validate_cli_args(backend, cli_args, base_tag, callback): if backend == BACKEND_ONPREM: From 27e22ee2992664fab059c7a4ea2fa74a64a4f0dd Mon Sep 17 00:00:00 2001 From: mibe Date: Mon, 7 Oct 2024 18:18:14 +0100 Subject: [PATCH 21/48] #61 Fixed the pytest-extension integration test --- justfile | 4 +- pytest-extension/test/integration/tmp_test.py | 103 ------------------ 2 files changed, 2 insertions(+), 105 deletions(-) delete mode 100644 pytest-extension/test/integration/tmp_test.py diff --git a/justfile b/justfile index e6ee06e..5da6c8d 100644 --- a/justfile +++ b/justfile @@ -17,8 +17,8 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") - # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - run(f"poetry -C {p}/ run pytest -s --backend=onprem {p}/test/integration/pytest_extension_test.py") + run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") + # run(f"poetry -C {p}/ run pytest -s --backend=onprem {p}/test/integration/pytest_extension_test.py") sys.exit(rc) relock +projects=PROJECTS: diff --git a/pytest-extension/test/integration/tmp_test.py b/pytest-extension/test/integration/tmp_test.py deleted file mode 100644 index 8dec9c7..0000000 --- a/pytest-extension/test/integration/tmp_test.py +++ /dev/null @@ -1,103 +0,0 @@ -import json -import pytest -import click -from click.testing import CliRunner -import exasol.bucketfs as bfs -from exasol.python_extension_common.connections.pyexasol_connection import open_pyexasol_connection -from exasol.python_extension_common.connections.bucketfs_location import create_bucketfs_location -from exasol.python_extension_common.cli.std_options import (StdParams, StdTags, select_std_options) -from exasol.pytest_backend import (BACKEND_ONPREM, BACKEND_SAAS) - -TEST_SCHEMA = 'PYTEXT_TEST_SCHEMA' -TEST_FILE_CONTENT = b'Gravity Sucks' - - -@pytest.fixture(scope="session") -def db_schema_name() -> str: - return TEST_SCHEMA - - -def test_pyexasol_connection(pyexasol_connection): - assert pyexasol_connection.execute(f"SELECT CURRENT_SCHEMA;").fetchval() == TEST_SCHEMA - - -def test_bucketfs_connection_factory(bucketfs_connection_factory, - pyexasol_connection, - backend_aware_bucketfs_params): - conn_name = 'test_connection' - path_in_bucket = 'test_path' - udf_name = 'EXTRACT_CONNECTION_OBJECT' - - # Write something to the bucket - bfs_path = bfs.path.build_path(**backend_aware_bucketfs_params, path=path_in_bucket) - bfs_path.write(TEST_FILE_CONTENT) - - # Create a connection object - bucketfs_connection_factory(conn_name, path_in_bucket) - - # Extract the content of this connection object - sql = ( - f'CREATE OR REPLACE PYTHON3 SCALAR SCRIPT "{udf_name}"()\n' - 'RETURNS VARCHAR(1024) AS\n' - 'import json\n' - 'def run(ctx):\n' - f' conn_obj = exa.get_connection("{conn_name}")\n' - ' bfs_params = json.loads(conn_obj.address)\n' - ' bfs_params.update(json.loads(conn_obj.user))\n' - ' bfs_params.update(json.loads(conn_obj.password))\n' - ' return json.dumps(bfs_params)\n' - '/' - ) - pyexasol_connection.execute(sql) - sql = f'SELECT "{udf_name}"();' - bfs_params_str = pyexasol_connection.execute(sql).fetchval() - - # Read from the bucket using data in the connection object - bfs_params = json.loads(bfs_params_str) - bfs_path = bfs.path.build_path(**bfs_params) - file_content = b"".join(bfs_path.read()) - - assert file_content == TEST_FILE_CONTENT - - -def validate_database_std_params(**kwargs): - with open_pyexasol_connection(**kwargs) as conn: - res = conn.execute('SELECT SESSION_ID FROM SYS.EXA_ALL_SESSIONS;').fetchall() - assert res - - -def validate_bucketfs_std_params(**kwargs): - bfs_path = create_bucketfs_location(**kwargs) - bfs_path = bfs_path / 'test_file.txt' - bfs_path.write(TEST_FILE_CONTENT) - file_content = b"".join(bfs_path.read()) - assert file_content == TEST_FILE_CONTENT - - -def validate_cli_args(backend, cli_args, base_tag, callback): - if backend == BACKEND_ONPREM: - tags = base_tag | StdTags.ONPREM - elif backend == BACKEND_SAAS: - tags = base_tag | StdTags.SAAS - else: - ValueError(f'Unknown backend {backend}') - opts = select_std_options(tags) - cmd = click.Command('whatever', params=opts, callback=callback) - runner = CliRunner() - runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=False) - - -def test_database_std_params(database_std_params): - validate_database_std_params(**database_std_params) - - -def test_bucketfs_std_params(bucketfs_std_params): - validate_bucketfs_std_params(**bucketfs_std_params, path_in_bucket='test_bucketfs_std_params') - - -def test_database_cli_args(backend, database_cli_args): - validate_cli_args(backend, database_cli_args, StdTags.DB, validate_database_std_params) - - -def test_bucketfs_cli_args(backend, bucketfs_cli_args): - validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) From 4bcb49e4f0542738842027e83fe7a748a93ead4c Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 08:36:52 +0100 Subject: [PATCH 22/48] #61 Fixed the pytest-extension integration test --- justfile | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/justfile b/justfile index 5da6c8d..e6ee06e 100644 --- a/justfile +++ b/justfile @@ -17,8 +17,8 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") - run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - # run(f"poetry -C {p}/ run pytest -s --backend=onprem {p}/test/integration/pytest_extension_test.py") + # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") + run(f"poetry -C {p}/ run pytest -s --backend=onprem {p}/test/integration/pytest_extension_test.py") sys.exit(rc) relock +projects=PROJECTS: From 4ed3609162b3981848e0c050ec08b2440a7591a1 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 08:54:43 +0100 Subject: [PATCH 23/48] #61 Fixed the pytest-extension integration test --- justfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/justfile b/justfile index e6ee06e..4be7a5c 100644 --- a/justfile +++ b/justfile @@ -18,7 +18,7 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - run(f"poetry -C {p}/ run pytest -s --backend=onprem {p}/test/integration/pytest_extension_test.py") + run(f"poetry -C {p}/ run pytest -s {p}/test/integration/pytest_extension_test.py") sys.exit(rc) relock +projects=PROJECTS: From 8bc31e1a001fc910b51d5ca9cf5532da2ffb0591 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 09:06:01 +0100 Subject: [PATCH 24/48] #61 Fixed the pytest-extension integration test --- justfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/justfile b/justfile index 4be7a5c..aeb6534 100644 --- a/justfile +++ b/justfile @@ -18,7 +18,7 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - run(f"poetry -C {p}/ run pytest -s {p}/test/integration/pytest_extension_test.py") + run(f"poetry -C {p}/ run pytest -s {p}/test") sys.exit(rc) relock +projects=PROJECTS: From ffe27c4765d2f5aea1013be17c24203b2fccfc8d Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 09:17:47 +0100 Subject: [PATCH 25/48] #61 Fixed the pytest-extension integration test --- justfile | 4 +- pytest-backend/poetry.lock | 497 +++++++++++++++++++------------ pytest-backend/pyproject.toml | 4 +- pytest-extension/poetry.lock | 408 ++++++++++++++++---------- pytest-extension/pyproject.toml | 4 +- pytest-slc/poetry.lock | 501 ++++++++++++++++++++------------ pytest-slc/pyproject.toml | 4 +- 7 files changed, 887 insertions(+), 535 deletions(-) diff --git a/justfile b/justfile index aeb6534..c954a39 100644 --- a/justfile +++ b/justfile @@ -17,8 +17,8 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") - # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - run(f"poetry -C {p}/ run pytest -s {p}/test") + run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") + # run(f"poetry -C {p}/ run pytest -s {p}/test") sys.exit(rc) relock +projects=PROJECTS: diff --git a/pytest-backend/poetry.lock b/pytest-backend/poetry.lock index aea87ef..e7188ab 100644 --- a/pytest-backend/poetry.lock +++ b/pytest-backend/poetry.lock @@ -1,4 +1,4 @@ -# This file is automatically @generated by Poetry 1.8.3 and should not be changed by hand. +# This file is automatically @generated by Poetry 1.8.2 and should not be changed by hand. [[package]] name = "alabaster" @@ -35,28 +35,27 @@ trio = ["trio (>=0.26.1)"] [[package]] name = "argcomplete" -version = "2.1.2" +version = "3.5.1" description = "Bash tab completion for argparse" optional = false -python-versions = ">=3.6" +python-versions = ">=3.8" files = [ - {file = "argcomplete-2.1.2-py3-none-any.whl", hash = "sha256:4ba9cdaa28c361d251edce884cd50b4b1215d65cdc881bd204426cdde9f52731"}, - {file = "argcomplete-2.1.2.tar.gz", hash = "sha256:fc82ef070c607b1559b5c720529d63b54d9dcf2dcfc2632b10e6372314a34457"}, + {file = "argcomplete-3.5.1-py3-none-any.whl", hash = "sha256:1a1d148bdaa3e3b93454900163403df41448a248af01b6e849edc5ac08e6c363"}, + {file = "argcomplete-3.5.1.tar.gz", hash = "sha256:eb1ee355aa2557bd3d0145de7b06b2a45b0ce461e1e7813f5d066039ab4177b4"}, ] [package.extras] -lint = ["flake8", "mypy"] -test = ["coverage", "flake8", "mypy", "pexpect", "wheel"] +test = ["coverage", "mypy", "pexpect", "ruff", "wheel"] [[package]] name = "astroid" -version = "3.3.4" +version = "3.3.5" description = "An abstract syntax tree for Python with inference support." optional = false python-versions = ">=3.9.0" files = [ - {file = "astroid-3.3.4-py3-none-any.whl", hash = "sha256:5eba185467253501b62a9f113c263524b4f5d55e1b30456370eed4cdbd6438fd"}, - {file = "astroid-3.3.4.tar.gz", hash = "sha256:e73d0b62dd680a7c07cb2cd0ce3c22570b044dd01bd994bc3a2dd16c6cbba162"}, + {file = "astroid-3.3.5-py3-none-any.whl", hash = "sha256:a9d1c946ada25098d790e079ba2a1b112157278f3fb7e718ae6a9252f5835dc8"}, + {file = "astroid-3.3.5.tar.gz", hash = "sha256:5cfc40ae9f68311075d27ef68a4841bdc5cc7f6cf86671b49f00607d30188e2d"}, ] [package.dependencies] @@ -95,6 +94,31 @@ files = [ [package.extras] dev = ["freezegun (>=1.0,<2.0)", "pytest (>=6.0)", "pytest-cov"] +[[package]] +name = "bandit" +version = "1.7.10" +description = "Security oriented static analyser for python code." +optional = false +python-versions = ">=3.8" +files = [ + {file = "bandit-1.7.10-py3-none-any.whl", hash = "sha256:665721d7bebbb4485a339c55161ac0eedde27d51e638000d91c8c2d68343ad02"}, + {file = "bandit-1.7.10.tar.gz", hash = "sha256:59ed5caf5d92b6ada4bf65bc6437feea4a9da1093384445fed4d472acc6cff7b"}, +] + +[package.dependencies] +colorama = {version = ">=0.3.9", markers = "platform_system == \"Windows\""} +PyYAML = ">=5.3.1" +rich = "*" +stevedore = ">=1.20.0" +tomli = {version = ">=1.1.0", optional = true, markers = "python_version < \"3.11\" and extra == \"toml\""} + +[package.extras] +baseline = ["GitPython (>=3.1.30)"] +sarif = ["jschema-to-python (>=1.2.3)", "sarif-om (>=1.0.4)"] +test = ["beautifulsoup4 (>=4.8.0)", "coverage (>=4.5.4)", "fixtures (>=3.0.0)", "flake8 (>=4.0.0)", "pylint (==1.9.4)", "stestr (>=2.5.0)", "testscenarios (>=0.5.0)", "testtools (>=2.3.0)"] +toml = ["tomli (>=1.1.0)"] +yaml = ["PyYAML"] + [[package]] name = "bcrypt" version = "4.2.0" @@ -158,33 +182,33 @@ lxml = ["lxml"] [[package]] name = "black" -version = "23.12.1" +version = "24.10.0" description = "The uncompromising code formatter." optional = false -python-versions = ">=3.8" +python-versions = ">=3.9" files = [ - {file = "black-23.12.1-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:e0aaf6041986767a5e0ce663c7a2f0e9eaf21e6ff87a5f95cbf3675bfd4c41d2"}, - {file = "black-23.12.1-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:c88b3711d12905b74206227109272673edce0cb29f27e1385f33b0163c414bba"}, - {file = "black-23.12.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a920b569dc6b3472513ba6ddea21f440d4b4c699494d2e972a1753cdc25df7b0"}, - {file = "black-23.12.1-cp310-cp310-win_amd64.whl", hash = "sha256:3fa4be75ef2a6b96ea8d92b1587dd8cb3a35c7e3d51f0738ced0781c3aa3a5a3"}, - {file = "black-23.12.1-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:8d4df77958a622f9b5a4c96edb4b8c0034f8434032ab11077ec6c56ae9f384ba"}, - {file = "black-23.12.1-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:602cfb1196dc692424c70b6507593a2b29aac0547c1be9a1d1365f0d964c353b"}, - {file = "black-23.12.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:9c4352800f14be5b4864016882cdba10755bd50805c95f728011bcb47a4afd59"}, - {file = "black-23.12.1-cp311-cp311-win_amd64.whl", hash = "sha256:0808494f2b2df923ffc5723ed3c7b096bd76341f6213989759287611e9837d50"}, - {file = "black-23.12.1-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:25e57fd232a6d6ff3f4478a6fd0580838e47c93c83eaf1ccc92d4faf27112c4e"}, - {file = "black-23.12.1-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:2d9e13db441c509a3763a7a3d9a49ccc1b4e974a47be4e08ade2a228876500ec"}, - {file = "black-23.12.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6d1bd9c210f8b109b1762ec9fd36592fdd528485aadb3f5849b2740ef17e674e"}, - {file = "black-23.12.1-cp312-cp312-win_amd64.whl", hash = "sha256:ae76c22bde5cbb6bfd211ec343ded2163bba7883c7bc77f6b756a1049436fbb9"}, - {file = "black-23.12.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:1fa88a0f74e50e4487477bc0bb900c6781dbddfdfa32691e780bf854c3b4a47f"}, - {file = "black-23.12.1-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:a4d6a9668e45ad99d2f8ec70d5c8c04ef4f32f648ef39048d010b0689832ec6d"}, - {file = "black-23.12.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b18fb2ae6c4bb63eebe5be6bd869ba2f14fd0259bda7d18a46b764d8fb86298a"}, - {file = "black-23.12.1-cp38-cp38-win_amd64.whl", hash = "sha256:c04b6d9d20e9c13f43eee8ea87d44156b8505ca8a3c878773f68b4e4812a421e"}, - {file = "black-23.12.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:3e1b38b3135fd4c025c28c55ddfc236b05af657828a8a6abe5deec419a0b7055"}, - {file = "black-23.12.1-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:4f0031eaa7b921db76decd73636ef3a12c942ed367d8c3841a0739412b260a54"}, - {file = "black-23.12.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:97e56155c6b737854e60a9ab1c598ff2533d57e7506d97af5481141671abf3ea"}, - {file = "black-23.12.1-cp39-cp39-win_amd64.whl", hash = "sha256:dd15245c8b68fe2b6bd0f32c1556509d11bb33aec9b5d0866dd8e2ed3dba09c2"}, - {file = "black-23.12.1-py3-none-any.whl", hash = "sha256:78baad24af0f033958cad29731e27363183e140962595def56423e626f4bee3e"}, - {file = "black-23.12.1.tar.gz", hash = "sha256:4ce3ef14ebe8d9509188014d96af1c456a910d5b5cbf434a09fef7e024b3d0d5"}, + {file = "black-24.10.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:e6668650ea4b685440857138e5fe40cde4d652633b1bdffc62933d0db4ed9812"}, + {file = "black-24.10.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:1c536fcf674217e87b8cc3657b81809d3c085d7bf3ef262ead700da345bfa6ea"}, + {file = "black-24.10.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:649fff99a20bd06c6f727d2a27f401331dc0cc861fb69cde910fe95b01b5928f"}, + {file = "black-24.10.0-cp310-cp310-win_amd64.whl", hash = "sha256:fe4d6476887de70546212c99ac9bd803d90b42fc4767f058a0baa895013fbb3e"}, + {file = "black-24.10.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:5a2221696a8224e335c28816a9d331a6c2ae15a2ee34ec857dcf3e45dbfa99ad"}, + {file = "black-24.10.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:f9da3333530dbcecc1be13e69c250ed8dfa67f43c4005fb537bb426e19200d50"}, + {file = "black-24.10.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:4007b1393d902b48b36958a216c20c4482f601569d19ed1df294a496eb366392"}, + {file = "black-24.10.0-cp311-cp311-win_amd64.whl", hash = "sha256:394d4ddc64782e51153eadcaaca95144ac4c35e27ef9b0a42e121ae7e57a9175"}, + {file = "black-24.10.0-cp312-cp312-macosx_10_13_x86_64.whl", hash = "sha256:b5e39e0fae001df40f95bd8cc36b9165c5e2ea88900167bddf258bacef9bbdc3"}, + {file = "black-24.10.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:d37d422772111794b26757c5b55a3eade028aa3fde43121ab7b673d050949d65"}, + {file = "black-24.10.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:14b3502784f09ce2443830e3133dacf2c0110d45191ed470ecb04d0f5f6fcb0f"}, + {file = "black-24.10.0-cp312-cp312-win_amd64.whl", hash = "sha256:30d2c30dc5139211dda799758559d1b049f7f14c580c409d6ad925b74a4208a8"}, + {file = "black-24.10.0-cp313-cp313-macosx_10_13_x86_64.whl", hash = "sha256:1cbacacb19e922a1d75ef2b6ccaefcd6e93a2c05ede32f06a21386a04cedb981"}, + {file = "black-24.10.0-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:1f93102e0c5bb3907451063e08b9876dbeac810e7da5a8bfb7aeb5a9ef89066b"}, + {file = "black-24.10.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:ddacb691cdcdf77b96f549cf9591701d8db36b2f19519373d60d31746068dbf2"}, + {file = "black-24.10.0-cp313-cp313-win_amd64.whl", hash = "sha256:680359d932801c76d2e9c9068d05c6b107f2584b2a5b88831c83962eb9984c1b"}, + {file = "black-24.10.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:17374989640fbca88b6a448129cd1745c5eb8d9547b464f281b251dd00155ccd"}, + {file = "black-24.10.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:63f626344343083322233f175aaf372d326de8436f5928c042639a4afbbf1d3f"}, + {file = "black-24.10.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:ccfa1d0cb6200857f1923b602f978386a3a2758a65b52e0950299ea014be6800"}, + {file = "black-24.10.0-cp39-cp39-win_amd64.whl", hash = "sha256:2cd9c95431d94adc56600710f8813ee27eea544dd118d45896bb734e9d7a0dc7"}, + {file = "black-24.10.0-py3-none-any.whl", hash = "sha256:3bb2b7a1f7b685f85b11fed1ef10f8a9148bceb49853e47a294a3dd963c1dd7d"}, + {file = "black-24.10.0.tar.gz", hash = "sha256:846ea64c97afe3bc677b761787993be4991810ecc7a4a937816dd6bddedc4875"}, ] [package.dependencies] @@ -198,7 +222,7 @@ typing-extensions = {version = ">=4.0.1", markers = "python_version < \"3.11\""} [package.extras] colorama = ["colorama (>=0.4.3)"] -d = ["aiohttp (>=3.7.4)", "aiohttp (>=3.7.4,!=3.9.0)"] +d = ["aiohttp (>=3.10)"] jupyter = ["ipython (>=7.8.0)", "tokenize-rt (>=3.2.0)"] uvloop = ["uvloop (>=0.15.2)"] @@ -607,13 +631,13 @@ dev = ["PyTest", "PyTest-Cov", "bump2version (<1)", "sphinx (<2)", "tox"] [[package]] name = "dill" -version = "0.3.8" +version = "0.3.9" description = "serialize all of Python" optional = false python-versions = ">=3.8" files = [ - {file = "dill-0.3.8-py3-none-any.whl", hash = "sha256:c36ca9ffb54365bdd2f8eb3eff7d2a21237f8452b57ace88b1ac615b7e815bd7"}, - {file = "dill-0.3.8.tar.gz", hash = "sha256:3ebe3c479ad625c4553aca177444d89b486b1d84982eeacded644afc0cf797ca"}, + {file = "dill-0.3.9-py3-none-any.whl", hash = "sha256:468dff3b89520b474c0397703366b7b95eebe6303f108adf9b19da1f702be87a"}, + {file = "dill-0.3.9.tar.gz", hash = "sha256:81aa267dddf68cbfe8029c42ca9ec6a4ab3b22371d1c450abc54422577b4512c"}, ] [package.extras] @@ -654,13 +678,13 @@ websockets = ["websocket-client (>=1.3.0)"] [[package]] name = "docutils" -version = "0.19" +version = "0.20.1" description = "Docutils -- Python Documentation Utilities" optional = false python-versions = ">=3.7" files = [ - {file = "docutils-0.19-py3-none-any.whl", hash = "sha256:5e1de4d849fee02c63b040a4a3fd567f4ab104defd8a5511fbbc24a8a017efbc"}, - {file = "docutils-0.19.tar.gz", hash = "sha256:33995a6753c30b7f577febfc2c50411fec6aac7f7ffeb7c4cfe5991072dcf9e6"}, + {file = "docutils-0.20.1-py3-none-any.whl", hash = "sha256:96f387a2c5562db4476f09f13bbab2192e764cac08ebbf3a34a95d9b1e4a59d6"}, + {file = "docutils-0.20.1.tar.gz", hash = "sha256:f08a4e276c3a1583a86dce3e34aba3fe04d02bba2dd51ed16106244e8a923e3b"}, ] [[package]] @@ -747,32 +771,36 @@ types-requests = ">=2.31.0.6,<3.0.0.0" [[package]] name = "exasol-toolbox" -version = "0.9.0" -description = "" +version = "0.15.0" +description = "Your one-stop solution for managing all standard tasks and core workflows of your Python project." optional = false python-versions = "<4.0,>=3.8" files = [ - {file = "exasol_toolbox-0.9.0-py3-none-any.whl", hash = "sha256:9f7043f0f564afbc8b1b04e957e2fb0669e90d7cabce096438ae22e154b54945"}, - {file = "exasol_toolbox-0.9.0.tar.gz", hash = "sha256:775b1a6926ec024d77cb2d4ca6e0627b7d05ecc9189bcddc91429645fedcdc84"}, + {file = "exasol_toolbox-0.15.0-py3-none-any.whl", hash = "sha256:26d0475a53b868a568ca3b58c50bc2776867d2c6155cca14aae75fac4c7efcfa"}, + {file = "exasol_toolbox-0.15.0.tar.gz", hash = "sha256:14260470633abadb6e4bd3aed49250bfcdef4f14cd09b5878dd42d43770b8c78"}, ] [package.dependencies] -black = ">=23.1.0,<24.0.0" +bandit = {version = ">=1.7.9,<2.0.0", extras = ["toml"]} +black = ">=24.1.0" coverage = ">=6.4.4,<8.0.0" -furo = ">=2022.9.15,<2023.0.0" +furo = ">=2022.9.15" importlib-resources = ">=5.12.0" isort = ">=5.12.0,<6.0.0" mypy = ">=0.971" -myst-parser = ">=2.0.0,<3.0.0" -nox = ">=2022.8.7,<2023.0.0" +myst-parser = ">=2.0.0,<4" +nox = ">=2022.8.7" pluggy = ">=1.5.0,<2.0.0" -pre-commit = ">=3.1.1,<4.0.0" -prysk = {version = ">=0.17.0,<0.18.0", extras = ["pytest-plugin"]} +pre-commit = ">=3.1.1,<4" +prysk = {version = ">0.17.0,<1", extras = ["pytest-plugin"]} pylint = ">=2.15.4" -pytest = ">=7.2.2,<8.0.0" +pytest = ">=7.2.2,<9" pyupgrade = ">=2.38.2,<4.0.0" -sphinx = ">=5.3,<7.0" +shibuya = ">=2024.5.14" +sphinx = ">=5.3,<8" sphinx-copybutton = ">=0.5.0,<0.6.0" +sphinx-design = ">=0.5.0,<1" +sphinx-inline-tabs = ">=2023.4.21,<2024.0.0" typer = {version = ">=0.7.0", extras = ["all"]} [[package]] @@ -827,20 +855,20 @@ typing = ["typing-extensions (>=4.12.2)"] [[package]] name = "furo" -version = "2022.12.7" +version = "2024.8.6" description = "A clean customisable Sphinx documentation theme." optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "furo-2022.12.7-py3-none-any.whl", hash = "sha256:7cb76c12a25ef65db85ab0743df907573d03027a33631f17d267e598ebb191f7"}, - {file = "furo-2022.12.7.tar.gz", hash = "sha256:d8008f8efbe7587a97ba533c8b2df1f9c21ee9b3e5cad0d27f61193d38b1a986"}, + {file = "furo-2024.8.6-py3-none-any.whl", hash = "sha256:6cd97c58b47813d3619e63e9081169880fbe331f0ca883c871ff1f3f11814f5c"}, + {file = "furo-2024.8.6.tar.gz", hash = "sha256:b63e4cee8abfc3136d3bc03a3d45a76a850bada4d6374d24c1716b0e01394a01"}, ] [package.dependencies] beautifulsoup4 = "*" pygments = ">=2.7" -sphinx = ">=5.0,<7.0" -sphinx-basic-ng = "*" +sphinx = ">=6.0,<9.0" +sphinx-basic-ng = ">=1.0.0.beta2" [[package]] name = "gitdb" @@ -887,13 +915,13 @@ files = [ [[package]] name = "httpcore" -version = "1.0.5" +version = "1.0.6" description = "A minimal low-level HTTP client." optional = false python-versions = ">=3.8" files = [ - {file = "httpcore-1.0.5-py3-none-any.whl", hash = "sha256:421f18bac248b25d310f3cacd198d55b8e6125c107797b609ff9b7a6ba7991b5"}, - {file = "httpcore-1.0.5.tar.gz", hash = "sha256:34a38e2f9291467ee3b44e89dd52615370e152954ba21721378a87b2960f7a61"}, + {file = "httpcore-1.0.6-py3-none-any.whl", hash = "sha256:27b59625743b85577a8c0e10e55b50b5368a4f2cfe8cc7bcfa9cf00829c2682f"}, + {file = "httpcore-1.0.6.tar.gz", hash = "sha256:73f6dbd6eb8c21bbf7ef8efad555481853f5f6acdeaff1edb0694289269ee17f"}, ] [package.dependencies] @@ -904,7 +932,7 @@ h11 = ">=0.13,<0.15" asyncio = ["anyio (>=4.0,<5.0)"] http2 = ["h2 (>=3,<5)"] socks = ["socksio (==1.*)"] -trio = ["trio (>=0.22.0,<0.26.0)"] +trio = ["trio (>=0.22.0,<1.0)"] [[package]] name = "httpx" @@ -1178,71 +1206,72 @@ testing = ["coverage", "pytest", "pytest-cov", "pytest-regressions"] [[package]] name = "markupsafe" -version = "2.1.5" +version = "3.0.0" description = "Safely add untrusted strings to HTML/XML markup." optional = false -python-versions = ">=3.7" +python-versions = ">=3.9" files = [ - {file = "MarkupSafe-2.1.5-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:a17a92de5231666cfbe003f0e4b9b3a7ae3afb1ec2845aadc2bacc93ff85febc"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:72b6be590cc35924b02c78ef34b467da4ba07e4e0f0454a2c5907f473fc50ce5"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:e61659ba32cf2cf1481e575d0462554625196a1f2fc06a1c777d3f48e8865d46"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2174c595a0d73a3080ca3257b40096db99799265e1c27cc5a610743acd86d62f"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ae2ad8ae6ebee9d2d94b17fb62763125f3f374c25618198f40cbb8b525411900"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:075202fa5b72c86ad32dc7d0b56024ebdbcf2048c0ba09f1cde31bfdd57bcfff"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:598e3276b64aff0e7b3451b72e94fa3c238d452e7ddcd893c3ab324717456bad"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:fce659a462a1be54d2ffcacea5e3ba2d74daa74f30f5f143fe0c58636e355fdd"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-win32.whl", hash = "sha256:d9fad5155d72433c921b782e58892377c44bd6252b5af2f67f16b194987338a4"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-win_amd64.whl", hash = "sha256:bf50cd79a75d181c9181df03572cdce0fbb75cc353bc350712073108cba98de5"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:629ddd2ca402ae6dbedfceeba9c46d5f7b2a61d9749597d4307f943ef198fc1f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:5b7b716f97b52c5a14bffdf688f971b2d5ef4029127f1ad7a513973cfd818df2"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:6ec585f69cec0aa07d945b20805be741395e28ac1627333b1c5b0105962ffced"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b91c037585eba9095565a3556f611e3cbfaa42ca1e865f7b8015fe5c7336d5a5"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:7502934a33b54030eaf1194c21c692a534196063db72176b0c4028e140f8f32c"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:0e397ac966fdf721b2c528cf028494e86172b4feba51d65f81ffd65c63798f3f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:c061bb86a71b42465156a3ee7bd58c8c2ceacdbeb95d05a99893e08b8467359a"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:3a57fdd7ce31c7ff06cdfbf31dafa96cc533c21e443d57f5b1ecc6cdc668ec7f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-win32.whl", hash = "sha256:397081c1a0bfb5124355710fe79478cdbeb39626492b15d399526ae53422b906"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-win_amd64.whl", hash = "sha256:2b7c57a4dfc4f16f7142221afe5ba4e093e09e728ca65c51f5620c9aaeb9a617"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-macosx_10_9_universal2.whl", hash = "sha256:8dec4936e9c3100156f8a2dc89c4b88d5c435175ff03413b443469c7c8c5f4d1"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:3c6b973f22eb18a789b1460b4b91bf04ae3f0c4234a0a6aa6b0a92f6f7b951d4"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:ac07bad82163452a6884fe8fa0963fb98c2346ba78d779ec06bd7a6262132aee"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f5dfb42c4604dddc8e4305050aa6deb084540643ed5804d7455b5df8fe16f5e5"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ea3d8a3d18833cf4304cd2fc9cbb1efe188ca9b5efef2bdac7adc20594a0e46b"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:d050b3361367a06d752db6ead6e7edeb0009be66bc3bae0ee9d97fb326badc2a"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:bec0a414d016ac1a18862a519e54b2fd0fc8bbfd6890376898a6c0891dd82e9f"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:58c98fee265677f63a4385256a6d7683ab1832f3ddd1e66fe948d5880c21a169"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-win32.whl", hash = "sha256:8590b4ae07a35970728874632fed7bd57b26b0102df2d2b233b6d9d82f6c62ad"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-win_amd64.whl", hash = "sha256:823b65d8706e32ad2df51ed89496147a42a2a6e01c13cfb6ffb8b1e92bc910bb"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:c8b29db45f8fe46ad280a7294f5c3ec36dbac9491f2d1c17345be8e69cc5928f"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:ec6a563cff360b50eed26f13adc43e61bc0c04d94b8be985e6fb24b81f6dcfdf"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a549b9c31bec33820e885335b451286e2969a2d9e24879f83fe904a5ce59d70a"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4f11aa001c540f62c6166c7726f71f7573b52c68c31f014c25cc7901deea0b52"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_aarch64.whl", hash = "sha256:7b2e5a267c855eea6b4283940daa6e88a285f5f2a67f2220203786dfa59b37e9"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:2d2d793e36e230fd32babe143b04cec8a8b3eb8a3122d2aceb4a371e6b09b8df"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:ce409136744f6521e39fd8e2a24c53fa18ad67aa5bc7c2cf83645cce5b5c4e50"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-win32.whl", hash = "sha256:4096e9de5c6fdf43fb4f04c26fb114f61ef0bf2e5604b6ee3019d51b69e8c371"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-win_amd64.whl", hash = "sha256:4275d846e41ecefa46e2015117a9f491e57a71ddd59bbead77e904dc02b1bed2"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-macosx_10_9_universal2.whl", hash = "sha256:656f7526c69fac7f600bd1f400991cc282b417d17539a1b228617081106feb4a"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:97cafb1f3cbcd3fd2b6fbfb99ae11cdb14deea0736fc2b0952ee177f2b813a46"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:1f3fbcb7ef1f16e48246f704ab79d79da8a46891e2da03f8783a5b6fa41a9532"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:fa9db3f79de01457b03d4f01b34cf91bc0048eb2c3846ff26f66687c2f6d16ab"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ffee1f21e5ef0d712f9033568f8344d5da8cc2869dbd08d87c84656e6a2d2f68"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:5dedb4db619ba5a2787a94d877bc8ffc0566f92a01c0ef214865e54ecc9ee5e0"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:30b600cf0a7ac9234b2638fbc0fb6158ba5bdcdf46aeb631ead21248b9affbc4"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:8dd717634f5a044f860435c1d8c16a270ddf0ef8588d4887037c5028b859b0c3"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-win32.whl", hash = "sha256:daa4ee5a243f0f20d528d939d06670a298dd39b1ad5f8a72a4275124a7819eff"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-win_amd64.whl", hash = "sha256:619bc166c4f2de5caa5a633b8b7326fbe98e0ccbfacabd87268a2b15ff73a029"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:7a68b554d356a91cce1236aa7682dc01df0edba8d043fd1ce607c49dd3c1edcf"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:db0b55e0f3cc0be60c1f19efdde9a637c32740486004f20d1cff53c3c0ece4d2"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:3e53af139f8579a6d5f7b76549125f0d94d7e630761a2111bc431fd820e163b8"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:17b950fccb810b3293638215058e432159d2b71005c74371d784862b7e4683f3"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4c31f53cdae6ecfa91a77820e8b151dba54ab528ba65dfd235c80b086d68a465"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:bff1b4290a66b490a2f4719358c0cdcd9bafb6b8f061e45c7a2460866bf50c2e"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:bc1667f8b83f48511b94671e0e441401371dfd0f0a795c7daa4a3cd1dde55bea"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:5049256f536511ee3f7e1b3f87d1d1209d327e818e6ae1365e8653d7e3abb6a6"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-win32.whl", hash = "sha256:00e046b6dd71aa03a41079792f8473dc494d564611a8f89bbbd7cb93295ebdcf"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-win_amd64.whl", hash = "sha256:fa173ec60341d6bb97a89f5ea19c85c5643c1e7dedebc22f5181eb73573142c5"}, - {file = "MarkupSafe-2.1.5.tar.gz", hash = "sha256:d283d37a890ba4c1ae73ffadf8046435c76e7bc2247bbb63c00bd1a709c6544b"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:380faf314c3c84c1682ca672e6280c6c59e92d0bc13dc71758ffa2de3cd4e252"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:1ee9790be6f62121c4c58bbced387b0965ab7bffeecb4e17cc42ef290784e363"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:5ddf5cb8e9c00d9bf8b0c75949fb3ff9ea2096ba531693e2e87336d197fdb908"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:9b36473a2d3e882d1873ea906ce54408b9588dc2c65989664e6e7f5a2de353d7"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:dba0f83119b9514bc37272ad012f0cc03f0805cc6a2bea7244e19250ac8ff29f"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_aarch64.whl", hash = "sha256:409535e0521c4630d5b5a1bf284e9d3c76d2fc2f153ebb12cf3827797798cc99"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_i686.whl", hash = "sha256:64a7c7856c3a409011139b17d137c2924df4318dab91ee0530800819617c4381"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_x86_64.whl", hash = "sha256:4deea1d9169578917d1f35cdb581bc7bab56a7e8c5be2633bd1b9549c3c22a01"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-win32.whl", hash = "sha256:3cd0bba31d484fe9b9d77698ddb67c978704603dc10cdc905512af308cfcca6b"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-win_amd64.whl", hash = "sha256:4ca04c60006867610a06575b46941ae616b19da0adc85b9f8f3d9cbd7a3da385"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:e64b390a306f9e849ee809f92af6a52cda41741c914358e0e9f8499d03741526"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:7c524203207f5b569df06c96dafdc337228921ee8c3cc5f6e891d024c6595352"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c409691696bec2b5e5c9efd9593c99025bf2f317380bf0d993ee0213516d908a"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:64f7d04410be600aa5ec0626d73d43e68a51c86500ce12917e10fd013e258df5"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:105ada43a61af22acb8774514c51900dc820c481cc5ba53f17c09d294d9c07ca"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_aarch64.whl", hash = "sha256:a5fd5500d4e4f7cc88d8c0f2e45126c4307ed31e08f8ec521474f2fd99d35ac3"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_i686.whl", hash = "sha256:25396abd52b16900932e05b7104bcdc640a4d96c914f39c3b984e5a17b01fba0"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_x86_64.whl", hash = "sha256:3efde9a8c56c3b6e5f3fa4baea828f8184970c7c78480fedb620d804b1c31e5c"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-win32.whl", hash = "sha256:12ddac720b8965332d36196f6f83477c6351ba6a25d4aff91e30708c729350d7"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-win_amd64.whl", hash = "sha256:658fdf6022740896c403d45148bf0c36978c6b48c9ef8b1f8d0c7a11b6cdea86"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-macosx_10_13_universal2.whl", hash = "sha256:d261ec38b8a99a39b62e0119ed47fe3b62f7691c500bc1e815265adc016438c1"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:e363440c8534bf2f2ef1b8fdc02037eb5fff8fce2a558519b22d6a3a38b3ec5e"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:7835de4c56066e096407a1852e5561f6033786dd987fa90dc384e45b9bd21295"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b6cc46a27d904c9be5732029769acf4b0af69345172ed1ef6d4db0c023ff603b"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:f0411641d31aa6f7f0cc13f0f18b63b8dc08da5f3a7505972a42ab059f479ba3"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_aarch64.whl", hash = "sha256:b2a7afd24d408b907672015555bc10be2382e6c5f62a488e2d452da670bbd389"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_i686.whl", hash = "sha256:c8ab7efeff1884c5da8e18f743b667215300e09043820d11723718de0b7db934"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_x86_64.whl", hash = "sha256:8219e2207f6c188d15614ea043636c2b36d2d79bf853639c124a179412325a13"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-win32.whl", hash = "sha256:59420b5a9a5d3fee483a32adb56d7369ae0d630798da056001be1e9f674f3aa6"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-win_amd64.whl", hash = "sha256:7ed789d0f7f11fcf118cf0acb378743dfdd4215d7f7d18837c88171405c9a452"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-macosx_10_13_universal2.whl", hash = "sha256:27d6a73682b99568916c54a4bfced40e7d871ba685b580ea04bbd2e405dfd4c5"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:494a64efc535e147fcc713dba58eecfce3a79f1e93ebe81995b387f5cd9bc2e1"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c5243044a927e8a6bb28517838662a019cd7f73d7f106bbb37ab5e7fa8451a92"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:63dae84964a9a3d2610808cee038f435d9a111620c37ccf872c2fcaeca6865b3"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:dcbee57fedc9b2182c54ffc1c5eed316c3da8bbfeda8009e1b5d7220199d15da"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_aarch64.whl", hash = "sha256:f846fd7c241e5bd4161e2a483663eb66e4d8e12130fcdc052f310f388f1d61c6"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_i686.whl", hash = "sha256:678fbceb202382aae42c1f0cd9f56b776bc20a58ae5b553ee1fe6b802983a1d6"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_x86_64.whl", hash = "sha256:bd9b8e458e2bab52f9ad3ab5dc8b689a3c84b12b2a2f64cd9a0dfe209fb6b42f"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-win32.whl", hash = "sha256:1fd02f47596e00a372f5b4af2b4c45f528bade65c66dfcbc6e1ea1bfda758e98"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-win_amd64.whl", hash = "sha256:b94bec9eda10111ec7102ef909eca4f3c2df979643924bfe58375f560713a7d1"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-macosx_10_13_universal2.whl", hash = "sha256:509c424069dd037d078925b6815fc56b7271f3aaec471e55e6fa513b0a80d2aa"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-macosx_11_0_arm64.whl", hash = "sha256:81be2c0084d8c69e97e3c5d73ce9e2a6e523556f2a19c4e195c09d499be2f808"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b43ac1eb9f91e0c14aac1d2ef0f76bc7b9ceea51de47536f61268191adf52ad7"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:3b231255770723f1e125d63c14269bcd8b8136ecfb620b9a18c0297e046d0736"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:c182d45600556917f811aa019d834a89fe4b6f6255da2fd0bdcf80e970f95918"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_aarch64.whl", hash = "sha256:9f91c90f8f3bf436f81c12eeb4d79f9ddd263c71125e6ad71341906832a34386"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_i686.whl", hash = "sha256:a7171d2b869e9be238ea318c196baf58fbf272704e9c1cd4be8c380eea963342"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_x86_64.whl", hash = "sha256:cb244adf2499aa37d5dc43431990c7f0b632d841af66a51d22bd89c437b60264"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-win32.whl", hash = "sha256:96e3ed550600185d34429477f1176cedea8293fa40e47fe37a05751bcb64c997"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-win_amd64.whl", hash = "sha256:1d151b9cf3307e259b749125a5a08c030ba15a8f1d567ca5bfb0e92f35e761f5"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:23efb2be7221105c8eb0e905433414d2439cb0a8c5d5ca081c1c72acef0f5613"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:81ee9c967956b9ea39b3a5270b7cb1740928d205b0dc72629164ce621b4debf9"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:5509a8373fed30b978557890a226c3d30569746c565b9daba69df80c160365a5"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f1c13c6c908811f867a8e9e66efb2d6c03d1cdd83e92788fe97f693c457dc44f"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:d7e63d1977d3806ce0a1a3e0099b089f61abdede5238ca6a3f3bf8877b46d095"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_aarch64.whl", hash = "sha256:d2c099be5274847d606574234e494f23a359e829ba337ea9037c3a72b0851942"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_i686.whl", hash = "sha256:e042ccf8fe5bf8b6a4b38b3f7d618eb10ea20402b0c9f4add9293408de447974"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_x86_64.whl", hash = "sha256:98fb3a2bf525ad66db96745707b93ba0f78928b7a1cb2f1cb4b143bc7e2ba3b3"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-win32.whl", hash = "sha256:a80c6740e1bfbe50cea7cbf74f48823bb57bd59d914ee22ff8a81963b08e62d2"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-win_amd64.whl", hash = "sha256:5d207ff5cceef77796f8aacd44263266248cf1fbc601441524d7835613f8abec"}, + {file = "markupsafe-3.0.0.tar.gz", hash = "sha256:03ff62dea2fef3eadf2f1853bc6332bcb0458d9608b11dfb1cd5aeda1c178ea6"}, ] [[package]] @@ -1346,17 +1375,17 @@ files = [ [[package]] name = "myst-parser" -version = "2.0.0" +version = "3.0.1" description = "An extended [CommonMark](https://spec.commonmark.org/) compliant parser," optional = false python-versions = ">=3.8" files = [ - {file = "myst_parser-2.0.0-py3-none-any.whl", hash = "sha256:7c36344ae39c8e740dad7fdabf5aa6fc4897a813083c6cc9990044eb93656b14"}, - {file = "myst_parser-2.0.0.tar.gz", hash = "sha256:ea929a67a6a0b1683cdbe19b8d2e724cd7643f8aa3e7bb18dd65beac3483bead"}, + {file = "myst_parser-3.0.1-py3-none-any.whl", hash = "sha256:6457aaa33a5d474aca678b8ead9b3dc298e89c68e67012e73146ea6fd54babf1"}, + {file = "myst_parser-3.0.1.tar.gz", hash = "sha256:88f0cb406cb363b077d176b51c476f62d60604d68a8dcdf4832e080441301a87"}, ] [package.dependencies] -docutils = ">=0.16,<0.21" +docutils = ">=0.18,<0.22" jinja2 = "*" markdown-it-py = ">=3.0,<4.0" mdit-py-plugins = ">=0.4,<1.0" @@ -1366,9 +1395,9 @@ sphinx = ">=6,<8" [package.extras] code-style = ["pre-commit (>=3.0,<4.0)"] linkify = ["linkify-it-py (>=2.0,<3.0)"] -rtd = ["ipython", "pydata-sphinx-theme (==v0.13.0rc4)", "sphinx-autodoc2 (>=0.4.2,<0.5.0)", "sphinx-book-theme (==1.0.0rc2)", "sphinx-copybutton", "sphinx-design2", "sphinx-pyscript", "sphinx-tippy (>=0.3.1)", "sphinx-togglebutton", "sphinxext-opengraph (>=0.8.2,<0.9.0)", "sphinxext-rediraffe (>=0.2.7,<0.3.0)"] -testing = ["beautifulsoup4", "coverage[toml]", "pytest (>=7,<8)", "pytest-cov", "pytest-param-files (>=0.3.4,<0.4.0)", "pytest-regressions", "sphinx-pytest"] -testing-docutils = ["pygments", "pytest (>=7,<8)", "pytest-param-files (>=0.3.4,<0.4.0)"] +rtd = ["ipython", "sphinx (>=7)", "sphinx-autodoc2 (>=0.5.0,<0.6.0)", "sphinx-book-theme (>=1.1,<2.0)", "sphinx-copybutton", "sphinx-design", "sphinx-pyscript", "sphinx-tippy (>=0.4.3)", "sphinx-togglebutton", "sphinxext-opengraph (>=0.9.0,<0.10.0)", "sphinxext-rediraffe (>=0.2.7,<0.3.0)"] +testing = ["beautifulsoup4", "coverage[toml]", "defusedxml", "pytest (>=8,<9)", "pytest-cov", "pytest-param-files (>=0.6.0,<0.7.0)", "pytest-regressions", "sphinx-pytest"] +testing-docutils = ["pygments", "pytest (>=8,<9)", "pytest-param-files (>=0.6.0,<0.7.0)"] [[package]] name = "netaddr" @@ -1415,23 +1444,25 @@ files = [ [[package]] name = "nox" -version = "2022.11.21" +version = "2024.4.15" description = "Flexible test automation." optional = false python-versions = ">=3.7" files = [ - {file = "nox-2022.11.21-py3-none-any.whl", hash = "sha256:0e41a990e290e274cb205a976c4c97ee3c5234441a8132c8c3fd9ea3c22149eb"}, - {file = "nox-2022.11.21.tar.gz", hash = "sha256:e21c31de0711d1274ca585a2c5fde36b1aa962005ba8e9322bf5eeed16dcd684"}, + {file = "nox-2024.4.15-py3-none-any.whl", hash = "sha256:6492236efa15a460ecb98e7b67562a28b70da006ab0be164e8821177577c0565"}, + {file = "nox-2024.4.15.tar.gz", hash = "sha256:ecf6700199cdfa9e5ea0a41ff5e6ef4641d09508eda6edb89d9987864115817f"}, ] [package.dependencies] -argcomplete = ">=1.9.4,<3.0" +argcomplete = ">=1.9.4,<4.0" colorlog = ">=2.6.1,<7.0.0" packaging = ">=20.9" -virtualenv = ">=14" +tomli = {version = ">=1", markers = "python_version < \"3.11\""} +virtualenv = ">=20.14.1" [package.extras] tox-to-nox = ["jinja2", "tox"] +uv = ["uv (>=0.1.6)"] [[package]] name = "packaging" @@ -1476,6 +1507,17 @@ files = [ {file = "pathspec-0.12.1.tar.gz", hash = "sha256:a482d51503a1ab33b1c67a6c3813a26953dbdc71c31dacaef9a838c4e29f5712"}, ] +[[package]] +name = "pbr" +version = "6.1.0" +description = "Python Build Reasonableness" +optional = false +python-versions = ">=2.6" +files = [ + {file = "pbr-6.1.0-py2.py3-none-any.whl", hash = "sha256:a776ae228892d8013649c0aeccbb3d5f99ee15e005a4cbb7e61d55a067b28a2a"}, + {file = "pbr-6.1.0.tar.gz", hash = "sha256:788183e382e3d1d7707db08978239965e8b9e4e5ed42669bf4758186734d5f24"}, +] + [[package]] name = "platformdirs" version = "4.3.6" @@ -1546,13 +1588,13 @@ virtualenv = ">=20.10.0" [[package]] name = "prysk" -version = "0.17.0" +version = "0.20.0" description = "Functional tests for command line applications" optional = false -python-versions = ">=3.8,<4.0.0" +python-versions = "<4.0.0,>=3.8" files = [ - {file = "prysk-0.17.0-py3-none-any.whl", hash = "sha256:c2e0ce69ede821e5a7e03f576c51e2a35000c570f6e22cf7c13daec1b3978832"}, - {file = "prysk-0.17.0.tar.gz", hash = "sha256:0a500bb9ff742eca878d5802bad9fcfd7ba1c6bbae64b2a2ff96bff94d4f8ad8"}, + {file = "prysk-0.20.0-py3-none-any.whl", hash = "sha256:3758f59febe1ff27710c8ba69a8edad42286050d041ed8df519fc4bbeea41133"}, + {file = "prysk-0.20.0.tar.gz", hash = "sha256:3499d24c9c8d534754d3915218cb2ab59cf59a8d6f37acfb68dc582650e67e33"}, ] [package.dependencies] @@ -1586,13 +1628,13 @@ files = [ [[package]] name = "pydot" -version = "3.0.1" +version = "3.0.2" description = "Python interface to Graphviz's Dot" optional = false python-versions = ">=3.8" files = [ - {file = "pydot-3.0.1-py3-none-any.whl", hash = "sha256:43f1e878dc1ff7c1c2e3470a6999d4e9e97771c5c862440c2f0af0ba844c231f"}, - {file = "pydot-3.0.1.tar.gz", hash = "sha256:e18cf7f287c497d77b536a3d20a46284568fea390776dface6eabbdf1b1b5efc"}, + {file = "pydot-3.0.2-py3-none-any.whl", hash = "sha256:99cedaa55d04abb0b2bc56d9981a6da781053dd5ac75c428e8dd53db53f90b14"}, + {file = "pydot-3.0.2.tar.gz", hash = "sha256:9180da540b51b3aa09fbf81140b3edfbe2315d778e8589a7d0a4a69c41332bae"}, ] [package.dependencies] @@ -1601,7 +1643,7 @@ pyparsing = ">=3.0.9" [package.extras] dev = ["chardet", "parameterized", "ruff"] release = ["zest.releaser[recommended]"] -tests = ["chardet", "parameterized", "ruff", "tox", "unittest-parallel"] +tests = ["chardet", "parameterized", "pytest", "pytest-cov", "pytest-xdist[psutil]", "ruff", "tox"] [[package]] name = "pyexasol" @@ -1831,25 +1873,29 @@ tokenize-rt = ">=5.2.0" [[package]] name = "pywin32" -version = "306" +version = "307" description = "Python for Window Extensions" optional = false python-versions = "*" files = [ - {file = "pywin32-306-cp310-cp310-win32.whl", hash = "sha256:06d3420a5155ba65f0b72f2699b5bacf3109f36acbe8923765c22938a69dfc8d"}, - {file = "pywin32-306-cp310-cp310-win_amd64.whl", hash = "sha256:84f4471dbca1887ea3803d8848a1616429ac94a4a8d05f4bc9c5dcfd42ca99c8"}, - {file = "pywin32-306-cp311-cp311-win32.whl", hash = "sha256:e65028133d15b64d2ed8f06dd9fbc268352478d4f9289e69c190ecd6818b6407"}, - {file = "pywin32-306-cp311-cp311-win_amd64.whl", hash = "sha256:a7639f51c184c0272e93f244eb24dafca9b1855707d94c192d4a0b4c01e1100e"}, - {file = "pywin32-306-cp311-cp311-win_arm64.whl", hash = "sha256:70dba0c913d19f942a2db25217d9a1b726c278f483a919f1abfed79c9cf64d3a"}, - {file = "pywin32-306-cp312-cp312-win32.whl", hash = "sha256:383229d515657f4e3ed1343da8be101000562bf514591ff383ae940cad65458b"}, - {file = "pywin32-306-cp312-cp312-win_amd64.whl", hash = "sha256:37257794c1ad39ee9be652da0462dc2e394c8159dfd913a8a4e8eb6fd346da0e"}, - {file = "pywin32-306-cp312-cp312-win_arm64.whl", hash = "sha256:5821ec52f6d321aa59e2db7e0a35b997de60c201943557d108af9d4ae1ec7040"}, - {file = "pywin32-306-cp37-cp37m-win32.whl", hash = "sha256:1c73ea9a0d2283d889001998059f5eaaba3b6238f767c9cf2833b13e6a685f65"}, - {file = "pywin32-306-cp37-cp37m-win_amd64.whl", hash = "sha256:72c5f621542d7bdd4fdb716227be0dd3f8565c11b280be6315b06ace35487d36"}, - {file = "pywin32-306-cp38-cp38-win32.whl", hash = "sha256:e4c092e2589b5cf0d365849e73e02c391c1349958c5ac3e9d5ccb9a28e017b3a"}, - {file = "pywin32-306-cp38-cp38-win_amd64.whl", hash = "sha256:e8ac1ae3601bee6ca9f7cb4b5363bf1c0badb935ef243c4733ff9a393b1690c0"}, - {file = "pywin32-306-cp39-cp39-win32.whl", hash = "sha256:e25fd5b485b55ac9c057f67d94bc203f3f6595078d1fb3b458c9c28b7153a802"}, - {file = "pywin32-306-cp39-cp39-win_amd64.whl", hash = "sha256:39b61c15272833b5c329a2989999dcae836b1eed650252ab1b7bfbe1d59f30f4"}, + {file = "pywin32-307-cp310-cp310-win32.whl", hash = "sha256:f8f25d893c1e1ce2d685ef6d0a481e87c6f510d0f3f117932781f412e0eba31b"}, + {file = "pywin32-307-cp310-cp310-win_amd64.whl", hash = "sha256:36e650c5e5e6b29b5d317385b02d20803ddbac5d1031e1f88d20d76676dd103d"}, + {file = "pywin32-307-cp310-cp310-win_arm64.whl", hash = "sha256:0c12d61e0274e0c62acee79e3e503c312426ddd0e8d4899c626cddc1cafe0ff4"}, + {file = "pywin32-307-cp311-cp311-win32.whl", hash = "sha256:fec5d27cc893178fab299de911b8e4d12c5954e1baf83e8a664311e56a272b75"}, + {file = "pywin32-307-cp311-cp311-win_amd64.whl", hash = "sha256:987a86971753ed7fdd52a7fb5747aba955b2c7fbbc3d8b76ec850358c1cc28c3"}, + {file = "pywin32-307-cp311-cp311-win_arm64.whl", hash = "sha256:fd436897c186a2e693cd0437386ed79f989f4d13d6f353f8787ecbb0ae719398"}, + {file = "pywin32-307-cp312-cp312-win32.whl", hash = "sha256:07649ec6b01712f36debf39fc94f3d696a46579e852f60157a729ac039df0815"}, + {file = "pywin32-307-cp312-cp312-win_amd64.whl", hash = "sha256:00d047992bb5dcf79f8b9b7c81f72e0130f9fe4b22df613f755ab1cc021d8347"}, + {file = "pywin32-307-cp312-cp312-win_arm64.whl", hash = "sha256:b53658acbfc6a8241d72cc09e9d1d666be4e6c99376bc59e26cdb6223c4554d2"}, + {file = "pywin32-307-cp313-cp313-win32.whl", hash = "sha256:ea4d56e48dc1ab2aa0a5e3c0741ad6e926529510516db7a3b6981a1ae74405e5"}, + {file = "pywin32-307-cp313-cp313-win_amd64.whl", hash = "sha256:576d09813eaf4c8168d0bfd66fb7cb3b15a61041cf41598c2db4a4583bf832d2"}, + {file = "pywin32-307-cp313-cp313-win_arm64.whl", hash = "sha256:b30c9bdbffda6a260beb2919f918daced23d32c79109412c2085cbc513338a0a"}, + {file = "pywin32-307-cp37-cp37m-win32.whl", hash = "sha256:5101472f5180c647d4525a0ed289ec723a26231550dbfd369ec19d5faf60e511"}, + {file = "pywin32-307-cp37-cp37m-win_amd64.whl", hash = "sha256:05de55a7c110478dc4b202230e98af5e0720855360d2b31a44bb4e296d795fba"}, + {file = "pywin32-307-cp38-cp38-win32.whl", hash = "sha256:13d059fb7f10792542082f5731d5d3d9645320fc38814759313e5ee97c3fac01"}, + {file = "pywin32-307-cp38-cp38-win_amd64.whl", hash = "sha256:7e0b2f93769d450a98ac7a31a087e07b126b6d571e8b4386a5762eb85325270b"}, + {file = "pywin32-307-cp39-cp39-win32.whl", hash = "sha256:55ee87f2f8c294e72ad9d4261ca423022310a6e79fb314a8ca76ab3f493854c6"}, + {file = "pywin32-307-cp39-cp39-win_amd64.whl", hash = "sha256:e9d5202922e74985b037c9ef46778335c102b74b95cec70f629453dbe7235d87"}, ] [[package]] @@ -1937,18 +1983,19 @@ use-chardet-on-py3 = ["chardet (>=3.0.2,<6)"] [[package]] name = "rich" -version = "13.8.1" +version = "13.9.2" description = "Render rich text, tables, progress bars, syntax highlighting, markdown and more to the terminal" optional = false -python-versions = ">=3.7.0" +python-versions = ">=3.8.0" files = [ - {file = "rich-13.8.1-py3-none-any.whl", hash = "sha256:1760a3c0848469b97b558fc61c85233e3dafb69c7a071b4d60c38099d3cd4c06"}, - {file = "rich-13.8.1.tar.gz", hash = "sha256:8260cda28e3db6bf04d2d1ef4dbc03ba80a824c88b0e7668a0f23126a424844a"}, + {file = "rich-13.9.2-py3-none-any.whl", hash = "sha256:8c82a3d3f8dcfe9e734771313e606b39d8247bb6b826e196f4914b333b743cf1"}, + {file = "rich-13.9.2.tar.gz", hash = "sha256:51a2c62057461aaf7152b4d611168f93a9fc73068f8ded2790f29fe2b5366d0c"}, ] [package.dependencies] markdown-it-py = ">=2.2.0" pygments = ">=2.13.0,<3.0.0" +typing-extensions = {version = ">=4.0.0,<5.0", markers = "python_version < \"3.11\""} [package.extras] jupyter = ["ipywidgets (>=7.5.1,<9)"] @@ -1998,6 +2045,20 @@ files = [ {file = "shellingham-1.5.4.tar.gz", hash = "sha256:8dbca0739d487e5bd35ab3ca4b36e11c4078f3a234bfce294b0a0291363404de"}, ] +[[package]] +name = "shibuya" +version = "2024.8.30" +description = "A clean, responsive, and customizable Sphinx documentation theme with light/dark mode." +optional = false +python-versions = ">=3.7" +files = [ + {file = "shibuya-2024.8.30-py3-none-any.whl", hash = "sha256:c5b865132babcddc4ed600b36a6d05ecc869979f358d9796268927e1eb7ef619"}, + {file = "shibuya-2024.8.30.tar.gz", hash = "sha256:0fdc75643ee40d00fb9a0f1f26ce1085e88df8e48b525a228fe202ffdf31883d"}, +] + +[package.dependencies] +Sphinx = "*" + [[package]] name = "simplejson" version = "3.19.3" @@ -2174,38 +2235,39 @@ files = [ [[package]] name = "sphinx" -version = "6.2.1" +version = "7.4.7" description = "Python documentation generator" optional = false -python-versions = ">=3.8" +python-versions = ">=3.9" files = [ - {file = "Sphinx-6.2.1.tar.gz", hash = "sha256:6d56a34697bb749ffa0152feafc4b19836c755d90a7c59b72bc7dfd371b9cc6b"}, - {file = "sphinx-6.2.1-py3-none-any.whl", hash = "sha256:97787ff1fa3256a3eef9eda523a63dbf299f7b47e053cfcf684a1c2a8380c912"}, + {file = "sphinx-7.4.7-py3-none-any.whl", hash = "sha256:c2419e2135d11f1951cd994d6eb18a1835bd8fdd8429f9ca375dc1f3281bd239"}, + {file = "sphinx-7.4.7.tar.gz", hash = "sha256:242f92a7ea7e6c5b406fdc2615413890ba9f699114a9c09192d7dfead2ee9cfe"}, ] [package.dependencies] -alabaster = ">=0.7,<0.8" -babel = ">=2.9" -colorama = {version = ">=0.4.5", markers = "sys_platform == \"win32\""} -docutils = ">=0.18.1,<0.20" +alabaster = ">=0.7.14,<0.8.0" +babel = ">=2.13" +colorama = {version = ">=0.4.6", markers = "sys_platform == \"win32\""} +docutils = ">=0.20,<0.22" imagesize = ">=1.3" -importlib-metadata = {version = ">=4.8", markers = "python_version < \"3.10\""} -Jinja2 = ">=3.0" -packaging = ">=21.0" -Pygments = ">=2.13" -requests = ">=2.25.0" -snowballstemmer = ">=2.0" +importlib-metadata = {version = ">=6.0", markers = "python_version < \"3.10\""} +Jinja2 = ">=3.1" +packaging = ">=23.0" +Pygments = ">=2.17" +requests = ">=2.30.0" +snowballstemmer = ">=2.2" sphinxcontrib-applehelp = "*" sphinxcontrib-devhelp = "*" sphinxcontrib-htmlhelp = ">=2.0.0" sphinxcontrib-jsmath = "*" sphinxcontrib-qthelp = "*" -sphinxcontrib-serializinghtml = ">=1.1.5" +sphinxcontrib-serializinghtml = ">=1.1.9" +tomli = {version = ">=2", markers = "python_version < \"3.11\""} [package.extras] 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)"] +lint = ["flake8 (>=6.0)", "importlib-metadata (>=6.0)", "mypy (==1.10.1)", "pytest (>=6.0)", "ruff (==0.5.2)", "sphinx-lint (>=0.9)", "tomli (>=2)", "types-docutils (==0.21.0.20240711)", "types-requests (>=2.30.0)"] +test = ["cython (>=3.0)", "defusedxml (>=0.7.1)", "pytest (>=8.0)", "setuptools (>=70.0)", "typing_extensions (>=4.9)"] [[package]] name = "sphinx-basic-ng" @@ -2242,6 +2304,49 @@ sphinx = ">=1.8" code-style = ["pre-commit (==2.12.1)"] rtd = ["ipython", "myst-nb", "sphinx", "sphinx-book-theme", "sphinx-examples"] +[[package]] +name = "sphinx-design" +version = "0.6.1" +description = "A sphinx extension for designing beautiful, view size responsive web components." +optional = false +python-versions = ">=3.9" +files = [ + {file = "sphinx_design-0.6.1-py3-none-any.whl", hash = "sha256:b11f37db1a802a183d61b159d9a202314d4d2fe29c163437001324fe2f19549c"}, + {file = "sphinx_design-0.6.1.tar.gz", hash = "sha256:b44eea3719386d04d765c1a8257caca2b3e6f8421d7b3a5e742c0fd45f84e632"}, +] + +[package.dependencies] +sphinx = ">=6,<9" + +[package.extras] +code-style = ["pre-commit (>=3,<4)"] +rtd = ["myst-parser (>=2,<4)"] +testing = ["defusedxml", "myst-parser (>=2,<4)", "pytest (>=8.3,<9.0)", "pytest-cov", "pytest-regressions"] +testing-no-myst = ["defusedxml", "pytest (>=8.3,<9.0)", "pytest-cov", "pytest-regressions"] +theme-furo = ["furo (>=2024.7.18,<2024.8.0)"] +theme-im = ["sphinx-immaterial (>=0.12.2,<0.13.0)"] +theme-pydata = ["pydata-sphinx-theme (>=0.15.2,<0.16.0)"] +theme-rtd = ["sphinx-rtd-theme (>=2.0,<3.0)"] +theme-sbt = ["sphinx-book-theme (>=1.1,<2.0)"] + +[[package]] +name = "sphinx-inline-tabs" +version = "2023.4.21" +description = "Add inline tabbed content to your Sphinx documentation." +optional = false +python-versions = ">=3.8" +files = [ + {file = "sphinx_inline_tabs-2023.4.21-py3-none-any.whl", hash = "sha256:06809ac613f7c48ddd6e2fa588413e3fe92cff2397b56e2ccf0b0218f9ef6a78"}, + {file = "sphinx_inline_tabs-2023.4.21.tar.gz", hash = "sha256:5df2f13f602c158f3f5f6c509e008aeada199a8c76d97ba3aa2822206683bebc"}, +] + +[package.dependencies] +sphinx = ">=3" + +[package.extras] +doc = ["furo", "myst-parser"] +test = ["pytest", "pytest-cov", "pytest-xdist"] + [[package]] name = "sphinxcontrib-applehelp" version = "2.0.0" @@ -2336,6 +2441,20 @@ lint = ["mypy", "ruff (==0.5.5)", "types-docutils"] standalone = ["Sphinx (>=5)"] test = ["pytest"] +[[package]] +name = "stevedore" +version = "5.3.0" +description = "Manage dynamic plugins for Python applications" +optional = false +python-versions = ">=3.8" +files = [ + {file = "stevedore-5.3.0-py3-none-any.whl", hash = "sha256:1efd34ca08f474dad08d9b19e934a22c68bb6fe416926479ba29e5013bcc8f78"}, + {file = "stevedore-5.3.0.tar.gz", hash = "sha256:9a64265f4060312828151c204efbe9b7a9852a0d9228756344dbc7e4023e375a"}, +] + +[package.dependencies] +pbr = ">=2.0.0" + [[package]] name = "stopwatch-py" version = "2.0.1" @@ -2375,13 +2494,13 @@ files = [ [[package]] name = "tomli" -version = "2.0.1" +version = "2.0.2" description = "A lil' TOML parser" optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "tomli-2.0.1-py3-none-any.whl", hash = "sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc"}, - {file = "tomli-2.0.1.tar.gz", hash = "sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f"}, + {file = "tomli-2.0.2-py3-none-any.whl", hash = "sha256:2ebe24485c53d303f690b0ec092806a085f07af5a5aa1464f3931eec36caaa38"}, + {file = "tomli-2.0.2.tar.gz", hash = "sha256:d46d457a85337051c36524bc5349dd91b1877838e2979ac5ced3e710ed8a60ed"}, ] [[package]] @@ -2495,13 +2614,13 @@ zstd = ["zstandard (>=0.18.0)"] [[package]] name = "virtualenv" -version = "20.26.5" +version = "20.26.6" description = "Virtual Python Environment builder" optional = false python-versions = ">=3.7" files = [ - {file = "virtualenv-20.26.5-py3-none-any.whl", hash = "sha256:4f3ac17b81fba3ce3bd6f4ead2749a72da5929c01774948e243db9ba41df4ff6"}, - {file = "virtualenv-20.26.5.tar.gz", hash = "sha256:ce489cac131aa58f4b25e321d6d186171f78e6cb13fafbf32a840cee67733ff4"}, + {file = "virtualenv-20.26.6-py3-none-any.whl", hash = "sha256:7345cc5b25405607a624d8418154577459c3e0277f5466dd79c49d5e492995f2"}, + {file = "virtualenv-20.26.6.tar.gz", hash = "sha256:280aede09a2a5c317e409a00102e7077c6432c5a38f0ef938e643805a7ad2c48"}, ] [package.dependencies] @@ -2630,4 +2749,4 @@ type = ["pytest-mypy"] [metadata] lock-version = "2.0" python-versions = ">=3.9,<4" -content-hash = "9a7e7e2a2065ca5ef8bcf8379397cd7a5ddce37a043829b8dab38f9c49b4099a" +content-hash = "d6221a0aea8c1fe6805a6060fbe13014251ba82d005430f8fc0620ac65023dc7" diff --git a/pytest-backend/pyproject.toml b/pytest-backend/pyproject.toml index 1fd136e..c4557bf 100644 --- a/pytest-backend/pyproject.toml +++ b/pytest-backend/pyproject.toml @@ -16,8 +16,8 @@ exasol-saas-api = ">=0.6.0,<1.0.0" backend = "exasol.pytest_backend" [tool.poetry.group.dev.dependencies] -exasol-toolbox = "0.9.0" -exasol-bucketfs = ">=0.12.0" +exasol-toolbox = ">=0.15.0,<1" +exasol-bucketfs = ">=0.13.0,<1" pyexasol = ">=0.26.0" [build-system] diff --git a/pytest-extension/poetry.lock b/pytest-extension/poetry.lock index 3f9bf80..c6008e0 100644 --- a/pytest-extension/poetry.lock +++ b/pytest-extension/poetry.lock @@ -35,18 +35,17 @@ trio = ["trio (>=0.26.1)"] [[package]] name = "argcomplete" -version = "2.1.2" +version = "3.5.1" description = "Bash tab completion for argparse" optional = false -python-versions = ">=3.6" +python-versions = ">=3.8" files = [ - {file = "argcomplete-2.1.2-py3-none-any.whl", hash = "sha256:4ba9cdaa28c361d251edce884cd50b4b1215d65cdc881bd204426cdde9f52731"}, - {file = "argcomplete-2.1.2.tar.gz", hash = "sha256:fc82ef070c607b1559b5c720529d63b54d9dcf2dcfc2632b10e6372314a34457"}, + {file = "argcomplete-3.5.1-py3-none-any.whl", hash = "sha256:1a1d148bdaa3e3b93454900163403df41448a248af01b6e849edc5ac08e6c363"}, + {file = "argcomplete-3.5.1.tar.gz", hash = "sha256:eb1ee355aa2557bd3d0145de7b06b2a45b0ce461e1e7813f5d066039ab4177b4"}, ] [package.extras] -lint = ["flake8", "mypy"] -test = ["coverage", "flake8", "mypy", "pexpect", "wheel"] +test = ["coverage", "mypy", "pexpect", "ruff", "wheel"] [[package]] name = "astroid" @@ -95,6 +94,31 @@ files = [ [package.extras] dev = ["freezegun (>=1.0,<2.0)", "pytest (>=6.0)", "pytest-cov"] +[[package]] +name = "bandit" +version = "1.7.10" +description = "Security oriented static analyser for python code." +optional = false +python-versions = ">=3.8" +files = [ + {file = "bandit-1.7.10-py3-none-any.whl", hash = "sha256:665721d7bebbb4485a339c55161ac0eedde27d51e638000d91c8c2d68343ad02"}, + {file = "bandit-1.7.10.tar.gz", hash = "sha256:59ed5caf5d92b6ada4bf65bc6437feea4a9da1093384445fed4d472acc6cff7b"}, +] + +[package.dependencies] +colorama = {version = ">=0.3.9", markers = "platform_system == \"Windows\""} +PyYAML = ">=5.3.1" +rich = "*" +stevedore = ">=1.20.0" +tomli = {version = ">=1.1.0", optional = true, markers = "python_version < \"3.11\" and extra == \"toml\""} + +[package.extras] +baseline = ["GitPython (>=3.1.30)"] +sarif = ["jschema-to-python (>=1.2.3)", "sarif-om (>=1.0.4)"] +test = ["beautifulsoup4 (>=4.8.0)", "coverage (>=4.5.4)", "fixtures (>=3.0.0)", "flake8 (>=4.0.0)", "pylint (==1.9.4)", "stestr (>=2.5.0)", "testscenarios (>=0.5.0)", "testtools (>=2.3.0)"] +toml = ["tomli (>=1.1.0)"] +yaml = ["PyYAML"] + [[package]] name = "bcrypt" version = "4.2.0" @@ -158,33 +182,33 @@ lxml = ["lxml"] [[package]] name = "black" -version = "23.12.1" +version = "24.10.0" description = "The uncompromising code formatter." optional = false -python-versions = ">=3.8" +python-versions = ">=3.9" files = [ - {file = "black-23.12.1-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:e0aaf6041986767a5e0ce663c7a2f0e9eaf21e6ff87a5f95cbf3675bfd4c41d2"}, - {file = "black-23.12.1-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:c88b3711d12905b74206227109272673edce0cb29f27e1385f33b0163c414bba"}, - {file = "black-23.12.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a920b569dc6b3472513ba6ddea21f440d4b4c699494d2e972a1753cdc25df7b0"}, - {file = "black-23.12.1-cp310-cp310-win_amd64.whl", hash = "sha256:3fa4be75ef2a6b96ea8d92b1587dd8cb3a35c7e3d51f0738ced0781c3aa3a5a3"}, - {file = "black-23.12.1-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:8d4df77958a622f9b5a4c96edb4b8c0034f8434032ab11077ec6c56ae9f384ba"}, - {file = "black-23.12.1-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:602cfb1196dc692424c70b6507593a2b29aac0547c1be9a1d1365f0d964c353b"}, - {file = "black-23.12.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:9c4352800f14be5b4864016882cdba10755bd50805c95f728011bcb47a4afd59"}, - {file = "black-23.12.1-cp311-cp311-win_amd64.whl", hash = "sha256:0808494f2b2df923ffc5723ed3c7b096bd76341f6213989759287611e9837d50"}, - {file = "black-23.12.1-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:25e57fd232a6d6ff3f4478a6fd0580838e47c93c83eaf1ccc92d4faf27112c4e"}, - {file = "black-23.12.1-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:2d9e13db441c509a3763a7a3d9a49ccc1b4e974a47be4e08ade2a228876500ec"}, - {file = "black-23.12.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6d1bd9c210f8b109b1762ec9fd36592fdd528485aadb3f5849b2740ef17e674e"}, - {file = "black-23.12.1-cp312-cp312-win_amd64.whl", hash = "sha256:ae76c22bde5cbb6bfd211ec343ded2163bba7883c7bc77f6b756a1049436fbb9"}, - {file = "black-23.12.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:1fa88a0f74e50e4487477bc0bb900c6781dbddfdfa32691e780bf854c3b4a47f"}, - {file = "black-23.12.1-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:a4d6a9668e45ad99d2f8ec70d5c8c04ef4f32f648ef39048d010b0689832ec6d"}, - {file = "black-23.12.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b18fb2ae6c4bb63eebe5be6bd869ba2f14fd0259bda7d18a46b764d8fb86298a"}, - {file = "black-23.12.1-cp38-cp38-win_amd64.whl", hash = "sha256:c04b6d9d20e9c13f43eee8ea87d44156b8505ca8a3c878773f68b4e4812a421e"}, - {file = "black-23.12.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:3e1b38b3135fd4c025c28c55ddfc236b05af657828a8a6abe5deec419a0b7055"}, - {file = "black-23.12.1-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:4f0031eaa7b921db76decd73636ef3a12c942ed367d8c3841a0739412b260a54"}, - {file = "black-23.12.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:97e56155c6b737854e60a9ab1c598ff2533d57e7506d97af5481141671abf3ea"}, - {file = "black-23.12.1-cp39-cp39-win_amd64.whl", hash = "sha256:dd15245c8b68fe2b6bd0f32c1556509d11bb33aec9b5d0866dd8e2ed3dba09c2"}, - {file = "black-23.12.1-py3-none-any.whl", hash = "sha256:78baad24af0f033958cad29731e27363183e140962595def56423e626f4bee3e"}, - {file = "black-23.12.1.tar.gz", hash = "sha256:4ce3ef14ebe8d9509188014d96af1c456a910d5b5cbf434a09fef7e024b3d0d5"}, + {file = "black-24.10.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:e6668650ea4b685440857138e5fe40cde4d652633b1bdffc62933d0db4ed9812"}, + {file = "black-24.10.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:1c536fcf674217e87b8cc3657b81809d3c085d7bf3ef262ead700da345bfa6ea"}, + {file = "black-24.10.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:649fff99a20bd06c6f727d2a27f401331dc0cc861fb69cde910fe95b01b5928f"}, + {file = "black-24.10.0-cp310-cp310-win_amd64.whl", hash = "sha256:fe4d6476887de70546212c99ac9bd803d90b42fc4767f058a0baa895013fbb3e"}, + {file = "black-24.10.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:5a2221696a8224e335c28816a9d331a6c2ae15a2ee34ec857dcf3e45dbfa99ad"}, + {file = "black-24.10.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:f9da3333530dbcecc1be13e69c250ed8dfa67f43c4005fb537bb426e19200d50"}, + {file = "black-24.10.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:4007b1393d902b48b36958a216c20c4482f601569d19ed1df294a496eb366392"}, + {file = "black-24.10.0-cp311-cp311-win_amd64.whl", hash = "sha256:394d4ddc64782e51153eadcaaca95144ac4c35e27ef9b0a42e121ae7e57a9175"}, + {file = "black-24.10.0-cp312-cp312-macosx_10_13_x86_64.whl", hash = "sha256:b5e39e0fae001df40f95bd8cc36b9165c5e2ea88900167bddf258bacef9bbdc3"}, + {file = "black-24.10.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:d37d422772111794b26757c5b55a3eade028aa3fde43121ab7b673d050949d65"}, + {file = "black-24.10.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:14b3502784f09ce2443830e3133dacf2c0110d45191ed470ecb04d0f5f6fcb0f"}, + {file = "black-24.10.0-cp312-cp312-win_amd64.whl", hash = "sha256:30d2c30dc5139211dda799758559d1b049f7f14c580c409d6ad925b74a4208a8"}, + {file = "black-24.10.0-cp313-cp313-macosx_10_13_x86_64.whl", hash = "sha256:1cbacacb19e922a1d75ef2b6ccaefcd6e93a2c05ede32f06a21386a04cedb981"}, + {file = "black-24.10.0-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:1f93102e0c5bb3907451063e08b9876dbeac810e7da5a8bfb7aeb5a9ef89066b"}, + {file = "black-24.10.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:ddacb691cdcdf77b96f549cf9591701d8db36b2f19519373d60d31746068dbf2"}, + {file = "black-24.10.0-cp313-cp313-win_amd64.whl", hash = "sha256:680359d932801c76d2e9c9068d05c6b107f2584b2a5b88831c83962eb9984c1b"}, + {file = "black-24.10.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:17374989640fbca88b6a448129cd1745c5eb8d9547b464f281b251dd00155ccd"}, + {file = "black-24.10.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:63f626344343083322233f175aaf372d326de8436f5928c042639a4afbbf1d3f"}, + {file = "black-24.10.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:ccfa1d0cb6200857f1923b602f978386a3a2758a65b52e0950299ea014be6800"}, + {file = "black-24.10.0-cp39-cp39-win_amd64.whl", hash = "sha256:2cd9c95431d94adc56600710f8813ee27eea544dd118d45896bb734e9d7a0dc7"}, + {file = "black-24.10.0-py3-none-any.whl", hash = "sha256:3bb2b7a1f7b685f85b11fed1ef10f8a9148bceb49853e47a294a3dd963c1dd7d"}, + {file = "black-24.10.0.tar.gz", hash = "sha256:846ea64c97afe3bc677b761787993be4991810ecc7a4a937816dd6bddedc4875"}, ] [package.dependencies] @@ -198,7 +222,7 @@ typing-extensions = {version = ">=4.0.1", markers = "python_version < \"3.11\""} [package.extras] colorama = ["colorama (>=0.4.3)"] -d = ["aiohttp (>=3.7.4)", "aiohttp (>=3.7.4,!=3.9.0)"] +d = ["aiohttp (>=3.10)"] jupyter = ["ipython (>=7.8.0)", "tokenize-rt (>=3.2.0)"] uvloop = ["uvloop (>=0.15.2)"] @@ -654,13 +678,13 @@ websockets = ["websocket-client (>=1.3.0)"] [[package]] name = "docutils" -version = "0.19" +version = "0.20.1" description = "Docutils -- Python Documentation Utilities" optional = false python-versions = ">=3.7" files = [ - {file = "docutils-0.19-py3-none-any.whl", hash = "sha256:5e1de4d849fee02c63b040a4a3fd567f4ab104defd8a5511fbbc24a8a017efbc"}, - {file = "docutils-0.19.tar.gz", hash = "sha256:33995a6753c30b7f577febfc2c50411fec6aac7f7ffeb7c4cfe5991072dcf9e6"}, + {file = "docutils-0.20.1-py3-none-any.whl", hash = "sha256:96f387a2c5562db4476f09f13bbab2192e764cac08ebbf3a34a95d9b1e4a59d6"}, + {file = "docutils-0.20.1.tar.gz", hash = "sha256:f08a4e276c3a1583a86dce3e34aba3fe04d02bba2dd51ed16106244e8a923e3b"}, ] [[package]] @@ -785,32 +809,36 @@ networkx = ">=3.3.0,<4.0.0" [[package]] name = "exasol-toolbox" -version = "0.9.0" -description = "" +version = "0.15.0" +description = "Your one-stop solution for managing all standard tasks and core workflows of your Python project." optional = false python-versions = "<4.0,>=3.8" files = [ - {file = "exasol_toolbox-0.9.0-py3-none-any.whl", hash = "sha256:9f7043f0f564afbc8b1b04e957e2fb0669e90d7cabce096438ae22e154b54945"}, - {file = "exasol_toolbox-0.9.0.tar.gz", hash = "sha256:775b1a6926ec024d77cb2d4ca6e0627b7d05ecc9189bcddc91429645fedcdc84"}, + {file = "exasol_toolbox-0.15.0-py3-none-any.whl", hash = "sha256:26d0475a53b868a568ca3b58c50bc2776867d2c6155cca14aae75fac4c7efcfa"}, + {file = "exasol_toolbox-0.15.0.tar.gz", hash = "sha256:14260470633abadb6e4bd3aed49250bfcdef4f14cd09b5878dd42d43770b8c78"}, ] [package.dependencies] -black = ">=23.1.0,<24.0.0" +bandit = {version = ">=1.7.9,<2.0.0", extras = ["toml"]} +black = ">=24.1.0" coverage = ">=6.4.4,<8.0.0" -furo = ">=2022.9.15,<2023.0.0" +furo = ">=2022.9.15" importlib-resources = ">=5.12.0" isort = ">=5.12.0,<6.0.0" mypy = ">=0.971" -myst-parser = ">=2.0.0,<3.0.0" -nox = ">=2022.8.7,<2023.0.0" +myst-parser = ">=2.0.0,<4" +nox = ">=2022.8.7" pluggy = ">=1.5.0,<2.0.0" -pre-commit = ">=3.1.1,<4.0.0" -prysk = {version = ">=0.17.0,<0.18.0", extras = ["pytest-plugin"]} +pre-commit = ">=3.1.1,<4" +prysk = {version = ">0.17.0,<1", extras = ["pytest-plugin"]} pylint = ">=2.15.4" -pytest = ">=7.2.2,<8.0.0" +pytest = ">=7.2.2,<9" pyupgrade = ">=2.38.2,<4.0.0" -sphinx = ">=5.3,<7.0" +shibuya = ">=2024.5.14" +sphinx = ">=5.3,<8" sphinx-copybutton = ">=0.5.0,<0.6.0" +sphinx-design = ">=0.5.0,<1" +sphinx-inline-tabs = ">=2023.4.21,<2024.0.0" typer = {version = ">=0.7.0", extras = ["all"]} [[package]] @@ -865,20 +893,20 @@ typing = ["typing-extensions (>=4.12.2)"] [[package]] name = "furo" -version = "2022.12.7" +version = "2024.8.6" description = "A clean customisable Sphinx documentation theme." optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "furo-2022.12.7-py3-none-any.whl", hash = "sha256:7cb76c12a25ef65db85ab0743df907573d03027a33631f17d267e598ebb191f7"}, - {file = "furo-2022.12.7.tar.gz", hash = "sha256:d8008f8efbe7587a97ba533c8b2df1f9c21ee9b3e5cad0d27f61193d38b1a986"}, + {file = "furo-2024.8.6-py3-none-any.whl", hash = "sha256:6cd97c58b47813d3619e63e9081169880fbe331f0ca883c871ff1f3f11814f5c"}, + {file = "furo-2024.8.6.tar.gz", hash = "sha256:b63e4cee8abfc3136d3bc03a3d45a76a850bada4d6374d24c1716b0e01394a01"}, ] [package.dependencies] beautifulsoup4 = "*" pygments = ">=2.7" -sphinx = ">=5.0,<7.0" -sphinx-basic-ng = "*" +sphinx = ">=6.0,<9.0" +sphinx-basic-ng = ">=1.0.0.beta2" [[package]] name = "gitdb" @@ -1213,71 +1241,72 @@ testing = ["coverage", "pytest", "pytest-cov", "pytest-regressions"] [[package]] name = "markupsafe" -version = "2.1.5" +version = "3.0.0" description = "Safely add untrusted strings to HTML/XML markup." optional = false -python-versions = ">=3.7" +python-versions = ">=3.9" files = [ - {file = "MarkupSafe-2.1.5-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:a17a92de5231666cfbe003f0e4b9b3a7ae3afb1ec2845aadc2bacc93ff85febc"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:72b6be590cc35924b02c78ef34b467da4ba07e4e0f0454a2c5907f473fc50ce5"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:e61659ba32cf2cf1481e575d0462554625196a1f2fc06a1c777d3f48e8865d46"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2174c595a0d73a3080ca3257b40096db99799265e1c27cc5a610743acd86d62f"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ae2ad8ae6ebee9d2d94b17fb62763125f3f374c25618198f40cbb8b525411900"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:075202fa5b72c86ad32dc7d0b56024ebdbcf2048c0ba09f1cde31bfdd57bcfff"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:598e3276b64aff0e7b3451b72e94fa3c238d452e7ddcd893c3ab324717456bad"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:fce659a462a1be54d2ffcacea5e3ba2d74daa74f30f5f143fe0c58636e355fdd"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-win32.whl", hash = "sha256:d9fad5155d72433c921b782e58892377c44bd6252b5af2f67f16b194987338a4"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-win_amd64.whl", hash = "sha256:bf50cd79a75d181c9181df03572cdce0fbb75cc353bc350712073108cba98de5"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:629ddd2ca402ae6dbedfceeba9c46d5f7b2a61d9749597d4307f943ef198fc1f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:5b7b716f97b52c5a14bffdf688f971b2d5ef4029127f1ad7a513973cfd818df2"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:6ec585f69cec0aa07d945b20805be741395e28ac1627333b1c5b0105962ffced"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b91c037585eba9095565a3556f611e3cbfaa42ca1e865f7b8015fe5c7336d5a5"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:7502934a33b54030eaf1194c21c692a534196063db72176b0c4028e140f8f32c"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:0e397ac966fdf721b2c528cf028494e86172b4feba51d65f81ffd65c63798f3f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:c061bb86a71b42465156a3ee7bd58c8c2ceacdbeb95d05a99893e08b8467359a"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:3a57fdd7ce31c7ff06cdfbf31dafa96cc533c21e443d57f5b1ecc6cdc668ec7f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-win32.whl", hash = "sha256:397081c1a0bfb5124355710fe79478cdbeb39626492b15d399526ae53422b906"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-win_amd64.whl", hash = "sha256:2b7c57a4dfc4f16f7142221afe5ba4e093e09e728ca65c51f5620c9aaeb9a617"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-macosx_10_9_universal2.whl", hash = "sha256:8dec4936e9c3100156f8a2dc89c4b88d5c435175ff03413b443469c7c8c5f4d1"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:3c6b973f22eb18a789b1460b4b91bf04ae3f0c4234a0a6aa6b0a92f6f7b951d4"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:ac07bad82163452a6884fe8fa0963fb98c2346ba78d779ec06bd7a6262132aee"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f5dfb42c4604dddc8e4305050aa6deb084540643ed5804d7455b5df8fe16f5e5"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ea3d8a3d18833cf4304cd2fc9cbb1efe188ca9b5efef2bdac7adc20594a0e46b"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:d050b3361367a06d752db6ead6e7edeb0009be66bc3bae0ee9d97fb326badc2a"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:bec0a414d016ac1a18862a519e54b2fd0fc8bbfd6890376898a6c0891dd82e9f"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:58c98fee265677f63a4385256a6d7683ab1832f3ddd1e66fe948d5880c21a169"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-win32.whl", hash = "sha256:8590b4ae07a35970728874632fed7bd57b26b0102df2d2b233b6d9d82f6c62ad"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-win_amd64.whl", hash = "sha256:823b65d8706e32ad2df51ed89496147a42a2a6e01c13cfb6ffb8b1e92bc910bb"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:c8b29db45f8fe46ad280a7294f5c3ec36dbac9491f2d1c17345be8e69cc5928f"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:ec6a563cff360b50eed26f13adc43e61bc0c04d94b8be985e6fb24b81f6dcfdf"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a549b9c31bec33820e885335b451286e2969a2d9e24879f83fe904a5ce59d70a"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4f11aa001c540f62c6166c7726f71f7573b52c68c31f014c25cc7901deea0b52"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_aarch64.whl", hash = "sha256:7b2e5a267c855eea6b4283940daa6e88a285f5f2a67f2220203786dfa59b37e9"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:2d2d793e36e230fd32babe143b04cec8a8b3eb8a3122d2aceb4a371e6b09b8df"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:ce409136744f6521e39fd8e2a24c53fa18ad67aa5bc7c2cf83645cce5b5c4e50"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-win32.whl", hash = "sha256:4096e9de5c6fdf43fb4f04c26fb114f61ef0bf2e5604b6ee3019d51b69e8c371"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-win_amd64.whl", hash = "sha256:4275d846e41ecefa46e2015117a9f491e57a71ddd59bbead77e904dc02b1bed2"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-macosx_10_9_universal2.whl", hash = "sha256:656f7526c69fac7f600bd1f400991cc282b417d17539a1b228617081106feb4a"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:97cafb1f3cbcd3fd2b6fbfb99ae11cdb14deea0736fc2b0952ee177f2b813a46"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:1f3fbcb7ef1f16e48246f704ab79d79da8a46891e2da03f8783a5b6fa41a9532"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:fa9db3f79de01457b03d4f01b34cf91bc0048eb2c3846ff26f66687c2f6d16ab"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ffee1f21e5ef0d712f9033568f8344d5da8cc2869dbd08d87c84656e6a2d2f68"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:5dedb4db619ba5a2787a94d877bc8ffc0566f92a01c0ef214865e54ecc9ee5e0"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:30b600cf0a7ac9234b2638fbc0fb6158ba5bdcdf46aeb631ead21248b9affbc4"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:8dd717634f5a044f860435c1d8c16a270ddf0ef8588d4887037c5028b859b0c3"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-win32.whl", hash = "sha256:daa4ee5a243f0f20d528d939d06670a298dd39b1ad5f8a72a4275124a7819eff"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-win_amd64.whl", hash = "sha256:619bc166c4f2de5caa5a633b8b7326fbe98e0ccbfacabd87268a2b15ff73a029"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:7a68b554d356a91cce1236aa7682dc01df0edba8d043fd1ce607c49dd3c1edcf"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:db0b55e0f3cc0be60c1f19efdde9a637c32740486004f20d1cff53c3c0ece4d2"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:3e53af139f8579a6d5f7b76549125f0d94d7e630761a2111bc431fd820e163b8"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:17b950fccb810b3293638215058e432159d2b71005c74371d784862b7e4683f3"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4c31f53cdae6ecfa91a77820e8b151dba54ab528ba65dfd235c80b086d68a465"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:bff1b4290a66b490a2f4719358c0cdcd9bafb6b8f061e45c7a2460866bf50c2e"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:bc1667f8b83f48511b94671e0e441401371dfd0f0a795c7daa4a3cd1dde55bea"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:5049256f536511ee3f7e1b3f87d1d1209d327e818e6ae1365e8653d7e3abb6a6"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-win32.whl", hash = "sha256:00e046b6dd71aa03a41079792f8473dc494d564611a8f89bbbd7cb93295ebdcf"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-win_amd64.whl", hash = "sha256:fa173ec60341d6bb97a89f5ea19c85c5643c1e7dedebc22f5181eb73573142c5"}, - {file = "MarkupSafe-2.1.5.tar.gz", hash = "sha256:d283d37a890ba4c1ae73ffadf8046435c76e7bc2247bbb63c00bd1a709c6544b"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:380faf314c3c84c1682ca672e6280c6c59e92d0bc13dc71758ffa2de3cd4e252"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:1ee9790be6f62121c4c58bbced387b0965ab7bffeecb4e17cc42ef290784e363"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:5ddf5cb8e9c00d9bf8b0c75949fb3ff9ea2096ba531693e2e87336d197fdb908"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:9b36473a2d3e882d1873ea906ce54408b9588dc2c65989664e6e7f5a2de353d7"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:dba0f83119b9514bc37272ad012f0cc03f0805cc6a2bea7244e19250ac8ff29f"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_aarch64.whl", hash = "sha256:409535e0521c4630d5b5a1bf284e9d3c76d2fc2f153ebb12cf3827797798cc99"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_i686.whl", hash = "sha256:64a7c7856c3a409011139b17d137c2924df4318dab91ee0530800819617c4381"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_x86_64.whl", hash = "sha256:4deea1d9169578917d1f35cdb581bc7bab56a7e8c5be2633bd1b9549c3c22a01"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-win32.whl", hash = "sha256:3cd0bba31d484fe9b9d77698ddb67c978704603dc10cdc905512af308cfcca6b"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-win_amd64.whl", hash = "sha256:4ca04c60006867610a06575b46941ae616b19da0adc85b9f8f3d9cbd7a3da385"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:e64b390a306f9e849ee809f92af6a52cda41741c914358e0e9f8499d03741526"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:7c524203207f5b569df06c96dafdc337228921ee8c3cc5f6e891d024c6595352"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c409691696bec2b5e5c9efd9593c99025bf2f317380bf0d993ee0213516d908a"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:64f7d04410be600aa5ec0626d73d43e68a51c86500ce12917e10fd013e258df5"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:105ada43a61af22acb8774514c51900dc820c481cc5ba53f17c09d294d9c07ca"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_aarch64.whl", hash = "sha256:a5fd5500d4e4f7cc88d8c0f2e45126c4307ed31e08f8ec521474f2fd99d35ac3"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_i686.whl", hash = "sha256:25396abd52b16900932e05b7104bcdc640a4d96c914f39c3b984e5a17b01fba0"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_x86_64.whl", hash = "sha256:3efde9a8c56c3b6e5f3fa4baea828f8184970c7c78480fedb620d804b1c31e5c"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-win32.whl", hash = "sha256:12ddac720b8965332d36196f6f83477c6351ba6a25d4aff91e30708c729350d7"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-win_amd64.whl", hash = "sha256:658fdf6022740896c403d45148bf0c36978c6b48c9ef8b1f8d0c7a11b6cdea86"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-macosx_10_13_universal2.whl", hash = "sha256:d261ec38b8a99a39b62e0119ed47fe3b62f7691c500bc1e815265adc016438c1"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:e363440c8534bf2f2ef1b8fdc02037eb5fff8fce2a558519b22d6a3a38b3ec5e"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:7835de4c56066e096407a1852e5561f6033786dd987fa90dc384e45b9bd21295"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b6cc46a27d904c9be5732029769acf4b0af69345172ed1ef6d4db0c023ff603b"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:f0411641d31aa6f7f0cc13f0f18b63b8dc08da5f3a7505972a42ab059f479ba3"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_aarch64.whl", hash = "sha256:b2a7afd24d408b907672015555bc10be2382e6c5f62a488e2d452da670bbd389"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_i686.whl", hash = "sha256:c8ab7efeff1884c5da8e18f743b667215300e09043820d11723718de0b7db934"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_x86_64.whl", hash = "sha256:8219e2207f6c188d15614ea043636c2b36d2d79bf853639c124a179412325a13"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-win32.whl", hash = "sha256:59420b5a9a5d3fee483a32adb56d7369ae0d630798da056001be1e9f674f3aa6"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-win_amd64.whl", hash = "sha256:7ed789d0f7f11fcf118cf0acb378743dfdd4215d7f7d18837c88171405c9a452"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-macosx_10_13_universal2.whl", hash = "sha256:27d6a73682b99568916c54a4bfced40e7d871ba685b580ea04bbd2e405dfd4c5"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:494a64efc535e147fcc713dba58eecfce3a79f1e93ebe81995b387f5cd9bc2e1"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c5243044a927e8a6bb28517838662a019cd7f73d7f106bbb37ab5e7fa8451a92"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:63dae84964a9a3d2610808cee038f435d9a111620c37ccf872c2fcaeca6865b3"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:dcbee57fedc9b2182c54ffc1c5eed316c3da8bbfeda8009e1b5d7220199d15da"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_aarch64.whl", hash = "sha256:f846fd7c241e5bd4161e2a483663eb66e4d8e12130fcdc052f310f388f1d61c6"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_i686.whl", hash = "sha256:678fbceb202382aae42c1f0cd9f56b776bc20a58ae5b553ee1fe6b802983a1d6"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_x86_64.whl", hash = "sha256:bd9b8e458e2bab52f9ad3ab5dc8b689a3c84b12b2a2f64cd9a0dfe209fb6b42f"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-win32.whl", hash = "sha256:1fd02f47596e00a372f5b4af2b4c45f528bade65c66dfcbc6e1ea1bfda758e98"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-win_amd64.whl", hash = "sha256:b94bec9eda10111ec7102ef909eca4f3c2df979643924bfe58375f560713a7d1"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-macosx_10_13_universal2.whl", hash = "sha256:509c424069dd037d078925b6815fc56b7271f3aaec471e55e6fa513b0a80d2aa"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-macosx_11_0_arm64.whl", hash = "sha256:81be2c0084d8c69e97e3c5d73ce9e2a6e523556f2a19c4e195c09d499be2f808"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b43ac1eb9f91e0c14aac1d2ef0f76bc7b9ceea51de47536f61268191adf52ad7"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:3b231255770723f1e125d63c14269bcd8b8136ecfb620b9a18c0297e046d0736"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:c182d45600556917f811aa019d834a89fe4b6f6255da2fd0bdcf80e970f95918"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_aarch64.whl", hash = "sha256:9f91c90f8f3bf436f81c12eeb4d79f9ddd263c71125e6ad71341906832a34386"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_i686.whl", hash = "sha256:a7171d2b869e9be238ea318c196baf58fbf272704e9c1cd4be8c380eea963342"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_x86_64.whl", hash = "sha256:cb244adf2499aa37d5dc43431990c7f0b632d841af66a51d22bd89c437b60264"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-win32.whl", hash = "sha256:96e3ed550600185d34429477f1176cedea8293fa40e47fe37a05751bcb64c997"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-win_amd64.whl", hash = "sha256:1d151b9cf3307e259b749125a5a08c030ba15a8f1d567ca5bfb0e92f35e761f5"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:23efb2be7221105c8eb0e905433414d2439cb0a8c5d5ca081c1c72acef0f5613"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:81ee9c967956b9ea39b3a5270b7cb1740928d205b0dc72629164ce621b4debf9"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:5509a8373fed30b978557890a226c3d30569746c565b9daba69df80c160365a5"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f1c13c6c908811f867a8e9e66efb2d6c03d1cdd83e92788fe97f693c457dc44f"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:d7e63d1977d3806ce0a1a3e0099b089f61abdede5238ca6a3f3bf8877b46d095"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_aarch64.whl", hash = "sha256:d2c099be5274847d606574234e494f23a359e829ba337ea9037c3a72b0851942"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_i686.whl", hash = "sha256:e042ccf8fe5bf8b6a4b38b3f7d618eb10ea20402b0c9f4add9293408de447974"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_x86_64.whl", hash = "sha256:98fb3a2bf525ad66db96745707b93ba0f78928b7a1cb2f1cb4b143bc7e2ba3b3"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-win32.whl", hash = "sha256:a80c6740e1bfbe50cea7cbf74f48823bb57bd59d914ee22ff8a81963b08e62d2"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-win_amd64.whl", hash = "sha256:5d207ff5cceef77796f8aacd44263266248cf1fbc601441524d7835613f8abec"}, + {file = "markupsafe-3.0.0.tar.gz", hash = "sha256:03ff62dea2fef3eadf2f1853bc6332bcb0458d9608b11dfb1cd5aeda1c178ea6"}, ] [[package]] @@ -1381,17 +1410,17 @@ files = [ [[package]] name = "myst-parser" -version = "2.0.0" +version = "3.0.1" description = "An extended [CommonMark](https://spec.commonmark.org/) compliant parser," optional = false python-versions = ">=3.8" files = [ - {file = "myst_parser-2.0.0-py3-none-any.whl", hash = "sha256:7c36344ae39c8e740dad7fdabf5aa6fc4897a813083c6cc9990044eb93656b14"}, - {file = "myst_parser-2.0.0.tar.gz", hash = "sha256:ea929a67a6a0b1683cdbe19b8d2e724cd7643f8aa3e7bb18dd65beac3483bead"}, + {file = "myst_parser-3.0.1-py3-none-any.whl", hash = "sha256:6457aaa33a5d474aca678b8ead9b3dc298e89c68e67012e73146ea6fd54babf1"}, + {file = "myst_parser-3.0.1.tar.gz", hash = "sha256:88f0cb406cb363b077d176b51c476f62d60604d68a8dcdf4832e080441301a87"}, ] [package.dependencies] -docutils = ">=0.16,<0.21" +docutils = ">=0.18,<0.22" jinja2 = "*" markdown-it-py = ">=3.0,<4.0" mdit-py-plugins = ">=0.4,<1.0" @@ -1401,9 +1430,9 @@ sphinx = ">=6,<8" [package.extras] code-style = ["pre-commit (>=3.0,<4.0)"] linkify = ["linkify-it-py (>=2.0,<3.0)"] -rtd = ["ipython", "pydata-sphinx-theme (==v0.13.0rc4)", "sphinx-autodoc2 (>=0.4.2,<0.5.0)", "sphinx-book-theme (==1.0.0rc2)", "sphinx-copybutton", "sphinx-design2", "sphinx-pyscript", "sphinx-tippy (>=0.3.1)", "sphinx-togglebutton", "sphinxext-opengraph (>=0.8.2,<0.9.0)", "sphinxext-rediraffe (>=0.2.7,<0.3.0)"] -testing = ["beautifulsoup4", "coverage[toml]", "pytest (>=7,<8)", "pytest-cov", "pytest-param-files (>=0.3.4,<0.4.0)", "pytest-regressions", "sphinx-pytest"] -testing-docutils = ["pygments", "pytest (>=7,<8)", "pytest-param-files (>=0.3.4,<0.4.0)"] +rtd = ["ipython", "sphinx (>=7)", "sphinx-autodoc2 (>=0.5.0,<0.6.0)", "sphinx-book-theme (>=1.1,<2.0)", "sphinx-copybutton", "sphinx-design", "sphinx-pyscript", "sphinx-tippy (>=0.4.3)", "sphinx-togglebutton", "sphinxext-opengraph (>=0.9.0,<0.10.0)", "sphinxext-rediraffe (>=0.2.7,<0.3.0)"] +testing = ["beautifulsoup4", "coverage[toml]", "defusedxml", "pytest (>=8,<9)", "pytest-cov", "pytest-param-files (>=0.6.0,<0.7.0)", "pytest-regressions", "sphinx-pytest"] +testing-docutils = ["pygments", "pytest (>=8,<9)", "pytest-param-files (>=0.6.0,<0.7.0)"] [[package]] name = "netaddr" @@ -1450,23 +1479,25 @@ files = [ [[package]] name = "nox" -version = "2022.11.21" +version = "2024.4.15" description = "Flexible test automation." optional = false python-versions = ">=3.7" files = [ - {file = "nox-2022.11.21-py3-none-any.whl", hash = "sha256:0e41a990e290e274cb205a976c4c97ee3c5234441a8132c8c3fd9ea3c22149eb"}, - {file = "nox-2022.11.21.tar.gz", hash = "sha256:e21c31de0711d1274ca585a2c5fde36b1aa962005ba8e9322bf5eeed16dcd684"}, + {file = "nox-2024.4.15-py3-none-any.whl", hash = "sha256:6492236efa15a460ecb98e7b67562a28b70da006ab0be164e8821177577c0565"}, + {file = "nox-2024.4.15.tar.gz", hash = "sha256:ecf6700199cdfa9e5ea0a41ff5e6ef4641d09508eda6edb89d9987864115817f"}, ] [package.dependencies] -argcomplete = ">=1.9.4,<3.0" +argcomplete = ">=1.9.4,<4.0" colorlog = ">=2.6.1,<7.0.0" packaging = ">=20.9" -virtualenv = ">=14" +tomli = {version = ">=1", markers = "python_version < \"3.11\""} +virtualenv = ">=20.14.1" [package.extras] tox-to-nox = ["jinja2", "tox"] +uv = ["uv (>=0.1.6)"] [[package]] name = "packaging" @@ -1511,6 +1542,17 @@ files = [ {file = "pathspec-0.12.1.tar.gz", hash = "sha256:a482d51503a1ab33b1c67a6c3813a26953dbdc71c31dacaef9a838c4e29f5712"}, ] +[[package]] +name = "pbr" +version = "6.1.0" +description = "Python Build Reasonableness" +optional = false +python-versions = ">=2.6" +files = [ + {file = "pbr-6.1.0-py2.py3-none-any.whl", hash = "sha256:a776ae228892d8013649c0aeccbb3d5f99ee15e005a4cbb7e61d55a067b28a2a"}, + {file = "pbr-6.1.0.tar.gz", hash = "sha256:788183e382e3d1d7707db08978239965e8b9e4e5ed42669bf4758186734d5f24"}, +] + [[package]] name = "platformdirs" version = "4.3.6" @@ -1581,13 +1623,13 @@ virtualenv = ">=20.10.0" [[package]] name = "prysk" -version = "0.17.0" +version = "0.20.0" description = "Functional tests for command line applications" optional = false -python-versions = ">=3.8,<4.0.0" +python-versions = "<4.0.0,>=3.8" files = [ - {file = "prysk-0.17.0-py3-none-any.whl", hash = "sha256:c2e0ce69ede821e5a7e03f576c51e2a35000c570f6e22cf7c13daec1b3978832"}, - {file = "prysk-0.17.0.tar.gz", hash = "sha256:0a500bb9ff742eca878d5802bad9fcfd7ba1c6bbae64b2a2ff96bff94d4f8ad8"}, + {file = "prysk-0.20.0-py3-none-any.whl", hash = "sha256:3758f59febe1ff27710c8ba69a8edad42286050d041ed8df519fc4bbeea41133"}, + {file = "prysk-0.20.0.tar.gz", hash = "sha256:3499d24c9c8d534754d3915218cb2ab59cf59a8d6f37acfb68dc582650e67e33"}, ] [package.dependencies] @@ -2053,6 +2095,20 @@ files = [ {file = "shellingham-1.5.4.tar.gz", hash = "sha256:8dbca0739d487e5bd35ab3ca4b36e11c4078f3a234bfce294b0a0291363404de"}, ] +[[package]] +name = "shibuya" +version = "2024.8.30" +description = "A clean, responsive, and customizable Sphinx documentation theme with light/dark mode." +optional = false +python-versions = ">=3.7" +files = [ + {file = "shibuya-2024.8.30-py3-none-any.whl", hash = "sha256:c5b865132babcddc4ed600b36a6d05ecc869979f358d9796268927e1eb7ef619"}, + {file = "shibuya-2024.8.30.tar.gz", hash = "sha256:0fdc75643ee40d00fb9a0f1f26ce1085e88df8e48b525a228fe202ffdf31883d"}, +] + +[package.dependencies] +Sphinx = "*" + [[package]] name = "simplejson" version = "3.19.3" @@ -2229,37 +2285,38 @@ files = [ [[package]] name = "sphinx" -version = "6.2.1" +version = "7.4.7" description = "Python documentation generator" optional = false -python-versions = ">=3.8" +python-versions = ">=3.9" files = [ - {file = "Sphinx-6.2.1.tar.gz", hash = "sha256:6d56a34697bb749ffa0152feafc4b19836c755d90a7c59b72bc7dfd371b9cc6b"}, - {file = "sphinx-6.2.1-py3-none-any.whl", hash = "sha256:97787ff1fa3256a3eef9eda523a63dbf299f7b47e053cfcf684a1c2a8380c912"}, + {file = "sphinx-7.4.7-py3-none-any.whl", hash = "sha256:c2419e2135d11f1951cd994d6eb18a1835bd8fdd8429f9ca375dc1f3281bd239"}, + {file = "sphinx-7.4.7.tar.gz", hash = "sha256:242f92a7ea7e6c5b406fdc2615413890ba9f699114a9c09192d7dfead2ee9cfe"}, ] [package.dependencies] -alabaster = ">=0.7,<0.8" -babel = ">=2.9" -colorama = {version = ">=0.4.5", markers = "sys_platform == \"win32\""} -docutils = ">=0.18.1,<0.20" +alabaster = ">=0.7.14,<0.8.0" +babel = ">=2.13" +colorama = {version = ">=0.4.6", markers = "sys_platform == \"win32\""} +docutils = ">=0.20,<0.22" imagesize = ">=1.3" -Jinja2 = ">=3.0" -packaging = ">=21.0" -Pygments = ">=2.13" -requests = ">=2.25.0" -snowballstemmer = ">=2.0" +Jinja2 = ">=3.1" +packaging = ">=23.0" +Pygments = ">=2.17" +requests = ">=2.30.0" +snowballstemmer = ">=2.2" sphinxcontrib-applehelp = "*" sphinxcontrib-devhelp = "*" sphinxcontrib-htmlhelp = ">=2.0.0" sphinxcontrib-jsmath = "*" sphinxcontrib-qthelp = "*" -sphinxcontrib-serializinghtml = ">=1.1.5" +sphinxcontrib-serializinghtml = ">=1.1.9" +tomli = {version = ">=2", markers = "python_version < \"3.11\""} [package.extras] 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)"] +lint = ["flake8 (>=6.0)", "importlib-metadata (>=6.0)", "mypy (==1.10.1)", "pytest (>=6.0)", "ruff (==0.5.2)", "sphinx-lint (>=0.9)", "tomli (>=2)", "types-docutils (==0.21.0.20240711)", "types-requests (>=2.30.0)"] +test = ["cython (>=3.0)", "defusedxml (>=0.7.1)", "pytest (>=8.0)", "setuptools (>=70.0)", "typing_extensions (>=4.9)"] [[package]] name = "sphinx-basic-ng" @@ -2296,6 +2353,49 @@ sphinx = ">=1.8" code-style = ["pre-commit (==2.12.1)"] rtd = ["ipython", "myst-nb", "sphinx", "sphinx-book-theme", "sphinx-examples"] +[[package]] +name = "sphinx-design" +version = "0.6.1" +description = "A sphinx extension for designing beautiful, view size responsive web components." +optional = false +python-versions = ">=3.9" +files = [ + {file = "sphinx_design-0.6.1-py3-none-any.whl", hash = "sha256:b11f37db1a802a183d61b159d9a202314d4d2fe29c163437001324fe2f19549c"}, + {file = "sphinx_design-0.6.1.tar.gz", hash = "sha256:b44eea3719386d04d765c1a8257caca2b3e6f8421d7b3a5e742c0fd45f84e632"}, +] + +[package.dependencies] +sphinx = ">=6,<9" + +[package.extras] +code-style = ["pre-commit (>=3,<4)"] +rtd = ["myst-parser (>=2,<4)"] +testing = ["defusedxml", "myst-parser (>=2,<4)", "pytest (>=8.3,<9.0)", "pytest-cov", "pytest-regressions"] +testing-no-myst = ["defusedxml", "pytest (>=8.3,<9.0)", "pytest-cov", "pytest-regressions"] +theme-furo = ["furo (>=2024.7.18,<2024.8.0)"] +theme-im = ["sphinx-immaterial (>=0.12.2,<0.13.0)"] +theme-pydata = ["pydata-sphinx-theme (>=0.15.2,<0.16.0)"] +theme-rtd = ["sphinx-rtd-theme (>=2.0,<3.0)"] +theme-sbt = ["sphinx-book-theme (>=1.1,<2.0)"] + +[[package]] +name = "sphinx-inline-tabs" +version = "2023.4.21" +description = "Add inline tabbed content to your Sphinx documentation." +optional = false +python-versions = ">=3.8" +files = [ + {file = "sphinx_inline_tabs-2023.4.21-py3-none-any.whl", hash = "sha256:06809ac613f7c48ddd6e2fa588413e3fe92cff2397b56e2ccf0b0218f9ef6a78"}, + {file = "sphinx_inline_tabs-2023.4.21.tar.gz", hash = "sha256:5df2f13f602c158f3f5f6c509e008aeada199a8c76d97ba3aa2822206683bebc"}, +] + +[package.dependencies] +sphinx = ">=3" + +[package.extras] +doc = ["furo", "myst-parser"] +test = ["pytest", "pytest-cov", "pytest-xdist"] + [[package]] name = "sphinxcontrib-applehelp" version = "2.0.0" @@ -2390,6 +2490,20 @@ lint = ["mypy", "ruff (==0.5.5)", "types-docutils"] standalone = ["Sphinx (>=5)"] test = ["pytest"] +[[package]] +name = "stevedore" +version = "5.3.0" +description = "Manage dynamic plugins for Python applications" +optional = false +python-versions = ">=3.8" +files = [ + {file = "stevedore-5.3.0-py3-none-any.whl", hash = "sha256:1efd34ca08f474dad08d9b19e934a22c68bb6fe416926479ba29e5013bcc8f78"}, + {file = "stevedore-5.3.0.tar.gz", hash = "sha256:9a64265f4060312828151c204efbe9b7a9852a0d9228756344dbc7e4023e375a"}, +] + +[package.dependencies] +pbr = ">=2.0.0" + [[package]] name = "stopwatch-py" version = "2.0.1" @@ -2683,4 +2797,4 @@ type = ["pytest-mypy"] [metadata] lock-version = "2.0" python-versions = ">=3.10,<4" -content-hash = "a02cd1c68a38920eab6386dc4ff78d458b3dc17c3b35a6c54fcc6a1781b653bb" +content-hash = "d089b7c4203ae09d753fd8e324d8785b61b07775da96fc78a51f4b19b2871c42" diff --git a/pytest-extension/pyproject.toml b/pytest-extension/pyproject.toml index 7d502d4..6b33dd7 100644 --- a/pytest-extension/pyproject.toml +++ b/pytest-extension/pyproject.toml @@ -17,8 +17,8 @@ exasol-python-extension-common = ">=0.7.0,<1" ext = "exasol.pytest_extension" [tool.poetry.group.dev.dependencies] -exasol-toolbox = "0.9.0" -exasol-bucketfs = ">=0.12.0" +exasol-toolbox = ">=0.15.0,<1" +exasol-bucketfs = ">=0.13.0,<1" click = "^8.1.7" [build-system] diff --git a/pytest-slc/poetry.lock b/pytest-slc/poetry.lock index b664124..a76b4a5 100644 --- a/pytest-slc/poetry.lock +++ b/pytest-slc/poetry.lock @@ -1,4 +1,4 @@ -# This file is automatically @generated by Poetry 1.8.3 and should not be changed by hand. +# This file is automatically @generated by Poetry 1.8.2 and should not be changed by hand. [[package]] name = "alabaster" @@ -35,28 +35,27 @@ trio = ["trio (>=0.26.1)"] [[package]] name = "argcomplete" -version = "2.1.2" +version = "3.5.1" description = "Bash tab completion for argparse" optional = false -python-versions = ">=3.6" +python-versions = ">=3.8" files = [ - {file = "argcomplete-2.1.2-py3-none-any.whl", hash = "sha256:4ba9cdaa28c361d251edce884cd50b4b1215d65cdc881bd204426cdde9f52731"}, - {file = "argcomplete-2.1.2.tar.gz", hash = "sha256:fc82ef070c607b1559b5c720529d63b54d9dcf2dcfc2632b10e6372314a34457"}, + {file = "argcomplete-3.5.1-py3-none-any.whl", hash = "sha256:1a1d148bdaa3e3b93454900163403df41448a248af01b6e849edc5ac08e6c363"}, + {file = "argcomplete-3.5.1.tar.gz", hash = "sha256:eb1ee355aa2557bd3d0145de7b06b2a45b0ce461e1e7813f5d066039ab4177b4"}, ] [package.extras] -lint = ["flake8", "mypy"] -test = ["coverage", "flake8", "mypy", "pexpect", "wheel"] +test = ["coverage", "mypy", "pexpect", "ruff", "wheel"] [[package]] name = "astroid" -version = "3.3.4" +version = "3.3.5" description = "An abstract syntax tree for Python with inference support." optional = false python-versions = ">=3.9.0" files = [ - {file = "astroid-3.3.4-py3-none-any.whl", hash = "sha256:5eba185467253501b62a9f113c263524b4f5d55e1b30456370eed4cdbd6438fd"}, - {file = "astroid-3.3.4.tar.gz", hash = "sha256:e73d0b62dd680a7c07cb2cd0ce3c22570b044dd01bd994bc3a2dd16c6cbba162"}, + {file = "astroid-3.3.5-py3-none-any.whl", hash = "sha256:a9d1c946ada25098d790e079ba2a1b112157278f3fb7e718ae6a9252f5835dc8"}, + {file = "astroid-3.3.5.tar.gz", hash = "sha256:5cfc40ae9f68311075d27ef68a4841bdc5cc7f6cf86671b49f00607d30188e2d"}, ] [package.dependencies] @@ -95,6 +94,31 @@ files = [ [package.extras] dev = ["freezegun (>=1.0,<2.0)", "pytest (>=6.0)", "pytest-cov"] +[[package]] +name = "bandit" +version = "1.7.10" +description = "Security oriented static analyser for python code." +optional = false +python-versions = ">=3.8" +files = [ + {file = "bandit-1.7.10-py3-none-any.whl", hash = "sha256:665721d7bebbb4485a339c55161ac0eedde27d51e638000d91c8c2d68343ad02"}, + {file = "bandit-1.7.10.tar.gz", hash = "sha256:59ed5caf5d92b6ada4bf65bc6437feea4a9da1093384445fed4d472acc6cff7b"}, +] + +[package.dependencies] +colorama = {version = ">=0.3.9", markers = "platform_system == \"Windows\""} +PyYAML = ">=5.3.1" +rich = "*" +stevedore = ">=1.20.0" +tomli = {version = ">=1.1.0", optional = true, markers = "python_version < \"3.11\" and extra == \"toml\""} + +[package.extras] +baseline = ["GitPython (>=3.1.30)"] +sarif = ["jschema-to-python (>=1.2.3)", "sarif-om (>=1.0.4)"] +test = ["beautifulsoup4 (>=4.8.0)", "coverage (>=4.5.4)", "fixtures (>=3.0.0)", "flake8 (>=4.0.0)", "pylint (==1.9.4)", "stestr (>=2.5.0)", "testscenarios (>=0.5.0)", "testtools (>=2.3.0)"] +toml = ["tomli (>=1.1.0)"] +yaml = ["PyYAML"] + [[package]] name = "bcrypt" version = "4.2.0" @@ -158,33 +182,33 @@ lxml = ["lxml"] [[package]] name = "black" -version = "23.12.1" +version = "24.10.0" description = "The uncompromising code formatter." optional = false -python-versions = ">=3.8" +python-versions = ">=3.9" files = [ - {file = "black-23.12.1-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:e0aaf6041986767a5e0ce663c7a2f0e9eaf21e6ff87a5f95cbf3675bfd4c41d2"}, - {file = "black-23.12.1-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:c88b3711d12905b74206227109272673edce0cb29f27e1385f33b0163c414bba"}, - {file = "black-23.12.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a920b569dc6b3472513ba6ddea21f440d4b4c699494d2e972a1753cdc25df7b0"}, - {file = "black-23.12.1-cp310-cp310-win_amd64.whl", hash = "sha256:3fa4be75ef2a6b96ea8d92b1587dd8cb3a35c7e3d51f0738ced0781c3aa3a5a3"}, - {file = "black-23.12.1-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:8d4df77958a622f9b5a4c96edb4b8c0034f8434032ab11077ec6c56ae9f384ba"}, - {file = "black-23.12.1-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:602cfb1196dc692424c70b6507593a2b29aac0547c1be9a1d1365f0d964c353b"}, - {file = "black-23.12.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:9c4352800f14be5b4864016882cdba10755bd50805c95f728011bcb47a4afd59"}, - {file = "black-23.12.1-cp311-cp311-win_amd64.whl", hash = "sha256:0808494f2b2df923ffc5723ed3c7b096bd76341f6213989759287611e9837d50"}, - {file = "black-23.12.1-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:25e57fd232a6d6ff3f4478a6fd0580838e47c93c83eaf1ccc92d4faf27112c4e"}, - {file = "black-23.12.1-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:2d9e13db441c509a3763a7a3d9a49ccc1b4e974a47be4e08ade2a228876500ec"}, - {file = "black-23.12.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6d1bd9c210f8b109b1762ec9fd36592fdd528485aadb3f5849b2740ef17e674e"}, - {file = "black-23.12.1-cp312-cp312-win_amd64.whl", hash = "sha256:ae76c22bde5cbb6bfd211ec343ded2163bba7883c7bc77f6b756a1049436fbb9"}, - {file = "black-23.12.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:1fa88a0f74e50e4487477bc0bb900c6781dbddfdfa32691e780bf854c3b4a47f"}, - {file = "black-23.12.1-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:a4d6a9668e45ad99d2f8ec70d5c8c04ef4f32f648ef39048d010b0689832ec6d"}, - {file = "black-23.12.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b18fb2ae6c4bb63eebe5be6bd869ba2f14fd0259bda7d18a46b764d8fb86298a"}, - {file = "black-23.12.1-cp38-cp38-win_amd64.whl", hash = "sha256:c04b6d9d20e9c13f43eee8ea87d44156b8505ca8a3c878773f68b4e4812a421e"}, - {file = "black-23.12.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:3e1b38b3135fd4c025c28c55ddfc236b05af657828a8a6abe5deec419a0b7055"}, - {file = "black-23.12.1-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:4f0031eaa7b921db76decd73636ef3a12c942ed367d8c3841a0739412b260a54"}, - {file = "black-23.12.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:97e56155c6b737854e60a9ab1c598ff2533d57e7506d97af5481141671abf3ea"}, - {file = "black-23.12.1-cp39-cp39-win_amd64.whl", hash = "sha256:dd15245c8b68fe2b6bd0f32c1556509d11bb33aec9b5d0866dd8e2ed3dba09c2"}, - {file = "black-23.12.1-py3-none-any.whl", hash = "sha256:78baad24af0f033958cad29731e27363183e140962595def56423e626f4bee3e"}, - {file = "black-23.12.1.tar.gz", hash = "sha256:4ce3ef14ebe8d9509188014d96af1c456a910d5b5cbf434a09fef7e024b3d0d5"}, + {file = "black-24.10.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:e6668650ea4b685440857138e5fe40cde4d652633b1bdffc62933d0db4ed9812"}, + {file = "black-24.10.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:1c536fcf674217e87b8cc3657b81809d3c085d7bf3ef262ead700da345bfa6ea"}, + {file = "black-24.10.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:649fff99a20bd06c6f727d2a27f401331dc0cc861fb69cde910fe95b01b5928f"}, + {file = "black-24.10.0-cp310-cp310-win_amd64.whl", hash = "sha256:fe4d6476887de70546212c99ac9bd803d90b42fc4767f058a0baa895013fbb3e"}, + {file = "black-24.10.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:5a2221696a8224e335c28816a9d331a6c2ae15a2ee34ec857dcf3e45dbfa99ad"}, + {file = "black-24.10.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:f9da3333530dbcecc1be13e69c250ed8dfa67f43c4005fb537bb426e19200d50"}, + {file = "black-24.10.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:4007b1393d902b48b36958a216c20c4482f601569d19ed1df294a496eb366392"}, + {file = "black-24.10.0-cp311-cp311-win_amd64.whl", hash = "sha256:394d4ddc64782e51153eadcaaca95144ac4c35e27ef9b0a42e121ae7e57a9175"}, + {file = "black-24.10.0-cp312-cp312-macosx_10_13_x86_64.whl", hash = "sha256:b5e39e0fae001df40f95bd8cc36b9165c5e2ea88900167bddf258bacef9bbdc3"}, + {file = "black-24.10.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:d37d422772111794b26757c5b55a3eade028aa3fde43121ab7b673d050949d65"}, + {file = "black-24.10.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:14b3502784f09ce2443830e3133dacf2c0110d45191ed470ecb04d0f5f6fcb0f"}, + {file = "black-24.10.0-cp312-cp312-win_amd64.whl", hash = "sha256:30d2c30dc5139211dda799758559d1b049f7f14c580c409d6ad925b74a4208a8"}, + {file = "black-24.10.0-cp313-cp313-macosx_10_13_x86_64.whl", hash = "sha256:1cbacacb19e922a1d75ef2b6ccaefcd6e93a2c05ede32f06a21386a04cedb981"}, + {file = "black-24.10.0-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:1f93102e0c5bb3907451063e08b9876dbeac810e7da5a8bfb7aeb5a9ef89066b"}, + {file = "black-24.10.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:ddacb691cdcdf77b96f549cf9591701d8db36b2f19519373d60d31746068dbf2"}, + {file = "black-24.10.0-cp313-cp313-win_amd64.whl", hash = "sha256:680359d932801c76d2e9c9068d05c6b107f2584b2a5b88831c83962eb9984c1b"}, + {file = "black-24.10.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:17374989640fbca88b6a448129cd1745c5eb8d9547b464f281b251dd00155ccd"}, + {file = "black-24.10.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:63f626344343083322233f175aaf372d326de8436f5928c042639a4afbbf1d3f"}, + {file = "black-24.10.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl", hash = "sha256:ccfa1d0cb6200857f1923b602f978386a3a2758a65b52e0950299ea014be6800"}, + {file = "black-24.10.0-cp39-cp39-win_amd64.whl", hash = "sha256:2cd9c95431d94adc56600710f8813ee27eea544dd118d45896bb734e9d7a0dc7"}, + {file = "black-24.10.0-py3-none-any.whl", hash = "sha256:3bb2b7a1f7b685f85b11fed1ef10f8a9148bceb49853e47a294a3dd963c1dd7d"}, + {file = "black-24.10.0.tar.gz", hash = "sha256:846ea64c97afe3bc677b761787993be4991810ecc7a4a937816dd6bddedc4875"}, ] [package.dependencies] @@ -198,7 +222,7 @@ typing-extensions = {version = ">=4.0.1", markers = "python_version < \"3.11\""} [package.extras] colorama = ["colorama (>=0.4.3)"] -d = ["aiohttp (>=3.7.4)", "aiohttp (>=3.7.4,!=3.9.0)"] +d = ["aiohttp (>=3.10)"] jupyter = ["ipython (>=7.8.0)", "tokenize-rt (>=3.2.0)"] uvloop = ["uvloop (>=0.15.2)"] @@ -607,13 +631,13 @@ dev = ["PyTest", "PyTest-Cov", "bump2version (<1)", "sphinx (<2)", "tox"] [[package]] name = "dill" -version = "0.3.8" +version = "0.3.9" description = "serialize all of Python" optional = false python-versions = ">=3.8" files = [ - {file = "dill-0.3.8-py3-none-any.whl", hash = "sha256:c36ca9ffb54365bdd2f8eb3eff7d2a21237f8452b57ace88b1ac615b7e815bd7"}, - {file = "dill-0.3.8.tar.gz", hash = "sha256:3ebe3c479ad625c4553aca177444d89b486b1d84982eeacded644afc0cf797ca"}, + {file = "dill-0.3.9-py3-none-any.whl", hash = "sha256:468dff3b89520b474c0397703366b7b95eebe6303f108adf9b19da1f702be87a"}, + {file = "dill-0.3.9.tar.gz", hash = "sha256:81aa267dddf68cbfe8029c42ca9ec6a4ab3b22371d1c450abc54422577b4512c"}, ] [package.extras] @@ -654,13 +678,13 @@ websockets = ["websocket-client (>=1.3.0)"] [[package]] name = "docutils" -version = "0.19" +version = "0.20.1" description = "Docutils -- Python Documentation Utilities" optional = false python-versions = ">=3.7" files = [ - {file = "docutils-0.19-py3-none-any.whl", hash = "sha256:5e1de4d849fee02c63b040a4a3fd567f4ab104defd8a5511fbbc24a8a017efbc"}, - {file = "docutils-0.19.tar.gz", hash = "sha256:33995a6753c30b7f577febfc2c50411fec6aac7f7ffeb7c4cfe5991072dcf9e6"}, + {file = "docutils-0.20.1-py3-none-any.whl", hash = "sha256:96f387a2c5562db4476f09f13bbab2192e764cac08ebbf3a34a95d9b1e4a59d6"}, + {file = "docutils-0.20.1.tar.gz", hash = "sha256:f08a4e276c3a1583a86dce3e34aba3fe04d02bba2dd51ed16106244e8a923e3b"}, ] [[package]] @@ -727,13 +751,13 @@ simplejson = ">=3.16.0" [[package]] name = "exasol-python-extension-common" -version = "0.6.0" +version = "0.7.0" description = "A collection of common utilities for Exasol extensions." optional = false python-versions = "<4.0.0,>=3.10.0" files = [ - {file = "exasol_python_extension_common-0.6.0-py3-none-any.whl", hash = "sha256:434c01936ab67ab00b1fc8f218d2eb90c415a93e9cef9fb9910fdbde6e02bc81"}, - {file = "exasol_python_extension_common-0.6.0.tar.gz", hash = "sha256:c121153f6605601e22ddcd3f9afa9a24cb4f05c1de030c7871a594a419f17575"}, + {file = "exasol_python_extension_common-0.7.0-py3-none-any.whl", hash = "sha256:ee4b77263648ca97716ccb372c2257b61141d5ce35d75b30bda63e788c214801"}, + {file = "exasol_python_extension_common-0.7.0.tar.gz", hash = "sha256:7e6b10dc5593d63a1333e57d8d5b8ceb0f5eec632b8a31740f1a03fbc0c3eabc"}, ] [package.dependencies] @@ -785,32 +809,36 @@ networkx = ">=3.3.0,<4.0.0" [[package]] name = "exasol-toolbox" -version = "0.9.0" -description = "" +version = "0.15.0" +description = "Your one-stop solution for managing all standard tasks and core workflows of your Python project." optional = false python-versions = "<4.0,>=3.8" files = [ - {file = "exasol_toolbox-0.9.0-py3-none-any.whl", hash = "sha256:9f7043f0f564afbc8b1b04e957e2fb0669e90d7cabce096438ae22e154b54945"}, - {file = "exasol_toolbox-0.9.0.tar.gz", hash = "sha256:775b1a6926ec024d77cb2d4ca6e0627b7d05ecc9189bcddc91429645fedcdc84"}, + {file = "exasol_toolbox-0.15.0-py3-none-any.whl", hash = "sha256:26d0475a53b868a568ca3b58c50bc2776867d2c6155cca14aae75fac4c7efcfa"}, + {file = "exasol_toolbox-0.15.0.tar.gz", hash = "sha256:14260470633abadb6e4bd3aed49250bfcdef4f14cd09b5878dd42d43770b8c78"}, ] [package.dependencies] -black = ">=23.1.0,<24.0.0" +bandit = {version = ">=1.7.9,<2.0.0", extras = ["toml"]} +black = ">=24.1.0" coverage = ">=6.4.4,<8.0.0" -furo = ">=2022.9.15,<2023.0.0" +furo = ">=2022.9.15" importlib-resources = ">=5.12.0" isort = ">=5.12.0,<6.0.0" mypy = ">=0.971" -myst-parser = ">=2.0.0,<3.0.0" -nox = ">=2022.8.7,<2023.0.0" +myst-parser = ">=2.0.0,<4" +nox = ">=2022.8.7" pluggy = ">=1.5.0,<2.0.0" -pre-commit = ">=3.1.1,<4.0.0" -prysk = {version = ">=0.17.0,<0.18.0", extras = ["pytest-plugin"]} +pre-commit = ">=3.1.1,<4" +prysk = {version = ">0.17.0,<1", extras = ["pytest-plugin"]} pylint = ">=2.15.4" -pytest = ">=7.2.2,<8.0.0" +pytest = ">=7.2.2,<9" pyupgrade = ">=2.38.2,<4.0.0" -sphinx = ">=5.3,<7.0" +shibuya = ">=2024.5.14" +sphinx = ">=5.3,<8" sphinx-copybutton = ">=0.5.0,<0.6.0" +sphinx-design = ">=0.5.0,<1" +sphinx-inline-tabs = ">=2023.4.21,<2024.0.0" typer = {version = ">=0.7.0", extras = ["all"]} [[package]] @@ -865,20 +893,20 @@ typing = ["typing-extensions (>=4.12.2)"] [[package]] name = "furo" -version = "2022.12.7" +version = "2024.8.6" description = "A clean customisable Sphinx documentation theme." optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "furo-2022.12.7-py3-none-any.whl", hash = "sha256:7cb76c12a25ef65db85ab0743df907573d03027a33631f17d267e598ebb191f7"}, - {file = "furo-2022.12.7.tar.gz", hash = "sha256:d8008f8efbe7587a97ba533c8b2df1f9c21ee9b3e5cad0d27f61193d38b1a986"}, + {file = "furo-2024.8.6-py3-none-any.whl", hash = "sha256:6cd97c58b47813d3619e63e9081169880fbe331f0ca883c871ff1f3f11814f5c"}, + {file = "furo-2024.8.6.tar.gz", hash = "sha256:b63e4cee8abfc3136d3bc03a3d45a76a850bada4d6374d24c1716b0e01394a01"}, ] [package.dependencies] beautifulsoup4 = "*" pygments = ">=2.7" -sphinx = ">=5.0,<7.0" -sphinx-basic-ng = "*" +sphinx = ">=6.0,<9.0" +sphinx-basic-ng = ">=1.0.0.beta2" [[package]] name = "gitdb" @@ -925,13 +953,13 @@ files = [ [[package]] name = "httpcore" -version = "1.0.5" +version = "1.0.6" description = "A minimal low-level HTTP client." optional = false python-versions = ">=3.8" files = [ - {file = "httpcore-1.0.5-py3-none-any.whl", hash = "sha256:421f18bac248b25d310f3cacd198d55b8e6125c107797b609ff9b7a6ba7991b5"}, - {file = "httpcore-1.0.5.tar.gz", hash = "sha256:34a38e2f9291467ee3b44e89dd52615370e152954ba21721378a87b2960f7a61"}, + {file = "httpcore-1.0.6-py3-none-any.whl", hash = "sha256:27b59625743b85577a8c0e10e55b50b5368a4f2cfe8cc7bcfa9cf00829c2682f"}, + {file = "httpcore-1.0.6.tar.gz", hash = "sha256:73f6dbd6eb8c21bbf7ef8efad555481853f5f6acdeaff1edb0694289269ee17f"}, ] [package.dependencies] @@ -942,7 +970,7 @@ h11 = ">=0.13,<0.15" asyncio = ["anyio (>=4.0,<5.0)"] http2 = ["h2 (>=3,<5)"] socks = ["socksio (==1.*)"] -trio = ["trio (>=0.22.0,<0.26.0)"] +trio = ["trio (>=0.22.0,<1.0)"] [[package]] name = "httpx" @@ -1213,71 +1241,72 @@ testing = ["coverage", "pytest", "pytest-cov", "pytest-regressions"] [[package]] name = "markupsafe" -version = "2.1.5" +version = "3.0.0" description = "Safely add untrusted strings to HTML/XML markup." optional = false -python-versions = ">=3.7" +python-versions = ">=3.9" files = [ - {file = "MarkupSafe-2.1.5-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:a17a92de5231666cfbe003f0e4b9b3a7ae3afb1ec2845aadc2bacc93ff85febc"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:72b6be590cc35924b02c78ef34b467da4ba07e4e0f0454a2c5907f473fc50ce5"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:e61659ba32cf2cf1481e575d0462554625196a1f2fc06a1c777d3f48e8865d46"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2174c595a0d73a3080ca3257b40096db99799265e1c27cc5a610743acd86d62f"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ae2ad8ae6ebee9d2d94b17fb62763125f3f374c25618198f40cbb8b525411900"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:075202fa5b72c86ad32dc7d0b56024ebdbcf2048c0ba09f1cde31bfdd57bcfff"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:598e3276b64aff0e7b3451b72e94fa3c238d452e7ddcd893c3ab324717456bad"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:fce659a462a1be54d2ffcacea5e3ba2d74daa74f30f5f143fe0c58636e355fdd"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-win32.whl", hash = "sha256:d9fad5155d72433c921b782e58892377c44bd6252b5af2f67f16b194987338a4"}, - {file = "MarkupSafe-2.1.5-cp310-cp310-win_amd64.whl", hash = "sha256:bf50cd79a75d181c9181df03572cdce0fbb75cc353bc350712073108cba98de5"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:629ddd2ca402ae6dbedfceeba9c46d5f7b2a61d9749597d4307f943ef198fc1f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:5b7b716f97b52c5a14bffdf688f971b2d5ef4029127f1ad7a513973cfd818df2"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:6ec585f69cec0aa07d945b20805be741395e28ac1627333b1c5b0105962ffced"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b91c037585eba9095565a3556f611e3cbfaa42ca1e865f7b8015fe5c7336d5a5"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:7502934a33b54030eaf1194c21c692a534196063db72176b0c4028e140f8f32c"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:0e397ac966fdf721b2c528cf028494e86172b4feba51d65f81ffd65c63798f3f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:c061bb86a71b42465156a3ee7bd58c8c2ceacdbeb95d05a99893e08b8467359a"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:3a57fdd7ce31c7ff06cdfbf31dafa96cc533c21e443d57f5b1ecc6cdc668ec7f"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-win32.whl", hash = "sha256:397081c1a0bfb5124355710fe79478cdbeb39626492b15d399526ae53422b906"}, - {file = "MarkupSafe-2.1.5-cp311-cp311-win_amd64.whl", hash = "sha256:2b7c57a4dfc4f16f7142221afe5ba4e093e09e728ca65c51f5620c9aaeb9a617"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-macosx_10_9_universal2.whl", hash = "sha256:8dec4936e9c3100156f8a2dc89c4b88d5c435175ff03413b443469c7c8c5f4d1"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:3c6b973f22eb18a789b1460b4b91bf04ae3f0c4234a0a6aa6b0a92f6f7b951d4"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:ac07bad82163452a6884fe8fa0963fb98c2346ba78d779ec06bd7a6262132aee"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f5dfb42c4604dddc8e4305050aa6deb084540643ed5804d7455b5df8fe16f5e5"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ea3d8a3d18833cf4304cd2fc9cbb1efe188ca9b5efef2bdac7adc20594a0e46b"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:d050b3361367a06d752db6ead6e7edeb0009be66bc3bae0ee9d97fb326badc2a"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:bec0a414d016ac1a18862a519e54b2fd0fc8bbfd6890376898a6c0891dd82e9f"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:58c98fee265677f63a4385256a6d7683ab1832f3ddd1e66fe948d5880c21a169"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-win32.whl", hash = "sha256:8590b4ae07a35970728874632fed7bd57b26b0102df2d2b233b6d9d82f6c62ad"}, - {file = "MarkupSafe-2.1.5-cp312-cp312-win_amd64.whl", hash = "sha256:823b65d8706e32ad2df51ed89496147a42a2a6e01c13cfb6ffb8b1e92bc910bb"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:c8b29db45f8fe46ad280a7294f5c3ec36dbac9491f2d1c17345be8e69cc5928f"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:ec6a563cff360b50eed26f13adc43e61bc0c04d94b8be985e6fb24b81f6dcfdf"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a549b9c31bec33820e885335b451286e2969a2d9e24879f83fe904a5ce59d70a"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4f11aa001c540f62c6166c7726f71f7573b52c68c31f014c25cc7901deea0b52"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_aarch64.whl", hash = "sha256:7b2e5a267c855eea6b4283940daa6e88a285f5f2a67f2220203786dfa59b37e9"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:2d2d793e36e230fd32babe143b04cec8a8b3eb8a3122d2aceb4a371e6b09b8df"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:ce409136744f6521e39fd8e2a24c53fa18ad67aa5bc7c2cf83645cce5b5c4e50"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-win32.whl", hash = "sha256:4096e9de5c6fdf43fb4f04c26fb114f61ef0bf2e5604b6ee3019d51b69e8c371"}, - {file = "MarkupSafe-2.1.5-cp37-cp37m-win_amd64.whl", hash = "sha256:4275d846e41ecefa46e2015117a9f491e57a71ddd59bbead77e904dc02b1bed2"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-macosx_10_9_universal2.whl", hash = "sha256:656f7526c69fac7f600bd1f400991cc282b417d17539a1b228617081106feb4a"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:97cafb1f3cbcd3fd2b6fbfb99ae11cdb14deea0736fc2b0952ee177f2b813a46"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:1f3fbcb7ef1f16e48246f704ab79d79da8a46891e2da03f8783a5b6fa41a9532"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:fa9db3f79de01457b03d4f01b34cf91bc0048eb2c3846ff26f66687c2f6d16ab"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ffee1f21e5ef0d712f9033568f8344d5da8cc2869dbd08d87c84656e6a2d2f68"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:5dedb4db619ba5a2787a94d877bc8ffc0566f92a01c0ef214865e54ecc9ee5e0"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:30b600cf0a7ac9234b2638fbc0fb6158ba5bdcdf46aeb631ead21248b9affbc4"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:8dd717634f5a044f860435c1d8c16a270ddf0ef8588d4887037c5028b859b0c3"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-win32.whl", hash = "sha256:daa4ee5a243f0f20d528d939d06670a298dd39b1ad5f8a72a4275124a7819eff"}, - {file = "MarkupSafe-2.1.5-cp38-cp38-win_amd64.whl", hash = "sha256:619bc166c4f2de5caa5a633b8b7326fbe98e0ccbfacabd87268a2b15ff73a029"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:7a68b554d356a91cce1236aa7682dc01df0edba8d043fd1ce607c49dd3c1edcf"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:db0b55e0f3cc0be60c1f19efdde9a637c32740486004f20d1cff53c3c0ece4d2"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:3e53af139f8579a6d5f7b76549125f0d94d7e630761a2111bc431fd820e163b8"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:17b950fccb810b3293638215058e432159d2b71005c74371d784862b7e4683f3"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4c31f53cdae6ecfa91a77820e8b151dba54ab528ba65dfd235c80b086d68a465"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:bff1b4290a66b490a2f4719358c0cdcd9bafb6b8f061e45c7a2460866bf50c2e"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:bc1667f8b83f48511b94671e0e441401371dfd0f0a795c7daa4a3cd1dde55bea"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:5049256f536511ee3f7e1b3f87d1d1209d327e818e6ae1365e8653d7e3abb6a6"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-win32.whl", hash = "sha256:00e046b6dd71aa03a41079792f8473dc494d564611a8f89bbbd7cb93295ebdcf"}, - {file = "MarkupSafe-2.1.5-cp39-cp39-win_amd64.whl", hash = "sha256:fa173ec60341d6bb97a89f5ea19c85c5643c1e7dedebc22f5181eb73573142c5"}, - {file = "MarkupSafe-2.1.5.tar.gz", hash = "sha256:d283d37a890ba4c1ae73ffadf8046435c76e7bc2247bbb63c00bd1a709c6544b"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:380faf314c3c84c1682ca672e6280c6c59e92d0bc13dc71758ffa2de3cd4e252"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:1ee9790be6f62121c4c58bbced387b0965ab7bffeecb4e17cc42ef290784e363"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:5ddf5cb8e9c00d9bf8b0c75949fb3ff9ea2096ba531693e2e87336d197fdb908"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:9b36473a2d3e882d1873ea906ce54408b9588dc2c65989664e6e7f5a2de353d7"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:dba0f83119b9514bc37272ad012f0cc03f0805cc6a2bea7244e19250ac8ff29f"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_aarch64.whl", hash = "sha256:409535e0521c4630d5b5a1bf284e9d3c76d2fc2f153ebb12cf3827797798cc99"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_i686.whl", hash = "sha256:64a7c7856c3a409011139b17d137c2924df4318dab91ee0530800819617c4381"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-musllinux_1_2_x86_64.whl", hash = "sha256:4deea1d9169578917d1f35cdb581bc7bab56a7e8c5be2633bd1b9549c3c22a01"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-win32.whl", hash = "sha256:3cd0bba31d484fe9b9d77698ddb67c978704603dc10cdc905512af308cfcca6b"}, + {file = "MarkupSafe-3.0.0-cp310-cp310-win_amd64.whl", hash = "sha256:4ca04c60006867610a06575b46941ae616b19da0adc85b9f8f3d9cbd7a3da385"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:e64b390a306f9e849ee809f92af6a52cda41741c914358e0e9f8499d03741526"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:7c524203207f5b569df06c96dafdc337228921ee8c3cc5f6e891d024c6595352"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c409691696bec2b5e5c9efd9593c99025bf2f317380bf0d993ee0213516d908a"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:64f7d04410be600aa5ec0626d73d43e68a51c86500ce12917e10fd013e258df5"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:105ada43a61af22acb8774514c51900dc820c481cc5ba53f17c09d294d9c07ca"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_aarch64.whl", hash = "sha256:a5fd5500d4e4f7cc88d8c0f2e45126c4307ed31e08f8ec521474f2fd99d35ac3"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_i686.whl", hash = "sha256:25396abd52b16900932e05b7104bcdc640a4d96c914f39c3b984e5a17b01fba0"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-musllinux_1_2_x86_64.whl", hash = "sha256:3efde9a8c56c3b6e5f3fa4baea828f8184970c7c78480fedb620d804b1c31e5c"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-win32.whl", hash = "sha256:12ddac720b8965332d36196f6f83477c6351ba6a25d4aff91e30708c729350d7"}, + {file = "MarkupSafe-3.0.0-cp311-cp311-win_amd64.whl", hash = "sha256:658fdf6022740896c403d45148bf0c36978c6b48c9ef8b1f8d0c7a11b6cdea86"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-macosx_10_13_universal2.whl", hash = "sha256:d261ec38b8a99a39b62e0119ed47fe3b62f7691c500bc1e815265adc016438c1"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:e363440c8534bf2f2ef1b8fdc02037eb5fff8fce2a558519b22d6a3a38b3ec5e"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:7835de4c56066e096407a1852e5561f6033786dd987fa90dc384e45b9bd21295"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b6cc46a27d904c9be5732029769acf4b0af69345172ed1ef6d4db0c023ff603b"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:f0411641d31aa6f7f0cc13f0f18b63b8dc08da5f3a7505972a42ab059f479ba3"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_aarch64.whl", hash = "sha256:b2a7afd24d408b907672015555bc10be2382e6c5f62a488e2d452da670bbd389"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_i686.whl", hash = "sha256:c8ab7efeff1884c5da8e18f743b667215300e09043820d11723718de0b7db934"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-musllinux_1_2_x86_64.whl", hash = "sha256:8219e2207f6c188d15614ea043636c2b36d2d79bf853639c124a179412325a13"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-win32.whl", hash = "sha256:59420b5a9a5d3fee483a32adb56d7369ae0d630798da056001be1e9f674f3aa6"}, + {file = "MarkupSafe-3.0.0-cp312-cp312-win_amd64.whl", hash = "sha256:7ed789d0f7f11fcf118cf0acb378743dfdd4215d7f7d18837c88171405c9a452"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-macosx_10_13_universal2.whl", hash = "sha256:27d6a73682b99568916c54a4bfced40e7d871ba685b580ea04bbd2e405dfd4c5"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:494a64efc535e147fcc713dba58eecfce3a79f1e93ebe81995b387f5cd9bc2e1"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c5243044a927e8a6bb28517838662a019cd7f73d7f106bbb37ab5e7fa8451a92"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:63dae84964a9a3d2610808cee038f435d9a111620c37ccf872c2fcaeca6865b3"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:dcbee57fedc9b2182c54ffc1c5eed316c3da8bbfeda8009e1b5d7220199d15da"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_aarch64.whl", hash = "sha256:f846fd7c241e5bd4161e2a483663eb66e4d8e12130fcdc052f310f388f1d61c6"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_i686.whl", hash = "sha256:678fbceb202382aae42c1f0cd9f56b776bc20a58ae5b553ee1fe6b802983a1d6"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-musllinux_1_2_x86_64.whl", hash = "sha256:bd9b8e458e2bab52f9ad3ab5dc8b689a3c84b12b2a2f64cd9a0dfe209fb6b42f"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-win32.whl", hash = "sha256:1fd02f47596e00a372f5b4af2b4c45f528bade65c66dfcbc6e1ea1bfda758e98"}, + {file = "MarkupSafe-3.0.0-cp313-cp313-win_amd64.whl", hash = "sha256:b94bec9eda10111ec7102ef909eca4f3c2df979643924bfe58375f560713a7d1"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-macosx_10_13_universal2.whl", hash = "sha256:509c424069dd037d078925b6815fc56b7271f3aaec471e55e6fa513b0a80d2aa"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-macosx_11_0_arm64.whl", hash = "sha256:81be2c0084d8c69e97e3c5d73ce9e2a6e523556f2a19c4e195c09d499be2f808"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b43ac1eb9f91e0c14aac1d2ef0f76bc7b9ceea51de47536f61268191adf52ad7"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:3b231255770723f1e125d63c14269bcd8b8136ecfb620b9a18c0297e046d0736"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:c182d45600556917f811aa019d834a89fe4b6f6255da2fd0bdcf80e970f95918"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_aarch64.whl", hash = "sha256:9f91c90f8f3bf436f81c12eeb4d79f9ddd263c71125e6ad71341906832a34386"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_i686.whl", hash = "sha256:a7171d2b869e9be238ea318c196baf58fbf272704e9c1cd4be8c380eea963342"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-musllinux_1_2_x86_64.whl", hash = "sha256:cb244adf2499aa37d5dc43431990c7f0b632d841af66a51d22bd89c437b60264"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-win32.whl", hash = "sha256:96e3ed550600185d34429477f1176cedea8293fa40e47fe37a05751bcb64c997"}, + {file = "MarkupSafe-3.0.0-cp313-cp313t-win_amd64.whl", hash = "sha256:1d151b9cf3307e259b749125a5a08c030ba15a8f1d567ca5bfb0e92f35e761f5"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:23efb2be7221105c8eb0e905433414d2439cb0a8c5d5ca081c1c72acef0f5613"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:81ee9c967956b9ea39b3a5270b7cb1740928d205b0dc72629164ce621b4debf9"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:5509a8373fed30b978557890a226c3d30569746c565b9daba69df80c160365a5"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f1c13c6c908811f867a8e9e66efb2d6c03d1cdd83e92788fe97f693c457dc44f"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:d7e63d1977d3806ce0a1a3e0099b089f61abdede5238ca6a3f3bf8877b46d095"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_aarch64.whl", hash = "sha256:d2c099be5274847d606574234e494f23a359e829ba337ea9037c3a72b0851942"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_i686.whl", hash = "sha256:e042ccf8fe5bf8b6a4b38b3f7d618eb10ea20402b0c9f4add9293408de447974"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-musllinux_1_2_x86_64.whl", hash = "sha256:98fb3a2bf525ad66db96745707b93ba0f78928b7a1cb2f1cb4b143bc7e2ba3b3"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-win32.whl", hash = "sha256:a80c6740e1bfbe50cea7cbf74f48823bb57bd59d914ee22ff8a81963b08e62d2"}, + {file = "MarkupSafe-3.0.0-cp39-cp39-win_amd64.whl", hash = "sha256:5d207ff5cceef77796f8aacd44263266248cf1fbc601441524d7835613f8abec"}, + {file = "markupsafe-3.0.0.tar.gz", hash = "sha256:03ff62dea2fef3eadf2f1853bc6332bcb0458d9608b11dfb1cd5aeda1c178ea6"}, ] [[package]] @@ -1381,17 +1410,17 @@ files = [ [[package]] name = "myst-parser" -version = "2.0.0" +version = "3.0.1" description = "An extended [CommonMark](https://spec.commonmark.org/) compliant parser," optional = false python-versions = ">=3.8" files = [ - {file = "myst_parser-2.0.0-py3-none-any.whl", hash = "sha256:7c36344ae39c8e740dad7fdabf5aa6fc4897a813083c6cc9990044eb93656b14"}, - {file = "myst_parser-2.0.0.tar.gz", hash = "sha256:ea929a67a6a0b1683cdbe19b8d2e724cd7643f8aa3e7bb18dd65beac3483bead"}, + {file = "myst_parser-3.0.1-py3-none-any.whl", hash = "sha256:6457aaa33a5d474aca678b8ead9b3dc298e89c68e67012e73146ea6fd54babf1"}, + {file = "myst_parser-3.0.1.tar.gz", hash = "sha256:88f0cb406cb363b077d176b51c476f62d60604d68a8dcdf4832e080441301a87"}, ] [package.dependencies] -docutils = ">=0.16,<0.21" +docutils = ">=0.18,<0.22" jinja2 = "*" markdown-it-py = ">=3.0,<4.0" mdit-py-plugins = ">=0.4,<1.0" @@ -1401,9 +1430,9 @@ sphinx = ">=6,<8" [package.extras] code-style = ["pre-commit (>=3.0,<4.0)"] linkify = ["linkify-it-py (>=2.0,<3.0)"] -rtd = ["ipython", "pydata-sphinx-theme (==v0.13.0rc4)", "sphinx-autodoc2 (>=0.4.2,<0.5.0)", "sphinx-book-theme (==1.0.0rc2)", "sphinx-copybutton", "sphinx-design2", "sphinx-pyscript", "sphinx-tippy (>=0.3.1)", "sphinx-togglebutton", "sphinxext-opengraph (>=0.8.2,<0.9.0)", "sphinxext-rediraffe (>=0.2.7,<0.3.0)"] -testing = ["beautifulsoup4", "coverage[toml]", "pytest (>=7,<8)", "pytest-cov", "pytest-param-files (>=0.3.4,<0.4.0)", "pytest-regressions", "sphinx-pytest"] -testing-docutils = ["pygments", "pytest (>=7,<8)", "pytest-param-files (>=0.3.4,<0.4.0)"] +rtd = ["ipython", "sphinx (>=7)", "sphinx-autodoc2 (>=0.5.0,<0.6.0)", "sphinx-book-theme (>=1.1,<2.0)", "sphinx-copybutton", "sphinx-design", "sphinx-pyscript", "sphinx-tippy (>=0.4.3)", "sphinx-togglebutton", "sphinxext-opengraph (>=0.9.0,<0.10.0)", "sphinxext-rediraffe (>=0.2.7,<0.3.0)"] +testing = ["beautifulsoup4", "coverage[toml]", "defusedxml", "pytest (>=8,<9)", "pytest-cov", "pytest-param-files (>=0.6.0,<0.7.0)", "pytest-regressions", "sphinx-pytest"] +testing-docutils = ["pygments", "pytest (>=8,<9)", "pytest-param-files (>=0.6.0,<0.7.0)"] [[package]] name = "netaddr" @@ -1450,23 +1479,25 @@ files = [ [[package]] name = "nox" -version = "2022.11.21" +version = "2024.4.15" description = "Flexible test automation." optional = false python-versions = ">=3.7" files = [ - {file = "nox-2022.11.21-py3-none-any.whl", hash = "sha256:0e41a990e290e274cb205a976c4c97ee3c5234441a8132c8c3fd9ea3c22149eb"}, - {file = "nox-2022.11.21.tar.gz", hash = "sha256:e21c31de0711d1274ca585a2c5fde36b1aa962005ba8e9322bf5eeed16dcd684"}, + {file = "nox-2024.4.15-py3-none-any.whl", hash = "sha256:6492236efa15a460ecb98e7b67562a28b70da006ab0be164e8821177577c0565"}, + {file = "nox-2024.4.15.tar.gz", hash = "sha256:ecf6700199cdfa9e5ea0a41ff5e6ef4641d09508eda6edb89d9987864115817f"}, ] [package.dependencies] -argcomplete = ">=1.9.4,<3.0" +argcomplete = ">=1.9.4,<4.0" colorlog = ">=2.6.1,<7.0.0" packaging = ">=20.9" -virtualenv = ">=14" +tomli = {version = ">=1", markers = "python_version < \"3.11\""} +virtualenv = ">=20.14.1" [package.extras] tox-to-nox = ["jinja2", "tox"] +uv = ["uv (>=0.1.6)"] [[package]] name = "packaging" @@ -1511,6 +1542,17 @@ files = [ {file = "pathspec-0.12.1.tar.gz", hash = "sha256:a482d51503a1ab33b1c67a6c3813a26953dbdc71c31dacaef9a838c4e29f5712"}, ] +[[package]] +name = "pbr" +version = "6.1.0" +description = "Python Build Reasonableness" +optional = false +python-versions = ">=2.6" +files = [ + {file = "pbr-6.1.0-py2.py3-none-any.whl", hash = "sha256:a776ae228892d8013649c0aeccbb3d5f99ee15e005a4cbb7e61d55a067b28a2a"}, + {file = "pbr-6.1.0.tar.gz", hash = "sha256:788183e382e3d1d7707db08978239965e8b9e4e5ed42669bf4758186734d5f24"}, +] + [[package]] name = "platformdirs" version = "4.3.6" @@ -1581,13 +1623,13 @@ virtualenv = ">=20.10.0" [[package]] name = "prysk" -version = "0.17.0" +version = "0.20.0" description = "Functional tests for command line applications" optional = false -python-versions = ">=3.8,<4.0.0" +python-versions = "<4.0.0,>=3.8" files = [ - {file = "prysk-0.17.0-py3-none-any.whl", hash = "sha256:c2e0ce69ede821e5a7e03f576c51e2a35000c570f6e22cf7c13daec1b3978832"}, - {file = "prysk-0.17.0.tar.gz", hash = "sha256:0a500bb9ff742eca878d5802bad9fcfd7ba1c6bbae64b2a2ff96bff94d4f8ad8"}, + {file = "prysk-0.20.0-py3-none-any.whl", hash = "sha256:3758f59febe1ff27710c8ba69a8edad42286050d041ed8df519fc4bbeea41133"}, + {file = "prysk-0.20.0.tar.gz", hash = "sha256:3499d24c9c8d534754d3915218cb2ab59cf59a8d6f37acfb68dc582650e67e33"}, ] [package.dependencies] @@ -1621,13 +1663,13 @@ files = [ [[package]] name = "pydot" -version = "3.0.1" +version = "3.0.2" description = "Python interface to Graphviz's Dot" optional = false python-versions = ">=3.8" files = [ - {file = "pydot-3.0.1-py3-none-any.whl", hash = "sha256:43f1e878dc1ff7c1c2e3470a6999d4e9e97771c5c862440c2f0af0ba844c231f"}, - {file = "pydot-3.0.1.tar.gz", hash = "sha256:e18cf7f287c497d77b536a3d20a46284568fea390776dface6eabbdf1b1b5efc"}, + {file = "pydot-3.0.2-py3-none-any.whl", hash = "sha256:99cedaa55d04abb0b2bc56d9981a6da781053dd5ac75c428e8dd53db53f90b14"}, + {file = "pydot-3.0.2.tar.gz", hash = "sha256:9180da540b51b3aa09fbf81140b3edfbe2315d778e8589a7d0a4a69c41332bae"}, ] [package.dependencies] @@ -1636,7 +1678,7 @@ pyparsing = ">=3.0.9" [package.extras] dev = ["chardet", "parameterized", "ruff"] release = ["zest.releaser[recommended]"] -tests = ["chardet", "parameterized", "ruff", "tox", "unittest-parallel"] +tests = ["chardet", "parameterized", "pytest", "pytest-cov", "pytest-xdist[psutil]", "ruff", "tox"] [[package]] name = "pyexasol" @@ -1897,25 +1939,29 @@ tokenize-rt = ">=5.2.0" [[package]] name = "pywin32" -version = "306" +version = "307" description = "Python for Window Extensions" optional = false python-versions = "*" files = [ - {file = "pywin32-306-cp310-cp310-win32.whl", hash = "sha256:06d3420a5155ba65f0b72f2699b5bacf3109f36acbe8923765c22938a69dfc8d"}, - {file = "pywin32-306-cp310-cp310-win_amd64.whl", hash = "sha256:84f4471dbca1887ea3803d8848a1616429ac94a4a8d05f4bc9c5dcfd42ca99c8"}, - {file = "pywin32-306-cp311-cp311-win32.whl", hash = "sha256:e65028133d15b64d2ed8f06dd9fbc268352478d4f9289e69c190ecd6818b6407"}, - {file = "pywin32-306-cp311-cp311-win_amd64.whl", hash = "sha256:a7639f51c184c0272e93f244eb24dafca9b1855707d94c192d4a0b4c01e1100e"}, - {file = "pywin32-306-cp311-cp311-win_arm64.whl", hash = "sha256:70dba0c913d19f942a2db25217d9a1b726c278f483a919f1abfed79c9cf64d3a"}, - {file = "pywin32-306-cp312-cp312-win32.whl", hash = "sha256:383229d515657f4e3ed1343da8be101000562bf514591ff383ae940cad65458b"}, - {file = "pywin32-306-cp312-cp312-win_amd64.whl", hash = "sha256:37257794c1ad39ee9be652da0462dc2e394c8159dfd913a8a4e8eb6fd346da0e"}, - {file = "pywin32-306-cp312-cp312-win_arm64.whl", hash = "sha256:5821ec52f6d321aa59e2db7e0a35b997de60c201943557d108af9d4ae1ec7040"}, - {file = "pywin32-306-cp37-cp37m-win32.whl", hash = "sha256:1c73ea9a0d2283d889001998059f5eaaba3b6238f767c9cf2833b13e6a685f65"}, - {file = "pywin32-306-cp37-cp37m-win_amd64.whl", hash = "sha256:72c5f621542d7bdd4fdb716227be0dd3f8565c11b280be6315b06ace35487d36"}, - {file = "pywin32-306-cp38-cp38-win32.whl", hash = "sha256:e4c092e2589b5cf0d365849e73e02c391c1349958c5ac3e9d5ccb9a28e017b3a"}, - {file = "pywin32-306-cp38-cp38-win_amd64.whl", hash = "sha256:e8ac1ae3601bee6ca9f7cb4b5363bf1c0badb935ef243c4733ff9a393b1690c0"}, - {file = "pywin32-306-cp39-cp39-win32.whl", hash = "sha256:e25fd5b485b55ac9c057f67d94bc203f3f6595078d1fb3b458c9c28b7153a802"}, - {file = "pywin32-306-cp39-cp39-win_amd64.whl", hash = "sha256:39b61c15272833b5c329a2989999dcae836b1eed650252ab1b7bfbe1d59f30f4"}, + {file = "pywin32-307-cp310-cp310-win32.whl", hash = "sha256:f8f25d893c1e1ce2d685ef6d0a481e87c6f510d0f3f117932781f412e0eba31b"}, + {file = "pywin32-307-cp310-cp310-win_amd64.whl", hash = "sha256:36e650c5e5e6b29b5d317385b02d20803ddbac5d1031e1f88d20d76676dd103d"}, + {file = "pywin32-307-cp310-cp310-win_arm64.whl", hash = "sha256:0c12d61e0274e0c62acee79e3e503c312426ddd0e8d4899c626cddc1cafe0ff4"}, + {file = "pywin32-307-cp311-cp311-win32.whl", hash = "sha256:fec5d27cc893178fab299de911b8e4d12c5954e1baf83e8a664311e56a272b75"}, + {file = "pywin32-307-cp311-cp311-win_amd64.whl", hash = "sha256:987a86971753ed7fdd52a7fb5747aba955b2c7fbbc3d8b76ec850358c1cc28c3"}, + {file = "pywin32-307-cp311-cp311-win_arm64.whl", hash = "sha256:fd436897c186a2e693cd0437386ed79f989f4d13d6f353f8787ecbb0ae719398"}, + {file = "pywin32-307-cp312-cp312-win32.whl", hash = "sha256:07649ec6b01712f36debf39fc94f3d696a46579e852f60157a729ac039df0815"}, + {file = "pywin32-307-cp312-cp312-win_amd64.whl", hash = "sha256:00d047992bb5dcf79f8b9b7c81f72e0130f9fe4b22df613f755ab1cc021d8347"}, + {file = "pywin32-307-cp312-cp312-win_arm64.whl", hash = "sha256:b53658acbfc6a8241d72cc09e9d1d666be4e6c99376bc59e26cdb6223c4554d2"}, + {file = "pywin32-307-cp313-cp313-win32.whl", hash = "sha256:ea4d56e48dc1ab2aa0a5e3c0741ad6e926529510516db7a3b6981a1ae74405e5"}, + {file = "pywin32-307-cp313-cp313-win_amd64.whl", hash = "sha256:576d09813eaf4c8168d0bfd66fb7cb3b15a61041cf41598c2db4a4583bf832d2"}, + {file = "pywin32-307-cp313-cp313-win_arm64.whl", hash = "sha256:b30c9bdbffda6a260beb2919f918daced23d32c79109412c2085cbc513338a0a"}, + {file = "pywin32-307-cp37-cp37m-win32.whl", hash = "sha256:5101472f5180c647d4525a0ed289ec723a26231550dbfd369ec19d5faf60e511"}, + {file = "pywin32-307-cp37-cp37m-win_amd64.whl", hash = "sha256:05de55a7c110478dc4b202230e98af5e0720855360d2b31a44bb4e296d795fba"}, + {file = "pywin32-307-cp38-cp38-win32.whl", hash = "sha256:13d059fb7f10792542082f5731d5d3d9645320fc38814759313e5ee97c3fac01"}, + {file = "pywin32-307-cp38-cp38-win_amd64.whl", hash = "sha256:7e0b2f93769d450a98ac7a31a087e07b126b6d571e8b4386a5762eb85325270b"}, + {file = "pywin32-307-cp39-cp39-win32.whl", hash = "sha256:55ee87f2f8c294e72ad9d4261ca423022310a6e79fb314a8ca76ab3f493854c6"}, + {file = "pywin32-307-cp39-cp39-win_amd64.whl", hash = "sha256:e9d5202922e74985b037c9ef46778335c102b74b95cec70f629453dbe7235d87"}, ] [[package]] @@ -2003,18 +2049,19 @@ use-chardet-on-py3 = ["chardet (>=3.0.2,<6)"] [[package]] name = "rich" -version = "13.8.1" +version = "13.9.2" description = "Render rich text, tables, progress bars, syntax highlighting, markdown and more to the terminal" optional = false -python-versions = ">=3.7.0" +python-versions = ">=3.8.0" files = [ - {file = "rich-13.8.1-py3-none-any.whl", hash = "sha256:1760a3c0848469b97b558fc61c85233e3dafb69c7a071b4d60c38099d3cd4c06"}, - {file = "rich-13.8.1.tar.gz", hash = "sha256:8260cda28e3db6bf04d2d1ef4dbc03ba80a824c88b0e7668a0f23126a424844a"}, + {file = "rich-13.9.2-py3-none-any.whl", hash = "sha256:8c82a3d3f8dcfe9e734771313e606b39d8247bb6b826e196f4914b333b743cf1"}, + {file = "rich-13.9.2.tar.gz", hash = "sha256:51a2c62057461aaf7152b4d611168f93a9fc73068f8ded2790f29fe2b5366d0c"}, ] [package.dependencies] markdown-it-py = ">=2.2.0" pygments = ">=2.13.0,<3.0.0" +typing-extensions = {version = ">=4.0.0,<5.0", markers = "python_version < \"3.11\""} [package.extras] jupyter = ["ipywidgets (>=7.5.1,<9)"] @@ -2064,6 +2111,20 @@ files = [ {file = "shellingham-1.5.4.tar.gz", hash = "sha256:8dbca0739d487e5bd35ab3ca4b36e11c4078f3a234bfce294b0a0291363404de"}, ] +[[package]] +name = "shibuya" +version = "2024.8.30" +description = "A clean, responsive, and customizable Sphinx documentation theme with light/dark mode." +optional = false +python-versions = ">=3.7" +files = [ + {file = "shibuya-2024.8.30-py3-none-any.whl", hash = "sha256:c5b865132babcddc4ed600b36a6d05ecc869979f358d9796268927e1eb7ef619"}, + {file = "shibuya-2024.8.30.tar.gz", hash = "sha256:0fdc75643ee40d00fb9a0f1f26ce1085e88df8e48b525a228fe202ffdf31883d"}, +] + +[package.dependencies] +Sphinx = "*" + [[package]] name = "simplejson" version = "3.19.3" @@ -2240,37 +2301,38 @@ files = [ [[package]] name = "sphinx" -version = "6.2.1" +version = "7.4.7" description = "Python documentation generator" optional = false -python-versions = ">=3.8" +python-versions = ">=3.9" files = [ - {file = "Sphinx-6.2.1.tar.gz", hash = "sha256:6d56a34697bb749ffa0152feafc4b19836c755d90a7c59b72bc7dfd371b9cc6b"}, - {file = "sphinx-6.2.1-py3-none-any.whl", hash = "sha256:97787ff1fa3256a3eef9eda523a63dbf299f7b47e053cfcf684a1c2a8380c912"}, + {file = "sphinx-7.4.7-py3-none-any.whl", hash = "sha256:c2419e2135d11f1951cd994d6eb18a1835bd8fdd8429f9ca375dc1f3281bd239"}, + {file = "sphinx-7.4.7.tar.gz", hash = "sha256:242f92a7ea7e6c5b406fdc2615413890ba9f699114a9c09192d7dfead2ee9cfe"}, ] [package.dependencies] -alabaster = ">=0.7,<0.8" -babel = ">=2.9" -colorama = {version = ">=0.4.5", markers = "sys_platform == \"win32\""} -docutils = ">=0.18.1,<0.20" +alabaster = ">=0.7.14,<0.8.0" +babel = ">=2.13" +colorama = {version = ">=0.4.6", markers = "sys_platform == \"win32\""} +docutils = ">=0.20,<0.22" imagesize = ">=1.3" -Jinja2 = ">=3.0" -packaging = ">=21.0" -Pygments = ">=2.13" -requests = ">=2.25.0" -snowballstemmer = ">=2.0" +Jinja2 = ">=3.1" +packaging = ">=23.0" +Pygments = ">=2.17" +requests = ">=2.30.0" +snowballstemmer = ">=2.2" sphinxcontrib-applehelp = "*" sphinxcontrib-devhelp = "*" sphinxcontrib-htmlhelp = ">=2.0.0" sphinxcontrib-jsmath = "*" sphinxcontrib-qthelp = "*" -sphinxcontrib-serializinghtml = ">=1.1.5" +sphinxcontrib-serializinghtml = ">=1.1.9" +tomli = {version = ">=2", markers = "python_version < \"3.11\""} [package.extras] 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)"] +lint = ["flake8 (>=6.0)", "importlib-metadata (>=6.0)", "mypy (==1.10.1)", "pytest (>=6.0)", "ruff (==0.5.2)", "sphinx-lint (>=0.9)", "tomli (>=2)", "types-docutils (==0.21.0.20240711)", "types-requests (>=2.30.0)"] +test = ["cython (>=3.0)", "defusedxml (>=0.7.1)", "pytest (>=8.0)", "setuptools (>=70.0)", "typing_extensions (>=4.9)"] [[package]] name = "sphinx-basic-ng" @@ -2307,6 +2369,49 @@ sphinx = ">=1.8" code-style = ["pre-commit (==2.12.1)"] rtd = ["ipython", "myst-nb", "sphinx", "sphinx-book-theme", "sphinx-examples"] +[[package]] +name = "sphinx-design" +version = "0.6.1" +description = "A sphinx extension for designing beautiful, view size responsive web components." +optional = false +python-versions = ">=3.9" +files = [ + {file = "sphinx_design-0.6.1-py3-none-any.whl", hash = "sha256:b11f37db1a802a183d61b159d9a202314d4d2fe29c163437001324fe2f19549c"}, + {file = "sphinx_design-0.6.1.tar.gz", hash = "sha256:b44eea3719386d04d765c1a8257caca2b3e6f8421d7b3a5e742c0fd45f84e632"}, +] + +[package.dependencies] +sphinx = ">=6,<9" + +[package.extras] +code-style = ["pre-commit (>=3,<4)"] +rtd = ["myst-parser (>=2,<4)"] +testing = ["defusedxml", "myst-parser (>=2,<4)", "pytest (>=8.3,<9.0)", "pytest-cov", "pytest-regressions"] +testing-no-myst = ["defusedxml", "pytest (>=8.3,<9.0)", "pytest-cov", "pytest-regressions"] +theme-furo = ["furo (>=2024.7.18,<2024.8.0)"] +theme-im = ["sphinx-immaterial (>=0.12.2,<0.13.0)"] +theme-pydata = ["pydata-sphinx-theme (>=0.15.2,<0.16.0)"] +theme-rtd = ["sphinx-rtd-theme (>=2.0,<3.0)"] +theme-sbt = ["sphinx-book-theme (>=1.1,<2.0)"] + +[[package]] +name = "sphinx-inline-tabs" +version = "2023.4.21" +description = "Add inline tabbed content to your Sphinx documentation." +optional = false +python-versions = ">=3.8" +files = [ + {file = "sphinx_inline_tabs-2023.4.21-py3-none-any.whl", hash = "sha256:06809ac613f7c48ddd6e2fa588413e3fe92cff2397b56e2ccf0b0218f9ef6a78"}, + {file = "sphinx_inline_tabs-2023.4.21.tar.gz", hash = "sha256:5df2f13f602c158f3f5f6c509e008aeada199a8c76d97ba3aa2822206683bebc"}, +] + +[package.dependencies] +sphinx = ">=3" + +[package.extras] +doc = ["furo", "myst-parser"] +test = ["pytest", "pytest-cov", "pytest-xdist"] + [[package]] name = "sphinxcontrib-applehelp" version = "2.0.0" @@ -2401,6 +2506,20 @@ lint = ["mypy", "ruff (==0.5.5)", "types-docutils"] standalone = ["Sphinx (>=5)"] test = ["pytest"] +[[package]] +name = "stevedore" +version = "5.3.0" +description = "Manage dynamic plugins for Python applications" +optional = false +python-versions = ">=3.8" +files = [ + {file = "stevedore-5.3.0-py3-none-any.whl", hash = "sha256:1efd34ca08f474dad08d9b19e934a22c68bb6fe416926479ba29e5013bcc8f78"}, + {file = "stevedore-5.3.0.tar.gz", hash = "sha256:9a64265f4060312828151c204efbe9b7a9852a0d9228756344dbc7e4023e375a"}, +] + +[package.dependencies] +pbr = ">=2.0.0" + [[package]] name = "stopwatch-py" version = "2.0.1" @@ -2440,13 +2559,13 @@ files = [ [[package]] name = "tomli" -version = "2.0.1" +version = "2.0.2" description = "A lil' TOML parser" optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "tomli-2.0.1-py3-none-any.whl", hash = "sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc"}, - {file = "tomli-2.0.1.tar.gz", hash = "sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f"}, + {file = "tomli-2.0.2-py3-none-any.whl", hash = "sha256:2ebe24485c53d303f690b0ec092806a085f07af5a5aa1464f3931eec36caaa38"}, + {file = "tomli-2.0.2.tar.gz", hash = "sha256:d46d457a85337051c36524bc5349dd91b1877838e2979ac5ced3e710ed8a60ed"}, ] [[package]] @@ -2559,13 +2678,13 @@ zstd = ["zstandard (>=0.18.0)"] [[package]] name = "virtualenv" -version = "20.26.5" +version = "20.26.6" description = "Virtual Python Environment builder" optional = false python-versions = ">=3.7" files = [ - {file = "virtualenv-20.26.5-py3-none-any.whl", hash = "sha256:4f3ac17b81fba3ce3bd6f4ead2749a72da5929c01774948e243db9ba41df4ff6"}, - {file = "virtualenv-20.26.5.tar.gz", hash = "sha256:ce489cac131aa58f4b25e321d6d186171f78e6cb13fafbf32a840cee67733ff4"}, + {file = "virtualenv-20.26.6-py3-none-any.whl", hash = "sha256:7345cc5b25405607a624d8418154577459c3e0277f5466dd79c49d5e492995f2"}, + {file = "virtualenv-20.26.6.tar.gz", hash = "sha256:280aede09a2a5c317e409a00102e7077c6432c5a38f0ef938e643805a7ad2c48"}, ] [package.dependencies] @@ -2694,4 +2813,4 @@ type = ["pytest-mypy"] [metadata] lock-version = "2.0" python-versions = ">=3.10,<4" -content-hash = "1382bf796b8cd6d4515c903cb4d948abd32b70db6c26873721cf94ab0815facb" +content-hash = "b8156add3d59c1360dac0303b9efd6dfea456d35a8f1ab0a276266c9d9a686e7" diff --git a/pytest-slc/pyproject.toml b/pytest-slc/pyproject.toml index 6726340..4def898 100644 --- a/pytest-slc/pyproject.toml +++ b/pytest-slc/pyproject.toml @@ -17,8 +17,8 @@ exasol-python-extension-common = ">=0.5.0" slc = "exasol.pytest_slc" [tool.poetry.group.dev.dependencies] -exasol-toolbox = "0.9.0" -exasol-bucketfs = ">=0.12.0" +exasol-toolbox = ">=0.15.0,<1" +exasol-bucketfs = ">=0.13.0,<1" [build-system] requires = ["poetry-core"] From be226980b46afe708cb76ea09eefd00f4a14e83d Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 09:26:54 +0100 Subject: [PATCH 26/48] #61 Enabled SaaS --- justfile | 4 ++-- pytest-extension/test/integration/pytest_extension_test.py | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/justfile b/justfile index c954a39..aeb6534 100644 --- a/justfile +++ b/justfile @@ -17,8 +17,8 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") - run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - # run(f"poetry -C {p}/ run pytest -s {p}/test") + # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") + run(f"poetry -C {p}/ run pytest -s {p}/test") sys.exit(rc) relock +projects=PROJECTS: diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index d3e80a0..a9e0c98 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -1,7 +1,7 @@ from textwrap import dedent import pytest -from exasol.pytest_backend import (BACKEND_OPTION, BACKEND_ALL, BACKEND_ONPREM) +from exasol.pytest_backend import (BACKEND_OPTION, BACKEND_ALL) pytest_plugins = ["pytester"] @@ -103,6 +103,6 @@ def test_bucketfs_cli_args(backend, bucketfs_cli_args): validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) """) pytester.makepyfile(test_code) - result = pytester.runpytest('-s', BACKEND_OPTION, BACKEND_ONPREM) + result = pytester.runpytest('-s', BACKEND_OPTION, BACKEND_ALL) assert result.ret == pytest.ExitCode.OK result.assert_outcomes(passed=6, skipped=6) From e5b282b443537b19a263dad5adc810d65c782b42 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 10:32:05 +0100 Subject: [PATCH 27/48] #61 Enabled all tests. --- justfile | 5 +- pytest-extension/README.md | 50 ++++++++++++++++++- pytest-extension/doc/changes/unreleased.md | 4 ++ .../test/integration/pytest_extension_test.py | 2 +- 4 files changed, 56 insertions(+), 5 deletions(-) diff --git a/justfile b/justfile index aeb6534..9d64519 100644 --- a/justfile +++ b/justfile @@ -1,5 +1,4 @@ -# PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" -PROJECTS := "pytest-extension" +PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" # Default target default: @@ -18,6 +17,8 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") + # Running tests in the nox session for the pytest-extension produces an error without a meaningful explanation. + # It is yet to be investigated. run(f"poetry -C {p}/ run pytest -s {p}/test") sys.exit(rc) diff --git a/pytest-extension/README.md b/pytest-extension/README.md index 61d8665..d7882a9 100644 --- a/pytest-extension/README.md +++ b/pytest-extension/README.md @@ -36,8 +36,54 @@ def test_something_else(bucketfs_connection_factory): ... ``` -The next two fixtures are used to test various deployment scenarios. The first one collects the CLI parameters -required to open a database connection. +The following fixtures are used to test various deployment scenarios where the connection parameters +for the Database and the BucketFS are supplied in a command line. The first two fixtures provide dictionaries +of standard cli parameters (`StdParams`) defined in the `exasol-python-extension-common`. + `database_std_params` - the Database connection parameters. + `bucketfs_std_params` - the BucketFs connection parameters. + +The next two fixtures - `database_cli_args` and `bucketfs_cli_args` - give the same parameters as the previous two +but in the form of command line arguments. They are helpful for testing the CLI directly, for example using the +click.CliRunner as in the samples below. + +```python +import click +from click.testing import CliRunner +from exasol.python_extension_common.cli.std_options import (StdParams, StdTags, select_std_options) +from exasol.pytest_backend import (BACKEND_ONPREM, BACKEND_SAAS) + +def test_db_connection_cli(backend, database_cli_args): + if backend == BACKEND_ONPREM: + tags = StdTags.DB | StdTags.ONPREM + elif backend == BACKEND_SAAS: + tags = StdTags.DB | StdTags.SAAS + else: + ValueError(f'Unknown backend {backend}') + + def test_something_with_db(**kwargs): + pass + + opts = select_std_options(tags) + cmd = click.Command('whatever', params=opts, callback=test_something_with_db) + runner = CliRunner() + runner.invoke(cmd, args=database_cli_args, catch_exceptions=False, standalone_mode=False) + +def test_bucketfs_connection_cli(backend, bucketfs_cli_args): + if backend == BACKEND_ONPREM: + tags = StdTags.BFS | StdTags.ONPREM + elif backend == BACKEND_SAAS: + tags = StdTags.BFS | StdTags.SAAS + else: + ValueError(f'Unknown backend {backend}') + + def test_something_with_bucketfs(**kwargs): + pass + + opts = select_std_options(tags) + cmd = click.Command('whatever', params=opts, callback=test_something_with_bucketfs) + runner = CliRunner() + runner.invoke(cmd, args=bucketfs_cli_args, catch_exceptions=False, standalone_mode=False) +``` Note, that by default the tests will run twice - once for each backend. diff --git a/pytest-extension/doc/changes/unreleased.md b/pytest-extension/doc/changes/unreleased.md index e33b376..0186046 100644 --- a/pytest-extension/doc/changes/unreleased.md +++ b/pytest-extension/doc/changes/unreleased.md @@ -3,3 +3,7 @@ ## Internal * Relock dependencies + +## Features + +* #61 Added CLI parameters. diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index a9e0c98..2367c60 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -105,4 +105,4 @@ def test_bucketfs_cli_args(backend, bucketfs_cli_args): pytester.makepyfile(test_code) result = pytester.runpytest('-s', BACKEND_OPTION, BACKEND_ALL) assert result.ret == pytest.ExitCode.OK - result.assert_outcomes(passed=6, skipped=6) + result.assert_outcomes(passed=12, skipped=0) From c82b07ecdec74b67e9cf20997bae541660d5b793 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 12:33:12 +0100 Subject: [PATCH 28/48] #61 Added cli_args fixture --- .../exasol/pytest_extension/__init__.py | 25 +++++++++++++------ 1 file changed, 18 insertions(+), 7 deletions(-) diff --git a/pytest-extension/exasol/pytest_extension/__init__.py b/pytest-extension/exasol/pytest_extension/__init__.py index 5367300..73131da 100644 --- a/pytest-extension/exasol/pytest_extension/__init__.py +++ b/pytest-extension/exasol/pytest_extension/__init__.py @@ -150,12 +150,17 @@ def bucketfs_std_params(backend, to the BucketFS on either DockerDB or SaaS test database. """ if backend == BACKEND_ONPREM: - return onprem_bucketfs_std_params + bfs_std_params = onprem_bucketfs_std_params elif backend == BACKEND_SAAS: - return saas_std_params + bfs_std_params = saas_std_params else: ValueError(f'Unknown backend {backend}') + # Work around for the bug in PEC (Issue#78 - no default for the StdParams.path_in_bucket) + if StdParams.path_in_bucket.name not in bfs_std_params: + bfs_std_params[StdParams.path_in_bucket.name] = '' + return bfs_std_params + def _cli_params_to_args(cli_params) -> str: def arg_string(k: str, v: Any): @@ -180,8 +185,14 @@ def bucketfs_cli_args(bucketfs_std_params) -> str: """ CLI argument string for testing a command that involves connecting to the BucketFS . """ - cli_args = _cli_params_to_args(bucketfs_std_params) - # Work around for the bug in PEC (Issue#78 - no default for the StdParams.path_in_bucket) - if StdParams.path_in_bucket not in bucketfs_std_params: - cli_args += f' --{StdParams.path_in_bucket.name.replace("_", "-")} ""' - return cli_args + return _cli_params_to_args(bucketfs_std_params) + + +def cli_args(database_std_params, bucketfs_std_params): + """ + CLI argument string for testing a command that involves connecting to both + the database and the BucketFS. + """ + std_params = dict(database_std_params) + std_params.update(bucketfs_std_params) + return _cli_params_to_args(database_std_params) From cb518e67ef7773233f38306910e5ac29abdf4c2e Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 12:35:50 +0100 Subject: [PATCH 29/48] #61 Added cli_args fixture --- pytest-extension/README.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/pytest-extension/README.md b/pytest-extension/README.md index d7882a9..b4fd08c 100644 --- a/pytest-extension/README.md +++ b/pytest-extension/README.md @@ -45,7 +45,8 @@ of standard cli parameters (`StdParams`) defined in the `exasol-python-extension The next two fixtures - `database_cli_args` and `bucketfs_cli_args` - give the same parameters as the previous two but in the form of command line arguments. They are helpful for testing the CLI directly, for example using the -click.CliRunner as in the samples below. +click.CliRunner as in the samples below. There is also a fixture - `cli_args` - that combines these two argument +strings. ```python import click From 7709ad925aac64c954cbce5bd117853b6a2e7199 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 15:25:23 +0100 Subject: [PATCH 30/48] #61 Fixed the tests --- justfile | 3 ++- pytest-extension/exasol/pytest_extension/__init__.py | 10 +++------- .../test/integration/pytest_extension_test.py | 3 +++ 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/justfile b/justfile index 9d64519..5487014 100644 --- a/justfile +++ b/justfile @@ -1,4 +1,5 @@ -PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" +# PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" +PROJECTS := "pytest-extension" # Default target default: diff --git a/pytest-extension/exasol/pytest_extension/__init__.py b/pytest-extension/exasol/pytest_extension/__init__.py index 73131da..4668cc6 100644 --- a/pytest-extension/exasol/pytest_extension/__init__.py +++ b/pytest-extension/exasol/pytest_extension/__init__.py @@ -150,17 +150,12 @@ def bucketfs_std_params(backend, to the BucketFS on either DockerDB or SaaS test database. """ if backend == BACKEND_ONPREM: - bfs_std_params = onprem_bucketfs_std_params + return onprem_bucketfs_std_params elif backend == BACKEND_SAAS: - bfs_std_params = saas_std_params + return saas_std_params else: ValueError(f'Unknown backend {backend}') - # Work around for the bug in PEC (Issue#78 - no default for the StdParams.path_in_bucket) - if StdParams.path_in_bucket.name not in bfs_std_params: - bfs_std_params[StdParams.path_in_bucket.name] = '' - return bfs_std_params - def _cli_params_to_args(cli_params) -> str: def arg_string(k: str, v: Any): @@ -188,6 +183,7 @@ def bucketfs_cli_args(bucketfs_std_params) -> str: return _cli_params_to_args(bucketfs_std_params) +@pytest.fixture(scope='session') def cli_args(database_std_params, bucketfs_std_params): """ CLI argument string for testing a command that involves connecting to both diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 2367c60..2e87958 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -72,6 +72,9 @@ def validate_database_std_params(**kwargs): assert res def validate_bucketfs_std_params(**kwargs): + # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket + if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: + kwargs[StdParams.path_in_bucket.name] = '' bfs_path = create_bucketfs_location(**kwargs) bfs_path = bfs_path / 'test_file.txt' bfs_path.write(TEST_FILE_CONTENT) From 39bdccc6f37345416006fa690eb562a57197843e Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 15:45:15 +0100 Subject: [PATCH 31/48] #61 Enabled all tests again --- justfile | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/justfile b/justfile index 5487014..9d64519 100644 --- a/justfile +++ b/justfile @@ -1,5 +1,4 @@ -# PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" -PROJECTS := "pytest-extension" +PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" # Default target default: From c908cc1a10a774aacb36a791de6644221fe4ecef Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 16:18:02 +0100 Subject: [PATCH 32/48] nox integration_tests --- justfile | 9 ++++----- .../test/integration/pytest_extension_test.py | 4 ++-- 2 files changed, 6 insertions(+), 7 deletions(-) diff --git a/justfile b/justfile index 9d64519..941c87f 100644 --- a/justfile +++ b/justfile @@ -1,4 +1,5 @@ -PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" +# PROJECTS := "pytest-slc pytest-extension pytest-backend pytest-saas pytest-itde" +PROJECTS := "pytest-extension" # Default target default: @@ -16,10 +17,8 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") - # run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s coverage") - # Running tests in the nox session for the pytest-extension produces an error without a meaningful explanation. - # It is yet to be investigated. - run(f"poetry -C {p}/ run pytest -s {p}/test") + run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s integration_tests") + # run(f"poetry -C {p}/ run pytest -s {p}/test") sys.exit(rc) relock +projects=PROJECTS: diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 2e87958..9b3ebfe 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -1,7 +1,7 @@ from textwrap import dedent import pytest -from exasol.pytest_backend import (BACKEND_OPTION, BACKEND_ALL) +from exasol.pytest_backend import (BACKEND_OPTION, BACKEND_ONPREM) pytest_plugins = ["pytester"] @@ -106,6 +106,6 @@ def test_bucketfs_cli_args(backend, bucketfs_cli_args): validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) """) pytester.makepyfile(test_code) - result = pytester.runpytest('-s', BACKEND_OPTION, BACKEND_ALL) + result = pytester.runpytest('-s', BACKEND_OPTION, BACKEND_ONPREM) assert result.ret == pytest.ExitCode.OK result.assert_outcomes(passed=12, skipped=0) From 1a793fb4ab0c00833ae36419f337a504a380a72e Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 16:22:46 +0100 Subject: [PATCH 33/48] nox integration_tests --- justfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/justfile b/justfile index 941c87f..cc48eb7 100644 --- a/justfile +++ b/justfile @@ -17,7 +17,7 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") - run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s integration_tests") + run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s integration-tests") # run(f"poetry -C {p}/ run pytest -s {p}/test") sys.exit(rc) From 33dc5bf10c324fa0844f7a2582430e70a08e9718 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 16:40:37 +0100 Subject: [PATCH 34/48] using the same kwargs as in the first test --- pytest-extension/test/integration/pytest_extension_test.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 9b3ebfe..d2b44c9 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -71,11 +71,15 @@ def validate_database_std_params(**kwargs): res = conn.execute('SELECT SESSION_ID FROM SYS.EXA_ALL_SESSIONS;').fetchall() assert res + bfs_kwargs = None + def validate_bucketfs_std_params(**kwargs): # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: kwargs[StdParams.path_in_bucket.name] = '' - bfs_path = create_bucketfs_location(**kwargs) + if bfs_kwargs is None: + bfs_kwargs = dict(kwargs) + bfs_path = create_bucketfs_location(**bfs_kwargs) bfs_path = bfs_path / 'test_file.txt' bfs_path.write(TEST_FILE_CONTENT) file_content = b"".join(bfs_path.read()) From 4585a32dd85ef9ffa93f6c09dbbf83b9f15a9873 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 16:46:44 +0100 Subject: [PATCH 35/48] using the same kwargs as in the first test --- pytest-extension/test/integration/pytest_extension_test.py | 1 + 1 file changed, 1 insertion(+) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index d2b44c9..399175f 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -74,6 +74,7 @@ def validate_database_std_params(**kwargs): bfs_kwargs = None def validate_bucketfs_std_params(**kwargs): + global bfs_kwargs # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: kwargs[StdParams.path_in_bucket.name] = '' From 32d200d3567606a7dc34950875dd8cb09b0331cb Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 16:57:23 +0100 Subject: [PATCH 36/48] capturing an exception --- .../test/integration/pytest_extension_test.py | 27 +++++++++++-------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 399175f..27a65d0 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -74,17 +74,22 @@ def validate_database_std_params(**kwargs): bfs_kwargs = None def validate_bucketfs_std_params(**kwargs): - global bfs_kwargs - # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket - if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: - kwargs[StdParams.path_in_bucket.name] = '' - if bfs_kwargs is None: - bfs_kwargs = dict(kwargs) - bfs_path = create_bucketfs_location(**bfs_kwargs) - bfs_path = bfs_path / 'test_file.txt' - bfs_path.write(TEST_FILE_CONTENT) - file_content = b"".join(bfs_path.read()) - assert file_content == TEST_FILE_CONTENT + error == '' + try: + global bfs_kwargs + # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket + if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: + kwargs[StdParams.path_in_bucket.name] = '' + if bfs_kwargs is None: + bfs_kwargs = dict(kwargs) + bfs_path = create_bucketfs_location(**bfs_kwargs) + bfs_path = bfs_path / 'test_file.txt' + bfs_path.write(TEST_FILE_CONTENT) + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT + except Exception as ex: + error = str(ex) + assert not error def validate_cli_args(backend, cli_args, base_tag, callback): if backend == BACKEND_ONPREM: From 6b67ea5b76c6886bffd9ee62fd1807c196f52871 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 17:02:02 +0100 Subject: [PATCH 37/48] capturing an exception --- pytest-extension/test/integration/pytest_extension_test.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 27a65d0..05a4edb 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -74,7 +74,7 @@ def validate_database_std_params(**kwargs): bfs_kwargs = None def validate_bucketfs_std_params(**kwargs): - error == '' + error = '' try: global bfs_kwargs # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket From 5736a9f8921ac96909f62a15d61f4e002360c90d Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 17:23:41 +0100 Subject: [PATCH 38/48] capturing an exception --- .../test/integration/pytest_extension_test.py | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 05a4edb..cbd2542 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -71,25 +71,18 @@ def validate_database_std_params(**kwargs): res = conn.execute('SELECT SESSION_ID FROM SYS.EXA_ALL_SESSIONS;').fetchall() assert res - bfs_kwargs = None - def validate_bucketfs_std_params(**kwargs): - error = '' try: - global bfs_kwargs # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: kwargs[StdParams.path_in_bucket.name] = '' - if bfs_kwargs is None: - bfs_kwargs = dict(kwargs) - bfs_path = create_bucketfs_location(**bfs_kwargs) + bfs_path = create_bucketfs_location(**kwargs) bfs_path = bfs_path / 'test_file.txt' bfs_path.write(TEST_FILE_CONTENT) file_content = b"".join(bfs_path.read()) assert file_content == TEST_FILE_CONTENT except Exception as ex: - error = str(ex) - assert not error + pass def validate_cli_args(backend, cli_args, base_tag, callback): if backend == BACKEND_ONPREM: From 31eee9d78442954e8ba6f105a92fa68ce2dcc3b3 Mon Sep 17 00:00:00 2001 From: mibe Date: Tue, 8 Oct 2024 17:30:04 +0100 Subject: [PATCH 39/48] standalone_mode --- pytest-extension/test/integration/pytest_extension_test.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index cbd2542..3b7f7aa 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -94,7 +94,7 @@ def validate_cli_args(backend, cli_args, base_tag, callback): opts = select_std_options(tags) cmd = click.Command('whatever', params=opts, callback=callback) runner = CliRunner() - runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=False) + runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=True) def test_database_std_params(database_std_params): validate_database_std_params(**database_std_params) From a7fac9999178de163ee6343a74d8677927addf3d Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 08:42:27 +0100 Subject: [PATCH 40/48] running with my-integration-tests --- justfile | 2 +- pytest-extension/noxfile.py | 11 ++++++++++ .../test/integration/pytest_extension_test.py | 21 ++++++++----------- 3 files changed, 21 insertions(+), 13 deletions(-) diff --git a/justfile b/justfile index cc48eb7..9c245b5 100644 --- a/justfile +++ b/justfile @@ -17,7 +17,7 @@ test +projects=PROJECTS: for p in "{{projects}}".split(): run(f"poetry -C {p}/ install") - run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s integration-tests") + run(f"poetry -C {p}/ run nox -f {p}/noxfile.py -s my-integration-tests") # run(f"poetry -C {p}/ run pytest -s {p}/test") sys.exit(rc) diff --git a/pytest-extension/noxfile.py b/pytest-extension/noxfile.py index bed354a..e013843 100644 --- a/pytest-extension/noxfile.py +++ b/pytest-extension/noxfile.py @@ -2,6 +2,8 @@ import sys import nox +from nox import Session +from noxconfig import PROJECT_CONFIG print(sys.path) # imports all nox task provided by the toolbox @@ -9,3 +11,12 @@ # default actions to be run if nothing is explicitly specified with the -s option nox.options.sessions = ["fix"] + + +@nox.session(name="my-integration-tests", python=False) +def my_integration_tests(session: Session) -> None: + path = PROJECT_CONFIG.root / "test" / "integration" + base_command = ["poetry", "run"] + pytest_command = ["pytest", "-v", "-s", f"{path}"] + command = base_command + pytest_command + session.run(*command) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 3b7f7aa..9b3ebfe 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -72,17 +72,14 @@ def validate_database_std_params(**kwargs): assert res def validate_bucketfs_std_params(**kwargs): - try: - # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket - if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: - kwargs[StdParams.path_in_bucket.name] = '' - bfs_path = create_bucketfs_location(**kwargs) - bfs_path = bfs_path / 'test_file.txt' - bfs_path.write(TEST_FILE_CONTENT) - file_content = b"".join(bfs_path.read()) - assert file_content == TEST_FILE_CONTENT - except Exception as ex: - pass + # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket + if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: + kwargs[StdParams.path_in_bucket.name] = '' + bfs_path = create_bucketfs_location(**kwargs) + bfs_path = bfs_path / 'test_file.txt' + bfs_path.write(TEST_FILE_CONTENT) + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT def validate_cli_args(backend, cli_args, base_tag, callback): if backend == BACKEND_ONPREM: @@ -94,7 +91,7 @@ def validate_cli_args(backend, cli_args, base_tag, callback): opts = select_std_options(tags) cmd = click.Command('whatever', params=opts, callback=callback) runner = CliRunner() - runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=True) + runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=False) def test_database_std_params(database_std_params): validate_database_std_params(**database_std_params) From 3032086d6734632b02eaf146ac55816f9885db6a Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 08:47:16 +0100 Subject: [PATCH 41/48] running with my-integration-tests --- pytest-extension/noxfile.py | 2 +- pytest-extension/test/integration/pytest_extension_test.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/pytest-extension/noxfile.py b/pytest-extension/noxfile.py index e013843..54f599d 100644 --- a/pytest-extension/noxfile.py +++ b/pytest-extension/noxfile.py @@ -17,6 +17,6 @@ def my_integration_tests(session: Session) -> None: path = PROJECT_CONFIG.root / "test" / "integration" base_command = ["poetry", "run"] - pytest_command = ["pytest", "-v", "-s", f"{path}"] + pytest_command = ["pytest", "-v", f"{path}"] command = base_command + pytest_command session.run(*command) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index 9b3ebfe..de4d3a5 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -108,4 +108,4 @@ def test_bucketfs_cli_args(backend, bucketfs_cli_args): pytester.makepyfile(test_code) result = pytester.runpytest('-s', BACKEND_OPTION, BACKEND_ONPREM) assert result.ret == pytest.ExitCode.OK - result.assert_outcomes(passed=12, skipped=0) + result.assert_outcomes(passed=6, skipped=6) From 654eed6988680264a875eec64e024072b7f1a58a Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 08:57:25 +0100 Subject: [PATCH 42/48] running with my-integration-tests --- pytest-extension/noxfile.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pytest-extension/noxfile.py b/pytest-extension/noxfile.py index 54f599d..e013843 100644 --- a/pytest-extension/noxfile.py +++ b/pytest-extension/noxfile.py @@ -17,6 +17,6 @@ def my_integration_tests(session: Session) -> None: path = PROJECT_CONFIG.root / "test" / "integration" base_command = ["poetry", "run"] - pytest_command = ["pytest", "-v", f"{path}"] + pytest_command = ["pytest", "-v", "-s", f"{path}"] command = base_command + pytest_command session.run(*command) From 32fec6e3cf607ae6f9290d808d1320c76cdd0086 Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 09:51:14 +0100 Subject: [PATCH 43/48] re-ordered the tests --- pytest-extension/noxfile.py | 2 +- .../test/integration/pytest_extension_test.py | 12 ++++++------ 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/pytest-extension/noxfile.py b/pytest-extension/noxfile.py index e013843..54f599d 100644 --- a/pytest-extension/noxfile.py +++ b/pytest-extension/noxfile.py @@ -17,6 +17,6 @@ def my_integration_tests(session: Session) -> None: path = PROJECT_CONFIG.root / "test" / "integration" base_command = ["poetry", "run"] - pytest_command = ["pytest", "-v", "-s", f"{path}"] + pytest_command = ["pytest", "-v", f"{path}"] command = base_command + pytest_command session.run(*command) diff --git a/pytest-extension/test/integration/pytest_extension_test.py b/pytest-extension/test/integration/pytest_extension_test.py index de4d3a5..51102e2 100644 --- a/pytest-extension/test/integration/pytest_extension_test.py +++ b/pytest-extension/test/integration/pytest_extension_test.py @@ -25,6 +25,12 @@ def test_extension_all_backends(pytester): def db_schema_name() -> str: return TEST_SCHEMA + def test_database_cli_args(backend, database_cli_args): + validate_cli_args(backend, database_cli_args, StdTags.DB, validate_database_std_params) + + def test_bucketfs_cli_args(backend, bucketfs_cli_args): + validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) + def test_pyexasol_connection(pyexasol_connection): assert pyexasol_connection.execute(f"SELECT CURRENT_SCHEMA;").fetchval() == TEST_SCHEMA @@ -98,12 +104,6 @@ def test_database_std_params(database_std_params): def test_bucketfs_std_params(bucketfs_std_params): validate_bucketfs_std_params(**bucketfs_std_params, path_in_bucket='test_bucketfs_std_params') - - def test_database_cli_args(backend, database_cli_args): - validate_cli_args(backend, database_cli_args, StdTags.DB, validate_database_std_params) - - def test_bucketfs_cli_args(backend, bucketfs_cli_args): - validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) """) pytester.makepyfile(test_code) result = pytester.runpytest('-s', BACKEND_OPTION, BACKEND_ONPREM) From e276751ec9c0224f9ad9c77e6ca54c339b83b6dc Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 11:15:05 +0100 Subject: [PATCH 44/48] separate test file --- pytest-extension/noxfile.py | 4 +- pytest-extension/test/integration/tmp_test.py | 106 ++++++++++++++++++ 2 files changed, 108 insertions(+), 2 deletions(-) create mode 100644 pytest-extension/test/integration/tmp_test.py diff --git a/pytest-extension/noxfile.py b/pytest-extension/noxfile.py index 54f599d..769a1c3 100644 --- a/pytest-extension/noxfile.py +++ b/pytest-extension/noxfile.py @@ -15,8 +15,8 @@ @nox.session(name="my-integration-tests", python=False) def my_integration_tests(session: Session) -> None: - path = PROJECT_CONFIG.root / "test" / "integration" + path = PROJECT_CONFIG.root / "test" / "integration" / "tmp_test.py" base_command = ["poetry", "run"] - pytest_command = ["pytest", "-v", f"{path}"] + pytest_command = ["pytest", "-v", "--backend=onprem", f"{path}"] command = base_command + pytest_command session.run(*command) diff --git a/pytest-extension/test/integration/tmp_test.py b/pytest-extension/test/integration/tmp_test.py new file mode 100644 index 0000000..cee393f --- /dev/null +++ b/pytest-extension/test/integration/tmp_test.py @@ -0,0 +1,106 @@ +import json +import pytest +import click +from click.testing import CliRunner +import exasol.bucketfs as bfs +from exasol.python_extension_common.connections.pyexasol_connection import open_pyexasol_connection +from exasol.python_extension_common.connections.bucketfs_location import create_bucketfs_location +from exasol.python_extension_common.cli.std_options import (StdParams, StdTags, select_std_options) +from exasol.pytest_backend import (BACKEND_ONPREM, BACKEND_SAAS) + +TEST_SCHEMA = 'PYTEXT_TEST_SCHEMA' +TEST_FILE_CONTENT = b'Gravity Sucks' + + +@pytest.fixture(scope="session") +def db_schema_name() -> str: + return TEST_SCHEMA + + +def test_pyexasol_connection(pyexasol_connection): + assert pyexasol_connection.execute(f"SELECT CURRENT_SCHEMA;").fetchval() == TEST_SCHEMA + + +def test_bucketfs_connection_factory(bucketfs_connection_factory, + pyexasol_connection, + backend_aware_bucketfs_params): + conn_name = 'test_connection' + path_in_bucket = 'test_path' + udf_name = 'EXTRACT_CONNECTION_OBJECT' + + # Write something to the bucket + bfs_path = bfs.path.build_path(**backend_aware_bucketfs_params, path=path_in_bucket) + bfs_path.write(TEST_FILE_CONTENT) + + # Create a connection object + bucketfs_connection_factory(conn_name, path_in_bucket) + + # Extract the content of this connection object + sql = ( + f'CREATE OR REPLACE PYTHON3 SCALAR SCRIPT "{udf_name}"()\n' + 'RETURNS VARCHAR(1024) AS\n' + 'import json\n' + 'def run(ctx):\n' + f' conn_obj = exa.get_connection("{conn_name}")\n' + ' bfs_params = json.loads(conn_obj.address)\n' + ' bfs_params.update(json.loads(conn_obj.user))\n' + ' bfs_params.update(json.loads(conn_obj.password))\n' + ' return json.dumps(bfs_params)\n' + '/' + ) + pyexasol_connection.execute(sql) + sql = f'SELECT "{udf_name}"();' + bfs_params_str = pyexasol_connection.execute(sql).fetchval() + + # Read from the bucket using data in the connection object + bfs_params = json.loads(bfs_params_str) + bfs_path = bfs.path.build_path(**bfs_params) + file_content = b"".join(bfs_path.read()) + + assert file_content == TEST_FILE_CONTENT + + +def validate_database_std_params(**kwargs): + with open_pyexasol_connection(**kwargs) as conn: + res = conn.execute('SELECT SESSION_ID FROM SYS.EXA_ALL_SESSIONS;').fetchall() + assert res + + +def validate_bucketfs_std_params(**kwargs): + # Temporary work around for the bug in PEC (Issue#78 - no default for the path_in_bucket + if StdParams.path_in_bucket.name in kwargs and kwargs[StdParams.path_in_bucket.name] is None: + kwargs[StdParams.path_in_bucket.name] = '' + bfs_path = create_bucketfs_location(**kwargs) + bfs_path = bfs_path / 'test_file.txt' + bfs_path.write(TEST_FILE_CONTENT) + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT + + +def validate_cli_args(backend, cli_args, base_tag, callback): + if backend == BACKEND_ONPREM: + tags = base_tag | StdTags.ONPREM + elif backend == BACKEND_SAAS: + tags = base_tag | StdTags.SAAS + else: + ValueError(f'Unknown backend {backend}') + opts = select_std_options(tags) + cmd = click.Command('whatever', params=opts, callback=callback) + runner = CliRunner() + runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=False) + + +def test_database_std_params(database_std_params): + validate_database_std_params(**database_std_params) + + +def test_bucketfs_std_params(bucketfs_std_params): + validate_bucketfs_std_params(**bucketfs_std_params, path_in_bucket='test_bucketfs_std_params') + + +def test_database_cli_args(backend, database_cli_args): + validate_cli_args(backend, database_cli_args, StdTags.DB, validate_database_std_params) + + +def test_bucketfs_cli_args(backend, bucketfs_cli_args): + validate_cli_args(backend, bucketfs_cli_args, StdTags.BFS, validate_bucketfs_std_params) From 45e37c0f4668398059596faf370f860c930038f9 Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 11:49:09 +0100 Subject: [PATCH 45/48] added time delay --- pytest-extension/test/integration/tmp_test.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/pytest-extension/test/integration/tmp_test.py b/pytest-extension/test/integration/tmp_test.py index cee393f..cfddd23 100644 --- a/pytest-extension/test/integration/tmp_test.py +++ b/pytest-extension/test/integration/tmp_test.py @@ -3,6 +3,7 @@ import click from click.testing import CliRunner import exasol.bucketfs as bfs +import time from exasol.python_extension_common.connections.pyexasol_connection import open_pyexasol_connection from exasol.python_extension_common.connections.bucketfs_location import create_bucketfs_location from exasol.python_extension_common.cli.std_options import (StdParams, StdTags, select_std_options) @@ -75,6 +76,7 @@ def validate_bucketfs_std_params(**kwargs): bfs_path.write(TEST_FILE_CONTENT) file_content = b"".join(bfs_path.read()) assert file_content == TEST_FILE_CONTENT + time.sleep(30) def validate_cli_args(backend, cli_args, base_tag, callback): @@ -87,7 +89,7 @@ def validate_cli_args(backend, cli_args, base_tag, callback): opts = select_std_options(tags) cmd = click.Command('whatever', params=opts, callback=callback) runner = CliRunner() - runner.invoke(cmd, args=cli_args, catch_exceptions=False, standalone_mode=False) + runner.invoke(cmd, args=cli_args, catch_exceptions=False) def test_database_std_params(database_std_params): From 4da2ecec3ad38da77ba95338eeac79f6b8d8ab50 Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 12:00:40 +0100 Subject: [PATCH 46/48] removed the bucketfs operations --- pytest-extension/test/integration/tmp_test.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/pytest-extension/test/integration/tmp_test.py b/pytest-extension/test/integration/tmp_test.py index cfddd23..32dbacb 100644 --- a/pytest-extension/test/integration/tmp_test.py +++ b/pytest-extension/test/integration/tmp_test.py @@ -73,10 +73,10 @@ def validate_bucketfs_std_params(**kwargs): kwargs[StdParams.path_in_bucket.name] = '' bfs_path = create_bucketfs_location(**kwargs) bfs_path = bfs_path / 'test_file.txt' - bfs_path.write(TEST_FILE_CONTENT) - file_content = b"".join(bfs_path.read()) - assert file_content == TEST_FILE_CONTENT - time.sleep(30) + # bfs_path.write(TEST_FILE_CONTENT) + # file_content = b"".join(bfs_path.read()) + # assert file_content == TEST_FILE_CONTENT + # time.sleep(30) def validate_cli_args(backend, cli_args, base_tag, callback): From 13f0d24be280563e1ac9a18817fc837be805aef7 Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 13:17:47 +0100 Subject: [PATCH 47/48] removed the log info --- .github/workflows/ci.yml | 2 +- pytest-extension/test/integration/tmp_test.py | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 22fe0db..0188bfa 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -39,4 +39,4 @@ jobs: SAAS_HOST: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_HOST }} SAAS_ACCOUNT_ID: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_ACCOUNT_ID }} SAAS_PAT: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_PAT }} - PYTEST_ADDOPTS: '-o log_cli=true -o log_cli_level=INFO ${{ steps.pytest-markers.outputs.slow-tests }}' + PYTEST_ADDOPTS: ${{ steps.pytest-markers.outputs.slow-tests }}' diff --git a/pytest-extension/test/integration/tmp_test.py b/pytest-extension/test/integration/tmp_test.py index 32dbacb..cfddd23 100644 --- a/pytest-extension/test/integration/tmp_test.py +++ b/pytest-extension/test/integration/tmp_test.py @@ -73,10 +73,10 @@ def validate_bucketfs_std_params(**kwargs): kwargs[StdParams.path_in_bucket.name] = '' bfs_path = create_bucketfs_location(**kwargs) bfs_path = bfs_path / 'test_file.txt' - # bfs_path.write(TEST_FILE_CONTENT) - # file_content = b"".join(bfs_path.read()) - # assert file_content == TEST_FILE_CONTENT - # time.sleep(30) + bfs_path.write(TEST_FILE_CONTENT) + file_content = b"".join(bfs_path.read()) + assert file_content == TEST_FILE_CONTENT + time.sleep(30) def validate_cli_args(backend, cli_args, base_tag, callback): From 7e3f285aa833da9e0d6b3a5bf8dc3b08889c96a7 Mon Sep 17 00:00:00 2001 From: mibe Date: Wed, 9 Oct 2024 13:19:28 +0100 Subject: [PATCH 48/48] removed the log info --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 0188bfa..dd76659 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -39,4 +39,4 @@ jobs: SAAS_HOST: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_HOST }} SAAS_ACCOUNT_ID: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_ACCOUNT_ID }} SAAS_PAT: ${{ secrets.INTEGRATION_TEAM_SAAS_STAGING_PAT }} - PYTEST_ADDOPTS: ${{ steps.pytest-markers.outputs.slow-tests }}' + PYTEST_ADDOPTS: '${{ steps.pytest-markers.outputs.slow-tests }}'