From 8db58cd7f5cdeece0ba8734711e30580fd8e6ef8 Mon Sep 17 00:00:00 2001 From: abikouo Date: Fri, 1 Mar 2024 17:08:32 +0100 Subject: [PATCH] fix sanity issues --- tests/sanity/ignore-2.14.txt | 1 - tests/sanity/ignore-2.15.txt | 1 - tests/sanity/ignore-2.16.txt | 1 - tests/sanity/ignore-2.17.txt | 1 - tests/sanity/refresh_ignore_files | 216 ------------------------------ 5 files changed, 220 deletions(-) delete mode 100644 tests/sanity/refresh_ignore_files diff --git a/tests/sanity/ignore-2.14.txt b/tests/sanity/ignore-2.14.txt index 80941b81dc..f62989e02b 100644 --- a/tests/sanity/ignore-2.14.txt +++ b/tests/sanity/ignore-2.14.txt @@ -32,4 +32,3 @@ plugins/modules/k8s.py validate-modules:return-syntax-error plugins/modules/k8s_scale.py validate-modules:return-syntax-error plugins/modules/k8s_service.py validate-modules:return-syntax-error plugins/modules/k8s_taint.py validate-modules:return-syntax-error -tests/integration/targets/k8s_delete/files/deployments.yaml yamllint!skip diff --git a/tests/sanity/ignore-2.15.txt b/tests/sanity/ignore-2.15.txt index 392cf05ac9..86c0791609 100644 --- a/tests/sanity/ignore-2.15.txt +++ b/tests/sanity/ignore-2.15.txt @@ -22,7 +22,6 @@ plugins/modules/k8s_scale.py validate-modules:parameter-type-not-in-doc plugins/modules/k8s_service.py validate-modules:parameter-type-not-in-doc tests/unit/module_utils/fixtures/definitions.yml yamllint!skip tests/unit/module_utils/fixtures/deployments.yml yamllint!skip -tests/integration/targets/k8s_delete/files/deployments.yaml yamllint!skip tests/unit/module_utils/fixtures/pods.yml yamllint!skip tests/integration/targets/helm/files/appversionless-chart-v2/templates/configmap.yaml yamllint!skip tests/integration/targets/helm/files/appversionless-chart/templates/configmap.yaml yamllint!skip diff --git a/tests/sanity/ignore-2.16.txt b/tests/sanity/ignore-2.16.txt index da7297b5a4..cb6e745047 100644 --- a/tests/sanity/ignore-2.16.txt +++ b/tests/sanity/ignore-2.16.txt @@ -25,7 +25,6 @@ plugins/modules/k8s_scale.py validate-modules:parameter-type-not-in-doc plugins/modules/k8s_service.py validate-modules:parameter-type-not-in-doc tests/unit/module_utils/fixtures/definitions.yml yamllint!skip tests/unit/module_utils/fixtures/deployments.yml yamllint!skip -tests/integration/targets/k8s_delete/files/deployments.yaml yamllint!skip tests/unit/module_utils/fixtures/pods.yml yamllint!skip tests/integration/targets/helm/files/appversionless-chart-v2/templates/configmap.yaml yamllint!skip tests/integration/targets/helm/files/appversionless-chart/templates/configmap.yaml yamllint!skip diff --git a/tests/sanity/ignore-2.17.txt b/tests/sanity/ignore-2.17.txt index 7d9081f47f..11c8b21e1c 100644 --- a/tests/sanity/ignore-2.17.txt +++ b/tests/sanity/ignore-2.17.txt @@ -16,7 +16,6 @@ plugins/modules/k8s_scale.py validate-modules:parameter-type-not-in-doc plugins/modules/k8s_service.py validate-modules:parameter-type-not-in-doc tests/unit/module_utils/fixtures/definitions.yml yamllint!skip tests/unit/module_utils/fixtures/deployments.yml yamllint!skip -tests/integration/targets/k8s_delete/files/deployments.yaml yamllint!skip tests/unit/module_utils/fixtures/pods.yml yamllint!skip tests/integration/targets/helm/files/appversionless-chart-v2/templates/configmap.yaml yamllint!skip tests/integration/targets/helm/files/appversionless-chart/templates/configmap.yaml yamllint!skip diff --git a/tests/sanity/refresh_ignore_files b/tests/sanity/refresh_ignore_files deleted file mode 100644 index bdb01b8c3b..0000000000 --- a/tests/sanity/refresh_ignore_files +++ /dev/null @@ -1,216 +0,0 @@ -#!/usr/bin/env python3 - - -import itertools - -from pathlib import Path - - -# Mapping of Ansible versions to supported Python versions -ANSIBLE_VERSIONS = { - "2.9": ["3.6", "3.7", "3.8"], - "2.10": ["3.6", "3.7", "3.8", "3.9"], - "2.11": ["3.6", "3.7", "3.8", "3.9"], - "2.12": ["3.6", "3.7", "3.8", "3.9", "3.10"], - "2.13": ["3.6", "3.7", "3.8", "3.9", "3.10"], - "2.14": ["3.6", "3.7", "3.8", "3.9", "3.10"], - "2.15": ["3.6", "3.7", "3.8", "3.9", "3.10", "3.11"], -} - -IMPORT_SKIPS = [ - "plugins/module_utils/client/discovery.py", - "plugins/module_utils/client/resource.py", - "plugins/module_utils/k8sdynamicclient.py", -] - -# Adds validate-modules:parameter-type-not-in-doc -PARAM_TYPE_SKIPS = [ - "plugins/modules/k8s.py", - "plugins/modules/k8s_scale.py", - "plugins/modules/k8s_service.py", -] - -# Adds validate-modules:return-syntax-error -RETURN_SYNTAX_SKIPS = [ - "plugins/modules/k8s.py", - "plugins/modules/k8s_scale.py", - "plugins/modules/k8s_service.py", - "plugins/modules/k8s_taint.py", -] - -YAML_LINT_SKIPS = [ - "tests/unit/module_utils/fixtures/definitions.yml", - "tests/unit/module_utils/fixtures/deployments.yml", - "tests/unit/module_utils/fixtures/pods.yml", - "tests/integration/targets/helm/files/appversionless-chart-v2/templates/configmap.yaml", - "tests/integration/targets/helm/files/appversionless-chart/templates/configmap.yaml", - "tests/integration/targets/helm/files/test-chart-v2/templates/configmap.yaml", - "tests/integration/targets/helm/files/test-chart/templates/configmap.yaml", - "tests/integration/targets/helm_diff/files/test-chart/templates/configmap.yaml", - "tests/integration/targets/k8s_scale/files/deployment.yaml", -] - -# Add shebang!skip -SHEBANG_SKIPS = [ - "tests/sanity/refresh_ignore_files", -] - -# Add validate-modules:import-error -VALIDATE_IMPORT_SKIPS = [ - "plugins/modules/k8s.py", - "plugins/modules/k8s_cp.py", - "plugins/modules/k8s_drain.py", - "plugins/modules/k8s_exec.py", - "plugins/modules/k8s_info.py", - "plugins/modules/k8s_json_patch.py", - "plugins/modules/k8s_log.py", - "plugins/modules/k8s_rollback.py", - "plugins/modules/k8s_scale.py", - "plugins/modules/k8s_service.py", - "plugins/modules/k8s_taint.py", -] - - -def import_skips(*versions): - for f in IMPORT_SKIPS: - for v in versions: - yield f"{f} import-{v}!skip" - -def param_type_skips(ansible_version): - if ansible_version not in ("2.9", "2.10"): - for f in PARAM_TYPE_SKIPS: - yield f"{f} validate-modules:parameter-type-not-in-doc" - - -def return_syntax_skips(ansible_version): - if ansible_version not in ("2.9", "2.10"): - for f in RETURN_SYNTAX_SKIPS: - yield f"{f} validate-modules:return-syntax-error" - else: - yield - - -def yaml_lint_skips(): - for f in YAML_LINT_SKIPS: - yield f"{f} yamllint!skip" - - -def shebang_skips(): - for f in SHEBANG_SKIPS: - yield f"{f} shebang!skip" - - -def import_boilerplate(path, ansible_version): - if ansible_version in ("2.9", "2.10", "2.11"): - for f in (p for p in path.glob("**/*.py") if not p.is_symlink()): - yield f"{f} future-import-boilerplate!skip" - else: - yield - - -def metaclass_boilerplate(path, ansible_version): - if ansible_version in ("2.9", "2.10", "2.11"): - for f in (p for p in path.glob("**/*.py") if not p.is_symlink()): - yield f"{f} metaclass-boilerplate!skip" - else: - yield - - -def unsupported_compile_skips(path, ansible_version): - """This adds rules for compile skips for all unsupported versions of python. - - These aren't needed for Ansible version 2.12+ as that can be managed on a - global level in tests/config.yml. - """ - if ansible_version in ("2.9", "2.10", "2.11"): - for f in (p for p in path.glob("**/*.py") if not p.is_symlink()): - yield ( - f"{f} compile-2.6!skip\n" - f"{f} compile-2.7!skip\n" - f"{f} compile-3.5!skip" - ) - - -def unsupported_import_skips(path, ansible_version): - """This adds rules for import skips for all unsupported versions of python. - - These aren't needed for Ansible version 2.12+ as that can be managed on a - global level in tests/config.yml. - """ - if ansible_version in ("2.9", "2.10", "2.11"): - if ansible_version in ("2.9", "2.10") and path.name == "plugins": - pathglob = itertools.chain( - path.joinpath("modules").glob("**/*.py"), - path.joinpath("module_utils").glob("**/*.py") - ) - else: - pathglob = path.glob("**/*.py") - for f in (p for p in pathglob if not p.is_symlink()): - yield ( - f"{f} import-2.6!skip\n" - f"{f} import-2.7!skip\n" - f"{f} import-3.5!skip" - ) - - -def unsupported_pylint_skips(path, ansible_version): - """This adds rules to skip pylint checks. - - This is only a problem on Ansible version 2.9 and 2.10 with python 3.5, - but there's no way to restrict this to a specific version of python. - """ - if ansible_version in ("2.9", "2.10"): - pathglob = itertools.chain( - path.joinpath("plugins/modules").glob("**/*.py"), - path.joinpath("plugins/module_utils").glob("**/*.py"), - path.joinpath("tests").glob("**/*.py"), - ) - for f in (p for p in pathglob if not p.is_symlink()): - yield f"{f} pylint!skip" - - -def unsupported_validate_modules_skips(ansible_version): - """Disable validate-modules test. - - Unfortunately, this is overly broad. Applying a validate-modules:import-error - skip fixes ansible 2.9 and python <3.6, but causes validation of the ignores - file itself to fail in python 3.6+. The only solution here is to simply - skip validate-modules altogether. - """ - if ansible_version in ("2.9", "2.10"): - for f in VALIDATE_IMPORT_SKIPS: - yield f"{f} validate-modules!skip" - - -def main(): - target_dir = Path('.') - sanity_dir = target_dir / "tests" / "sanity" - plugins = target_dir / "plugins" - units = target_dir / "tests" / "unit" - integration = target_dir / "tests" / "integration" - - for ansible, python in ANSIBLE_VERSIONS.items(): - with open(sanity_dir / f"ignore-{ansible}.txt", "w") as fp: - ignores = itertools.chain( - import_skips(*python), - param_type_skips(ansible), - yaml_lint_skips(), - shebang_skips(), - return_syntax_skips(ansible), - import_boilerplate(plugins, ansible), - import_boilerplate(units, ansible), - metaclass_boilerplate(plugins, ansible), - metaclass_boilerplate(units, ansible), - unsupported_import_skips(plugins, ansible), - unsupported_compile_skips(plugins, ansible), - unsupported_compile_skips(units, ansible), - unsupported_compile_skips(integration, ansible), - unsupported_pylint_skips(target_dir, ansible), - unsupported_validate_modules_skips(ansible), - ) - for f in filter(None, ignores): - fp.write(f + "\n") - - -if __name__ == "__main__": - main()