summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--debian/ansible-lint.lintian-overrides2
-rw-r--r--debian/changelog12
-rw-r--r--debian/control32
-rw-r--r--debian/patches/deb-testing.patch51
-rw-r--r--debian/patches/remove_version_check.patch8
-rw-r--r--debian/patches/ruamel-yaml-0.18.5.patch48
-rw-r--r--debian/patches/series2
-rwxr-xr-xdebian/rules24
-rw-r--r--debian/upstream/metadata1
9 files changed, 160 insertions, 20 deletions
diff --git a/debian/ansible-lint.lintian-overrides b/debian/ansible-lint.lintian-overrides
new file mode 100644
index 0000000..6a22138
--- /dev/null
+++ b/debian/ansible-lint.lintian-overrides
@@ -0,0 +1,2 @@
+# Not docs, but data files
+ansible-lint: package-contains-documentation-outside-usr-share-doc [usr/lib/python3/dist-packages/ansiblelint/*.md]
diff --git a/debian/changelog b/debian/changelog
index 8479da7..985c8b1 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -1,3 +1,15 @@
+ansible-lint (6.17.2-2) unstable; urgency=medium
+
+ * Team upload.
+ * Add patch for newer ruamel.yaml 0.18.5+
+ * Enable testing using pybuild & pytest, also as autopkgtests.
+ * Ignore lintian complaints about ansiblelint/rules/*.md "package-
+ contains-documentation-outside-usr-share-doc"
+ * d/control: reformatted
+ * Build-Depends: s/dh-python/dh-sequence-python3/ (routine-update)
+
+ -- Michael R. Crusoe <crusoe@debian.org> Mon, 29 Apr 2024 12:48:02 +0200
+
ansible-lint (6.17.2-1~progress7.99u1) graograman-backports; urgency=medium
* Initial reupload to graograman-backports.
diff --git a/debian/control b/debian/control
index 15dddef..6f2c517 100644
--- a/debian/control
+++ b/debian/control
@@ -1,28 +1,41 @@
Source: ansible-lint
-Section: misc
-Priority: optional
Maintainer: Progress Linux Maintainers <maintainers@lists.progress-linux.org>
XSBC-Uploaders: Daniel Baumann <daniel.baumann@progress-linux.org>
XSBC-Original-Maintainer: Debian Python Team <team+python@tracker.debian.org>
-XSBC-Original-Uploaders: Samuel Henrique <samueloph@debian.org>, Gregory Colpart <reg@debian.org>
+XSBC-Original-Uploaders: Samuel Henrique <samueloph@debian.org>,
+ Gregory Colpart <reg@debian.org>
Bugs: mailto:maintainers@lists.progress-linux.org
+Section: misc
+Priority: optional
Build-Depends: debhelper-compat (= 13),
- dh-python,
+ dh-sequence-python3,
pybuild-plugin-pyproject,
python3-all,
python3-setuptools,
python3-setuptools-scm,
+ python3-pytest <!nocheck>,
+ python3-pytest-mock <!nocheck>,
+ python3-pytest-xdist <!nocheck>,
+ python3-ansible-compat (>= 4.0.5) <!nocheck>,
+ python3-filelock (>= 3.3.0) <!nocheck>,
+ python3-rich (>= 12.0.0) <!nocheck>,
+ python3-ruamel.yaml (>= 0.18.5) <!nocheck>,
+ python3-wcmatch <!nocheck>,
+ black (>= 22.8.0) <!nocheck>,
+ git <!nocheck>,
+ yamllint (>= 1.30.0) <!nocheck>
Standards-Version: 4.6.2
-Rules-Requires-Root: no
-Homepage: https://github.com/ansible-community/ansible-lint
Vcs-Browser: https://git.progress-linux.org/packages/graograman-backports/ansible-lint
Vcs-Git: https://git.progress-linux.org/packages/graograman-backports/ansible-lint
XSBC-Original-Vcs-Browser: https://salsa.debian.org/python-team/packages/ansible-lint
XSBC-Original-Vcs-Git: https://salsa.debian.org/python-team/packages/ansible-lint.git
+Homepage: https://github.com/ansible-community/ansible-lint
+Rules-Requires-Root: no
+Testsuite: autopkgtest-pkg-pybuild
Package: ansible-lint
Architecture: all
-Depends: ansible-core (>= 2.12.0),
+Depends: ansible-core,
black (>= 22.8.0),
git,
python3-ansible-compat (>= 4.0.5),
@@ -32,9 +45,8 @@ Depends: ansible-core (>= 2.12.0),
python3-packaging (>= 21.3),
python3-pathspec (>= 0.10.3),
python3-rich (>= 12.0.0),
- python3-ruamel.yaml (>= 0.17.0),
- python3-ruamel.yaml (<< 0.18),
- python3-wcmatch (>= 8.1.2),
+ python3-ruamel.yaml (>= 0.18.5),
+ python3-wcmatch,
python3-yaml (>= 5.4.1),
yamllint (>= 1.30.0),
${misc:Depends},
diff --git a/debian/patches/deb-testing.patch b/debian/patches/deb-testing.patch
new file mode 100644
index 0000000..7556c4f
--- /dev/null
+++ b/debian/patches/deb-testing.patch
@@ -0,0 +1,51 @@
+Author: Michael R. Crusoe <crusoe@debian.org>
+Description: Debian-specific changes for running the tests offline during the build
+Forwarded: not-needed
+--- ansible-lint.orig/conftest.py
++++ ansible-lint/conftest.py
+@@ -15,7 +15,7 @@
+
+ # checking if user is running pytest without installing test dependencies:
+ missing = []
+-for module in ["ansible", "black", "mypy", "pylint"]:
++for module in ["ansible", "black"]:
+ if not importlib.util.find_spec(module):
+ missing.append(module)
+ if missing:
+@@ -30,18 +30,6 @@
+ """Ensure we run preparation only on master thread when running in parallel."""
+ if is_help_option_present(config):
+ return
+- if is_master(config):
+- # we need to be sure that we have the requirements installed as some tests
+- # might depend on these. This approach is compatible with GHA caching.
+- try:
+- subprocess.check_output(
+- ["./tools/install-reqs.sh"], # noqa: S603
+- stderr=subprocess.PIPE,
+- text=True,
+- )
+- except subprocess.CalledProcessError as exc:
+- print(f"{exc}\n{exc.stderr}\n{exc.stdout}", file=sys.stderr) # noqa: T201
+- sys.exit(1)
+
+
+ def is_help_option_present(config: pytest.Config) -> bool:
+--- ansible-lint.orig/test/test_schemas.py
++++ ansible-lint/test/test_schemas.py
+@@ -10,7 +10,6 @@
+ from unittest.mock import DEFAULT, MagicMock, patch
+
+ import pytest
+-import spdx.config
+
+ from ansiblelint.file_utils import Lintable
+ from ansiblelint.schemas import __file__ as schema_module
+@@ -18,7 +17,6 @@
+ from ansiblelint.schemas.main import validate_file_schema
+
+ schema_path = Path(schema_module).parent
+-spdx_config_path = Path(spdx.config.__file__).parent
+
+
+ def test_refresh_schemas() -> None:
diff --git a/debian/patches/remove_version_check.patch b/debian/patches/remove_version_check.patch
index 8e57d96..c68c8aa 100644
--- a/debian/patches/remove_version_check.patch
+++ b/debian/patches/remove_version_check.patch
@@ -1,11 +1,9 @@
Description: Remove version check at runtime
Author: Samuel Henrique <samueloph@debian.org>
Forwarded: not-needed
-Index: ansible-lint/src/ansiblelint/config.py
-===================================================================
--- ansible-lint.orig/src/ansiblelint/config.py
+++ ansible-lint/src/ansiblelint/config.py
-@@ -270,53 +270,5 @@ def get_deps_versions() -> dict[str, Ver
+@@ -265,53 +265,5 @@
def get_version_warning() -> str:
@@ -61,11 +59,9 @@ Index: ansible-lint/src/ansiblelint/config.py
- return msg
+ """Patched on Debian to not download release information from third parties"""
+ return ""
-Index: ansible-lint/test/test_main.py
-===================================================================
--- ansible-lint.orig/test/test_main.py
+++ ansible-lint/test/test_main.py
-@@ -48,7 +48,7 @@ def test_call_from_outside_venv(expected
+@@ -48,7 +48,7 @@
warning_found = "PATH altered to include" in proc.stderr
assert warning_found is expected_warning
diff --git a/debian/patches/ruamel-yaml-0.18.5.patch b/debian/patches/ruamel-yaml-0.18.5.patch
new file mode 100644
index 0000000..aaf29c6
--- /dev/null
+++ b/debian/patches/ruamel-yaml-0.18.5.patch
@@ -0,0 +1,48 @@
+From: Sorin Sbarnea <ssbarnea@redhat.com>
+Date: Fri, 3 Nov 2023 12:59:04 +0000
+Subject: Require ruamel.yaml >= 0.18.5
+Origin: upstream,https://github.com/ansible/ansible-lint/pull/3880
+Forwarded: not-needed
+
+Backported from upstream for version 6.17.2
+
+--- ansible-lint.orig/.config/requirements.in
++++ ansible-lint/.config/requirements.in
+@@ -10,7 +10,7 @@
+ pathspec>=0.10.3 # Mozilla Public License 2.0 (MPL 2.0)
+ pyyaml>=5.4.1 # MIT (centos 9 has 5.3.1)
+ rich>=12.0.0 # MIT
+-ruamel.yaml>=0.17.0,<0.18,!=0.17.29,!=0.17.30 # MIT, next version is planned to have breaking changes
++ruamel.yaml>=0.18.5 # MIT
+ requests>=2.31.0 # Apache-2.0 (indirect, but we want newer version for security reasons)
+ subprocess-tee>=0.4.1 # MIT, used by ansible-compat
+ yamllint >= 1.30.0 # GPLv3
+--- ansible-lint.orig/src/ansiblelint/yaml_utils.py
++++ ansible-lint/src/ansiblelint/yaml_utils.py
+@@ -795,7 +795,7 @@
+ """
+ # Default to reading/dumping YAML 1.1 (ruamel.yaml defaults to 1.2)
+ self._yaml_version_default: tuple[int, int] = (1, 1)
+- self._yaml_version: str | tuple[int, int] = self._yaml_version_default
++ self._yaml_version: tuple[int, int] = self._yaml_version_default
+
+ super().__init__(typ=typ, pure=pure, output=output, plug_ins=plug_ins)
+
+@@ -898,7 +898,7 @@
+ return cast(dict[str, Union[bool, int, str]], config)
+
+ @property # type: ignore[override]
+- def version(self) -> str | tuple[int, int]:
++ def version(self) -> tuple[int, int]:
+ """Return the YAML version used to parse or dump.
+
+ Ansible uses PyYAML which only supports YAML 1.1. ruamel.yaml defaults to 1.2.
+@@ -909,7 +909,7 @@
+ return self._yaml_version
+
+ @version.setter
+- def version(self, value: str | tuple[int, int] | None) -> None:
++ def version(self, value: tuple[int, int] | None) -> None:
+ """Ensure that yaml version uses our default value.
+
+ The yaml Reader updates this value based on the ``%YAML`` directive in files.
diff --git a/debian/patches/series b/debian/patches/series
index 836a30d..6aa9c8a 100644
--- a/debian/patches/series
+++ b/debian/patches/series
@@ -1 +1,3 @@
+ruamel-yaml-0.18.5.patch
remove_version_check.patch
+deb-testing.patch
diff --git a/debian/rules b/debian/rules
index 24db829..b0f80a6 100755
--- a/debian/rules
+++ b/debian/rules
@@ -1,8 +1,24 @@
#!/usr/bin/make -f
-include /usr/share/dpkg/pkg-info.mk
+export LC_ALL=C.UTF-8
+export PYBUILD_BEFORE_TEST=cp --recursive {dir}/examples {dir}/conftest.py {dir}/.pre-commit-config.yaml {dir}/.ansible-lint {build_dir}/
+export PYBUILD_AFTER_TEST=rm -Rf {build_dir}/examples {build_dir}/conftest.py {build_dir}/.pre-commit-config.yaml {build_dir}/.ansible-lint
-%:
- dh $@ --with python3 --buildsystem=pybuild
+export PYBUILD_TEST_ARGS=-n auto -k "not (test_spdx or test_args_module_pass or test_risky_file_permissions or test_fqcn_builtin_fail or test_fqcn_builtin_pass or test_transformer or test_call_from_outside_venv or test_schema_moves or test_rules_id_format or test_yamllint or test_example or test_example_custom_module or test_verbosity or test_task_hook_import_playbook)"
+# test_spdx: requires the yet-to-be-packaged https://pypi.org/project/spdx/
+# test_args_module_pass: require internet access
+# test_risky_file_permissions: requires internet access
+# test_fqcn_builtin_fail: requires internet access
+# test_fqcn_builtin_pass: requires internet access
+# test_transformer: required internet access
+# test_call_from_outside_venv: assumes we are running the test from a virtualenv
+# test_schema_moves: unknown
+# test_rules_id_format: unknown
+# test_yamllint: unknown (due to different version of yamllint?)
+# test_example: unknown
+# test_example_custom_module: unknown
+# test_verbosity: unknown
+# test_task_hook_import_playbook: unknown
-override_dh_auto_test:
+%:
+ dh $@ --buildsystem=pybuild
diff --git a/debian/upstream/metadata b/debian/upstream/metadata
index d0fc2e1..2607d00 100644
--- a/debian/upstream/metadata
+++ b/debian/upstream/metadata
@@ -2,3 +2,4 @@ Bug-Database: https://github.com/ansible/ansible-lint/issues
Bug-Submit: https://github.com/ansible/ansible-lint/issues/new
Repository: https://github.com/ansible/ansible-lint.git
Repository-Browse: https://github.com/ansible/ansible-lint
+Security-Contact: https://github.com/ansible/ansible-lint/tree/HEAD/.github/SECURITY.md