diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 8c016e16..7c79f977 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -27,11 +27,11 @@ jobs: - name: Lint Python files run: | - tox -e lint + tox run -e lint - name: Typecheck Python files run: | - tox -e check + tox run -e check tests: name: Tests @@ -65,7 +65,7 @@ jobs: - name: Coverage run: | - tox -e coverage + tox run -e coverage codecov - name: Integration diff --git a/README.rst b/README.rst index 9eecf5c2..42a3f5de 100644 --- a/README.rst +++ b/README.rst @@ -33,7 +33,7 @@ If you prefer live discussions, some of us also hang out in `_ on irc.libera.chat. LXD Documentation: `https://documentation.ubuntu.com/lxd/en/latest/ -https://documentation.ubuntu.com/lxd/en/latest/`_ +`_ PyLXD API Documentation: `https://pylxd.readthedocs.io/en/latest/ `_ diff --git a/doc/source/contributing.rst b/doc/source/contributing.rst index 5f2d3edc..b13c50e6 100644 --- a/doc/source/contributing.rst +++ b/doc/source/contributing.rst @@ -64,20 +64,20 @@ Code standards pyLXD formats code with Black and isort. Verify the formatting with:: - tox -e lint + tox run -e lint If it fails, you can reformat the code with:: - tox -e format + tox run -e format Testing ------- Testing pyLXD is in 3 parts: -1. Conformance with Black and isort, using the ``tox -e lint`` command. -2. Unit tests using ``tox -e py`` or ``tox -e coverage``. -3. Integration tests using the ``tox -e integration-in-lxd``. +1. Conformance with Black and isort, using the ``tox run -e lint`` command. +2. Unit tests using ``tox run -e py`` or ``tox run -e coverage``. +3. Integration tests using the ``tox run -e integration-in-lxd``. .. note:: all of the tests can be run by just using the ``tox`` command on it's own, with the exception of the integration tests. These are not @@ -103,7 +103,7 @@ Integration Testing ^^^^^^^^^^^^^^^^^^^ Integration testing requires a running LXD system. They can be tested locally -in LXD container with nesting support; ``tox -e integration-in-lxd``. +in LXD container with nesting support; ``tox run -e integration-in-lxd``. .. _Github: https://github.com/canonical/pylxd .. _Tox: https://tox.wiki/en/latest/ diff --git a/integration/run-integration-tests b/integration/run-integration-tests index dca099be..199d29d8 100755 --- a/integration/run-integration-tests +++ b/integration/run-integration-tests @@ -47,7 +47,7 @@ OLD_TRUST_LIST="$(mktemp)" save_trust_list > "${OLD_TRUST_LIST}" # finally run the integration tests -tox -e integration +tox run -e integration # Remove any cert added to the trusted list by the integration tests NEW_TRUST_LIST="$(mktemp)" diff --git a/migration/run_migration_integration_tests-18-04 b/migration/run_migration_integration_tests-18-04 index 68a7f9ce..ee49b6be 100755 --- a/migration/run_migration_integration_tests-18-04 +++ b/migration/run_migration_integration_tests-18-04 @@ -70,7 +70,7 @@ lxc exec "$CONTAINER_ONE_NAME" -- mkdir -p /opt/pylxd # NOTE: rockstar (13 Sep 2016) - --recursive is not supported in lxd <2.1, so # until we have pervasive support for that, we'll do this tar hack. tar cf - ./* .git | lxc exec "$CONTAINER_ONE_NAME" -- tar xf - -C /opt/pylxd -lxc exec "$CONTAINER_ONE_NAME" -- /bin/sh -c "cd /opt/pylxd && tox -emigration" +lxc exec "$CONTAINER_ONE_NAME" -- /bin/sh -c "cd /opt/pylxd && tox run -e migration" lxc delete --force "$CONTAINER_ONE_NAME" lxc delete --force "$CONTAINER_TWO_NAME" diff --git a/pylxd/models/storage_pool.py b/pylxd/models/storage_pool.py index 205cda17..790d940d 100644 --- a/pylxd/models/storage_pool.py +++ b/pylxd/models/storage_pool.py @@ -399,7 +399,7 @@ def get(cls, storage_pool, _type, name): volume = cls( storage_pool.client, storage_pool=storage_pool, - **response.json()["metadata"] + **response.json()["metadata"], ) return volume diff --git a/pyproject.toml b/pyproject.toml new file mode 100644 index 00000000..f2476624 --- /dev/null +++ b/pyproject.toml @@ -0,0 +1,45 @@ +[project] +name = "pylxd" +version = "2.3.2a" +description = "python library for LXD" +readme = "README.rst" +authors = [ + {name = "Paul Hummer and others (see CONTRIBUTORS.rst"}, + {email = "lxd@lists.canonical.com"}, +] +classifiers = [ + "Intended Audience :: Information Technology", + "Intended Audience :: System Administrators", + "License :: OSI Approved :: Apache Software License", + "Operating System :: POSIX :: Linux", + "Programming Language :: Python :: 3", +] +license = {file = "LICENSE"} +requires-python = ">=3.8" +dependencies = [ + "cryptography >= 3.2", + "python-dateutil >= 2.4.2", + "requests >= 2.20.0", + "requests-toolbelt >= 0.8.0", + "requests-unixsocket >= 0.1.5", + "urllib3 < 2", + "ws4py != 0.3.5, >= 0.3.4", # 0.3.5 is broken for websocket support +] + +[project.urls] +Homepage = "https://ubuntu.com/lxd" +Documentation = "https://pylxd.readthedocs.io/en/latest/" +Repository = "https://github.com/canonical/pylxd" + +[build-system] +requires = ["setuptools"] + +[tool.setuptools] +packages = ["pylxd"] + +[tool.mypy] +ignore_missing_imports = true +install_types = true +non_interactive = true +warn_return_any = true +warn_unused_configs = true diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 00000000..03b9afb4 --- /dev/null +++ b/requirements.txt @@ -0,0 +1,7 @@ +cryptography >= 3.2 +python-dateutil >= 2.4.2 +requests >= 2.20.0 +requests-toolbelt >= 0.8.0 +requests-unixsocket >= 0.1.5 +urllib3 < 2 +ws4py != 0.3.5, >= 0.3.4 # 0.3.5 is broken for websocket support diff --git a/setup.cfg b/setup.cfg deleted file mode 100644 index 5d0a4570..00000000 --- a/setup.cfg +++ /dev/null @@ -1,130 +0,0 @@ -[metadata] -name = pylxd -version = 2.3.2a -description = python library for LXD -long_description = file: README.rst -author = Paul Hummer and others (see CONTRIBUTORS.rst) -author_email = lxd@lists.canonical.com -home_page = https://ubuntu.com/lxd -classifier = - Intended Audience :: Information Technology - Intended Audience :: System Administrators - License :: OSI Approved :: Apache Software License - Operating System :: POSIX :: Linux - Programming Language :: Python :: 3 - -[options] -python_requires = >= 3.8 -packages = find: -install_requires = - cryptography >= 3.2 - python-dateutil >= 2.4.2 - requests >= 2.20.0 - requests-toolbelt >= 0.8.0 - requests-unixsocket >= 0.1.5 - urllib3 < 2 - ws4py != 0.3.5, >= 0.3.4 # 0.3.5 is broken for websocket support - -[options.extras_require] -testing = - ddt >= 0.7.0 - mock-services >= 0.3 - pytest-cov == 2.10.1 - pytest >= 6.1.2 - # mock-services is old and unmaintained. Doesn't work with newer versions - # of requests-mock. Thus, we have to pin it down. - requests-mock < 1.2 - # Python 3.12 no longer installs `setuptools` in venv - # but mock-services depends on it for `pkg_resources` - setuptools -format = - black == 23.1.0 - flake8 >= 2.5.0 - isort == 5.6.4 -check = - mypy -doc = - Sphinx - -[flake8] -show-source = True -ignore = E203, E266, E501, W503, W504 -exclude = .git, .tox, dist, doc, *egg, build - -[mypy] -ignore_missing_imports = True -install_types = True -non_interactive = True -warn_return_any = True -warn_unused_configs = True - -[build_sphinx] -source-dir = doc/source -build-dir = doc/build -all_files = 1 - -[upload_sphinx] -upload-dir = doc/build/html - -[tox:tox] -minversion = 1.6 -envlist = lint,check,coverage -skipsdist = True - -[testenv] -usedevelop = True -setenv = - PYLXD_WARNINGS=none -deps = - .[testing] -commands = - pytest {posargs:pylxd} - -[testenv:integration] -commands = - pytest integration {posargs} - -[testenv:integration-in-lxd] -commands = - {toxinidir}/integration/run-integration-tests-in-lxd - -[testenv:migration] -commands = pytest migration {posargs} - -[testenv:format] -deps = - .[format] -commands= - isort --profile black {toxinidir} - black {toxinidir} - -[testenv:lint] -deps = - .[format] -commands = - black --check {toxinidir} - isort --profile black --check-only --diff {toxinidir} - flake8 {toxinidir} - -[testenv:check] -deps = - .[check] -commands = - mypy -p pylxd {posargs} - -[testenv:coverage] -deps = - .[testing] -commands = pytest --cov=pylxd pylxd {posargs} - -[testenv:i18n] -deps = - .[i18n] -commands = - {envpython} setup.py {posargs} - -[testenv:doc] -deps = - .[doc] -commands = - {envpython} setup.py build_sphinx diff --git a/setup.py b/setup.py deleted file mode 100644 index d44f073a..00000000 --- a/setup.py +++ /dev/null @@ -1,16 +0,0 @@ -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or -# implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -from setuptools import setup - -setup() diff --git a/tox.ini b/tox.ini new file mode 100644 index 00000000..47556623 --- /dev/null +++ b/tox.ini @@ -0,0 +1,77 @@ +[tox] +minversion = 1.6 +skipsdist = True +envlist = lint,check,coverage + +[vars] +src_path = {toxinidir}/pylxd/ + +# Define dependency groups +# https://tox.wiki/en/latest/config.html#substitution-for-values-from-other-sections +[testing] +deps = + -rrequirements.txt + ddt >= 0.7.0 + mock-services >= 0.3 + pytest-cov >= 2.10.1 + pytest >= 6.1.2 + # mock-services is old and unmaintained. Doesn't work with newer versions + # of requests-mock. Thus, we have to pin it down. + requests-mock < 1.2 + # Python 3.12 no longer installs `setuptools` in venv + # but mock-services depends on it for `pkg_resources` + setuptools + +[format] +deps = + black == 23.1.0 + flake8 >= 2.5.0 + isort == 5.6.4 + +[testenv] +basepython = python3 +setenv = + PYLXD_WARNINGS=none + PYTHONPATH = {[vars]src_path} + PY_COLORS=1 +package = editable +deps = {[testing]deps} +commands = pytest {posargs:pylxd} + +[testenv:integration] +deps = {[testing]deps} +commands = pytest integration {posargs} + +[testenv:integration-in-lxd] +deps = {[testing]deps} +commands = {toxinidir}/integration/run-integration-tests-in-lxd + +[testenv:migration] +deps = {[testing]deps} +commands = pytest migration {posargs} + +[testenv:format] +deps = {[format]deps} +commands = + isort --profile black {toxinidir} + black {toxinidir} + +[testenv:lint] +deps = {[format]deps} +commands = + black --check {toxinidir} + isort --profile black --check-only --diff {toxinidir} + flake8 {toxinidir} + +[testenv:check] +deps = mypy +commands = mypy -p pylxd {posargs} + +[testenv:coverage] +deps = {[testing]deps} +commands = pytest --cov=pylxd pylxd {posargs} + +[flake8] +show-source = True +ignore = E203, E266, E501, W503, W504 +exclude = .git, .tox, dist, doc, *egg, build