From 72b2d276c7dd28c7c280307c3637283195323dd3 Mon Sep 17 00:00:00 2001 From: Guillaume Mulocher Date: Tue, 16 Jul 2024 15:26:55 +0200 Subject: [PATCH 1/6] =?UTF-8?q?Doc:=20Deprecate=20the=20eos=5Fdesigns=20an?= =?UTF-8?q?d=20eos=5Fcli=5Fconfig=5Fgen=20jsonschema.json=E2=80=A6=20(#419?= =?UTF-8?q?5)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ansible_collections/arista/avd/docs/release-notes/4.x.x.md | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/ansible_collections/arista/avd/docs/release-notes/4.x.x.md b/ansible_collections/arista/avd/docs/release-notes/4.x.x.md index 59956f4ca31..29c3af73441 100644 --- a/ansible_collections/arista/avd/docs/release-notes/4.x.x.md +++ b/ansible_collections/arista/avd/docs/release-notes/4.x.x.md @@ -12,7 +12,12 @@ title: Release Notes for AVD 4.x.x - Documentation for AVD version `4.x.x` [available here](https://www.avd.sh/en/stable/) - +## Release 4.10.0 + +### Deprecations + +- In AVD version 5.0.0, the `eos_designs.jsonschema.json` and `eos_cli_config_gen.jsonschema.json` will no longer be generated. These schemas are not being used and have never been complete. + ## Release 4.9.0 ### Breaking or behavioral changes in eos_designs From 5b4b171636797efe398cbe55f0c28d756a372ce3 Mon Sep 17 00:00:00 2001 From: Guillaume Mulocher Date: Tue, 16 Jul 2024 15:27:46 +0200 Subject: [PATCH 2/6] Fix(plugins): Prevent deprecation warnings when deprecated filters are not used (#4199) Co-authored-by: Carl Buchmann --- .pre-commit-config.yaml | 3 +- .../documentation/devices/host1.md | 9 +++ .../intended/configs/host1.cfg | 8 +++ .../host1/port-channel-interfaces.yml | 8 +++ .../avd/plugins/action/eos_cli_config_gen.py | 2 +- .../avd/plugins/filter/deprecated_filters.py | 47 +++++++++++++ .../arista/avd/plugins/filter/generate_esi.py | 66 ------------------- .../avd/plugins/filter/generate_esi.yml | 31 +++++++++ .../avd/plugins/filter/generate_lacp_id.py | 61 ----------------- .../avd/plugins/filter/generate_lacp_id.yml | 27 ++++++++ .../plugins/filter/generate_route_target.py | 63 ------------------ .../plugins/filter/generate_route_target.yml | 29 ++++++++ 12 files changed, 162 insertions(+), 192 deletions(-) create mode 100644 ansible_collections/arista/avd/plugins/filter/deprecated_filters.py delete mode 100644 ansible_collections/arista/avd/plugins/filter/generate_esi.py create mode 100644 ansible_collections/arista/avd/plugins/filter/generate_esi.yml delete mode 100644 ansible_collections/arista/avd/plugins/filter/generate_lacp_id.py create mode 100644 ansible_collections/arista/avd/plugins/filter/generate_lacp_id.yml delete mode 100644 ansible_collections/arista/avd/plugins/filter/generate_route_target.py create mode 100644 ansible_collections/arista/avd/plugins/filter/generate_route_target.yml diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index bd6ab1e3eb2..18f012aaf48 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -180,9 +180,10 @@ repos: name: Build documentation for collection filter plugins. entry: ansible-doc-extractor --template ansible_collections/arista/avd/docs/templates/plugin-docs.j2 --markdown "ansible_collections/arista/avd/docs/plugins/Filter_plugins/" language: python - types: [python] + types_or: [python, yaml] additional_dependencies: ['ansible-doc-extractor>=0.1.10', 'ansible-core>=2.15.0,<2.18.0'] files: ansible_collections/arista/avd/plugins/filter/ + exclude: ^(ansible_collections/arista/avd/plugins/filter/deprecated_filters.py)$ - id: docs-plugin-lookup name: Build documentation for collection lookup plugins. diff --git a/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/documentation/devices/host1.md b/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/documentation/devices/host1.md index 3cc891fb02b..0e8d7be9dee 100644 --- a/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/documentation/devices/host1.md +++ b/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/documentation/devices/host1.md @@ -721,6 +721,7 @@ interface Ethernet47 | Interface | Description | Type | Mode | VLANs | Native VLAN | Trunk Group | LACP Fallback Timeout | LACP Fallback Mode | MLAG ID | EVPN ESI | | --------- | ----------- | ---- | ---- | ----- | ----------- | ------------| --------------------- | ------------------ | ------- | -------- | | Port-Channel1 | SRV01_bond0 | switched | trunk | 2-3000 | - | - | - | - | - | 0000:0000:0404:0404:0303 | +| Port-Channel30 | deprecate_filters_testing | switched | access | - | - | - | - | - | - | deaf:beed:0303:0202:0101 | | Port-Channel51 | ipv6_prefix | switched | trunk | 1-500 | - | - | - | - | - | - | ##### Flexible Encapsulation Interfaces @@ -757,6 +758,14 @@ interface Port-Channel2.1000 route-target import 03:03:02:02:01:01 lacp system-id 0303.0202.0101 ! +interface Port-Channel30 + description deprecate_filters_testing + switchport + evpn ethernet-segment + identifier deaf:beed:0303:0202:0101 + route-target import 03:03:02:02:01:01 + lacp system-id 0303.0202.0101 +! interface Port-Channel51 description ipv6_prefix switchport diff --git a/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/intended/configs/host1.cfg b/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/intended/configs/host1.cfg index 5405be908d7..244ea675c32 100644 --- a/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/intended/configs/host1.cfg +++ b/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/intended/configs/host1.cfg @@ -170,6 +170,14 @@ interface Port-Channel2.1000 route-target import 03:03:02:02:01:01 lacp system-id 0303.0202.0101 ! +interface Port-Channel30 + description deprecate_filters_testing + switchport + evpn ethernet-segment + identifier deaf:beed:0303:0202:0101 + route-target import 03:03:02:02:01:01 + lacp system-id 0303.0202.0101 +! interface Port-Channel51 description ipv6_prefix switchport diff --git a/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/inventory/host_vars/host1/port-channel-interfaces.yml b/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/inventory/host_vars/host1/port-channel-interfaces.yml index 78720cb676a..bcdf9b75f00 100644 --- a/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/inventory/host_vars/host1/port-channel-interfaces.yml +++ b/ansible_collections/arista/avd/molecule/eos_cli_config_gen_deprecated_vars/inventory/host_vars/host1/port-channel-interfaces.yml @@ -30,6 +30,14 @@ port_channel_interfaces: rt: 03:03:02:02:01:01 lacp_id: 0303.0202.0101 + # Testing deprecated filter plugins to be remove in AVD 5.0.0 + Port-Channel30: + description: deprecate_filters_testing + esi: "{{ '0303:0202:0101' | arista.avd.generate_esi('deaf:beed:') }}" + rt: "{{ '0303:0202:0101' | arista.avd.generate_route_target }}" + lacp_id: "{{ '0303:0202:0101' | arista.avd.generate_lacp_id }}" + + Port-Channel51: description: ipv6_prefix vlans: 1-500 diff --git a/ansible_collections/arista/avd/plugins/action/eos_cli_config_gen.py b/ansible_collections/arista/avd/plugins/action/eos_cli_config_gen.py index b36d3c22842..a7cc2732a09 100644 --- a/ansible_collections/arista/avd/plugins/action/eos_cli_config_gen.py +++ b/ansible_collections/arista/avd/plugins/action/eos_cli_config_gen.py @@ -188,7 +188,7 @@ def prepare_task_vars(self, task_vars: dict, structured_config_filename: str, *, try: task_vars[var] = self._templar.template(task_vars[var], fail_on_undefined=False) except Exception as e: - raise AnsibleActionFail(f"Exception during templating of task_var '{var}'") from e + raise AnsibleActionFail(f"Exception during templating of task_var '{var}': '{e}'") from e if not isinstance(task_vars, dict): # Corner case for ansible-test where the passed task_vars is a nested chain-map diff --git a/ansible_collections/arista/avd/plugins/filter/deprecated_filters.py b/ansible_collections/arista/avd/plugins/filter/deprecated_filters.py new file mode 100644 index 00000000000..2d587cf139f --- /dev/null +++ b/ansible_collections/arista/avd/plugins/filter/deprecated_filters.py @@ -0,0 +1,47 @@ +# Copyright (c) 2023-2024 Arista Networks, Inc. +# Use of this source code is governed by the Apache License 2.0 +# that can be found in the LICENSE file. +# +# deprecated filters - grouped together to avoid Ansible to generate warning on loading the module name... +# + +__metaclass__ = type + +from ansible.errors import AnsibleFilterError + +from ansible_collections.arista.avd.plugins.plugin_utils.pyavd_wrappers import RaiseOnUse, wrap_filter + +PLUGIN_NAME_1 = "arista.avd.generate_lacp_id" +PLUGIN_NAME_2 = "arista.avd.generate_esi" +PLUGIN_NAME_3 = "arista.avd.generate_route_target" + +try: + from pyavd.j2filters import generate_esi, generate_lacp_id, generate_route_target +except ImportError as e: + generate_lacp_id = RaiseOnUse( + AnsibleFilterError( + f"The '{PLUGIN_NAME_1}' plugin requires the 'pyavd' Python library. Got import error", + orig_exc=e, + ) + ) + generate_esi = RaiseOnUse( + AnsibleFilterError( + f"The '{PLUGIN_NAME_2}' plugin requires the 'pyavd' Python library. Got import error", + orig_exc=e, + ) + ) + generate_route_target = RaiseOnUse( + AnsibleFilterError( + f"The '{PLUGIN_NAME_3}' plugin requires the 'pyavd' Python library. Got import error", + orig_exc=e, + ) + ) + + +class FilterModule(object): + def filters(self): + return { + "generate_lacp_id": wrap_filter(PLUGIN_NAME_1)(generate_lacp_id), + "generate_esi": wrap_filter(PLUGIN_NAME_2)(generate_esi), + "generate_route_target": wrap_filter(PLUGIN_NAME_3)(generate_route_target), + } diff --git a/ansible_collections/arista/avd/plugins/filter/generate_esi.py b/ansible_collections/arista/avd/plugins/filter/generate_esi.py deleted file mode 100644 index 4af0b52bfaa..00000000000 --- a/ansible_collections/arista/avd/plugins/filter/generate_esi.py +++ /dev/null @@ -1,66 +0,0 @@ -# Copyright (c) 2023-2024 Arista Networks, Inc. -# Use of this source code is governed by the Apache License 2.0 -# that can be found in the LICENSE file. -from __future__ import absolute_import, division, print_function - -__metaclass__ = type - -from ansible.errors import AnsibleFilterError - -from ansible_collections.arista.avd.plugins.plugin_utils.pyavd_wrappers import RaiseOnUse, wrap_filter - -PLUGIN_NAME = "arista.avd.generate_esi" - -try: - from pyavd.j2filters import generate_esi -except ImportError as e: - generate_esi = RaiseOnUse( - AnsibleFilterError( - f"The '{PLUGIN_NAME}' plugin requires the 'pyavd' Python library. Got import error", - orig_exc=e, - ) - ) - - -DOCUMENTATION = r""" ---- -name: generate_esi -collection: arista.avd -author: Arista Ansible Team (@aristanetworks) -version_added: "1.1" -short_description: Transforms short_esi `0303:0202:0101` to EVPN ESI format `0000:0000:0303:0202:0101` -description: Concatenates the given `esi_prefix` and `short_esi`. -positional: _input -options: - _input: - description: Short ESI value as per AVD definition in eos_designs. - type: string - required: true - esi_prefix: - description: ESI prefix value. Will be concatenated with the `short_esi`. - type: string - default: "0000:0000:" -deprecated: - removed_in: "5.0.0" - why: This filter is no longer used by AVD and is very simple to replace with generic Jinja syntax. - alternative: Use Jinja string concatenation instead like `{{ ~ }}` -""" - -EXAMPLES = r""" ---- -esi: "{{ short_esi | arista.avd.generate_esi('deaf:beed:') }}" -""" - -RETURN = r""" ---- -_value: - description: Concatenated string of `esi_prefix` and `short_esi` like `0000:0000:0303:0202:0101` - type: string -""" - - -class FilterModule(object): - def filters(self): - return { - "generate_esi": wrap_filter(PLUGIN_NAME)(generate_esi), - } diff --git a/ansible_collections/arista/avd/plugins/filter/generate_esi.yml b/ansible_collections/arista/avd/plugins/filter/generate_esi.yml new file mode 100644 index 00000000000..f4acbd5508b --- /dev/null +++ b/ansible_collections/arista/avd/plugins/filter/generate_esi.yml @@ -0,0 +1,31 @@ +--- +DOCUMENTATION: + name: generate_esi + collection: arista.avd + author: Arista Ansible Team (@aristanetworks) + version_added: "1.1" + short_description: Transforms short_esi `0303:0202:0101` to EVPN ESI format `0000:0000:0303:0202:0101` + description: Concatenates the given `esi_prefix` and `short_esi`. + positional: _input + options: + _input: + description: Short ESI value as per AVD definition in eos_designs. + type: string + required: true + esi_prefix: + description: ESI prefix value. Will be concatenated with the `short_esi`. + type: string + default: "0000:0000:" + deprecated: + removed_in: "5.0.0" + why: This filter is no longer used by AVD and is very simple to replace with generic Jinja syntax. + alternative: Use Jinja string concatenation instead like `{{ ~ }}` + +EXAMPLES: | + --- + esi: "{{ short_esi | arista.avd.generate_esi('deaf:beed:') }}" + +RETURN: + _value: + description: Concatenated string of `esi_prefix` and `short_esi` like `0000:0000:0303:0202:0101` + type: string diff --git a/ansible_collections/arista/avd/plugins/filter/generate_lacp_id.py b/ansible_collections/arista/avd/plugins/filter/generate_lacp_id.py deleted file mode 100644 index f9e9b507686..00000000000 --- a/ansible_collections/arista/avd/plugins/filter/generate_lacp_id.py +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright (c) 2023-2024 Arista Networks, Inc. -# Use of this source code is governed by the Apache License 2.0 -# that can be found in the LICENSE file. -from __future__ import absolute_import, division, print_function - -__metaclass__ = type - -from ansible.errors import AnsibleFilterError - -from ansible_collections.arista.avd.plugins.plugin_utils.pyavd_wrappers import RaiseOnUse, wrap_filter - -PLUGIN_NAME = "arista.avd.generate_lacp_id" - -try: - from pyavd.j2filters import generate_lacp_id -except ImportError as e: - generate_lacp_id = RaiseOnUse( - AnsibleFilterError( - f"The '{PLUGIN_NAME}' plugin requires the 'pyavd' Python library. Got import error", - orig_exc=e, - ) - ) - -DOCUMENTATION = r""" ---- -name: generate_lacp_id -collection: arista.avd -author: Arista Ansible Team (@aristanetworks) -version_added: "1.1" -short_description: Transforms short_esi `0303:0202:0101` to LACP ID format `0303.0202.0101` -description: Replaces `:` with `.` -positional: _input -options: - _input: - description: Short ESI value as per AVD definition in eos_designs. - type: string - required: true -deprecated: - removed_in: "5.0.0" - why: This filter is no longer used by AVD and is very simple to replace with a generic Jinja filter. - alternative: Use the builtin `replace` filter instead like `{{ | replace(':', '.') }}` -""" - -EXAMPLES = r""" ---- -lacp_id: "{{ short_esi | arista.avd.generate_lacp_id }}" -""" - -RETURN = r""" ---- -_value: - description: String based on LACP ID format like 0303.0202.0101 - type: string -""" - - -class FilterModule(object): - def filters(self): - return { - "generate_lacp_id": wrap_filter(PLUGIN_NAME)(generate_lacp_id), - } diff --git a/ansible_collections/arista/avd/plugins/filter/generate_lacp_id.yml b/ansible_collections/arista/avd/plugins/filter/generate_lacp_id.yml new file mode 100644 index 00000000000..2d19f51297f --- /dev/null +++ b/ansible_collections/arista/avd/plugins/filter/generate_lacp_id.yml @@ -0,0 +1,27 @@ +--- +DOCUMENTATION: + name: generate_lacp_id + collection: arista.avd + author: Arista Ansible Team (@aristanetworks) + version_added: "1.1" + short_description: Transforms short_esi `0303:0202:0101` to LACP ID format `0303.0202.0101` + description: Replaces `:` with `.` + positional: _input + options: + _input: + description: Short ESI value as per AVD definition in eos_designs. + type: string + required: true + deprecated: + removed_in: "5.0.0" + why: This filter is no longer used by AVD and is very simple to replace with a generic Jinja filter. + alternative: Use the builtin `replace` filter instead like `{{ | replace(':', '.') }}` + +EXAMPLES: |- + --- + lacp_id: "{{ short_esi | arista.avd.generate_lacp_id }}" + +RETURN: + _value: + description: String based on LACP ID format like 0303.0202.0101 + type: string diff --git a/ansible_collections/arista/avd/plugins/filter/generate_route_target.py b/ansible_collections/arista/avd/plugins/filter/generate_route_target.py deleted file mode 100644 index 5efa91b9b0d..00000000000 --- a/ansible_collections/arista/avd/plugins/filter/generate_route_target.py +++ /dev/null @@ -1,63 +0,0 @@ -# Copyright (c) 2023-2024 Arista Networks, Inc. -# Use of this source code is governed by the Apache License 2.0 -# that can be found in the LICENSE file. -from __future__ import absolute_import, division, print_function - -__metaclass__ = type - -from ansible.errors import AnsibleFilterError - -from ansible_collections.arista.avd.plugins.plugin_utils.pyavd_wrappers import RaiseOnUse, wrap_filter - -PLUGIN_NAME = "arista.avd.generate_route_target" - -try: - from pyavd.j2filters import generate_route_target -except ImportError as e: - generate_route_target = RaiseOnUse( - AnsibleFilterError( - f"The '{PLUGIN_NAME}' plugin requires the 'pyavd' Python library. Got import error", - orig_exc=e, - ) - ) - -DOCUMENTATION = r""" ---- -name: generate_route_target -collection: arista.avd -author: Arista Ansible Team (@aristanetworks) -version_added: "1.1" -short_description: Transforms short_esi `0303:0202:0101` to route-target format `03:03:02:02:01:01` -description: Removes `:` and inserts new `:` for each two characters. -positional: _input -options: - _input: - description: Short ESI value as per AVD definition in eos_designs. - type: string - required: true -deprecated: - removed_in: "5.0.0" - why: This filter is no longer used by AVD and is very simple to replace with a generic Jinja filter. - alternative: |- - Use the builtin `ansible.builtin.regex_replace` filter instead like - `{{ | ansible.builtin.regex_replace('(\\d{2})(\\d{2}):(\\d{2})(\\d{2}):(\\d{2})(\\d{2})', '\\1:\\2:\\3:\\4:\\5:\\6') }}` -""" - -EXAMPLES = r""" ---- -rt: "{{ short_esi | arista.avd.generate_route_target }}" -""" - -RETURN = r""" ---- -_value: - description: String based on route-target format like 03:03:02:02:01:01 - type: string -""" - - -class FilterModule(object): - def filters(self): - return { - "generate_route_target": wrap_filter(PLUGIN_NAME)(generate_route_target), - } diff --git a/ansible_collections/arista/avd/plugins/filter/generate_route_target.yml b/ansible_collections/arista/avd/plugins/filter/generate_route_target.yml new file mode 100644 index 00000000000..0dbe48afda9 --- /dev/null +++ b/ansible_collections/arista/avd/plugins/filter/generate_route_target.yml @@ -0,0 +1,29 @@ +--- +DOCUMENTATION: + name: generate_route_target + collection: arista.avd + author: Arista Ansible Team (@aristanetworks) + version_added: "1.1" + short_description: Transforms short_esi `0303:0202:0101` to route-target format `03:03:02:02:01:01` + description: Removes `:` and inserts new `:` for each two characters. + positional: _input + options: + _input: + description: Short ESI value as per AVD definition in eos_designs. + type: string + required: true + deprecated: + removed_in: "5.0.0" + why: This filter is no longer used by AVD and is very simple to replace with a generic Jinja filter. + alternative: |- + Use the builtin `ansible.builtin.regex_replace` filter instead like + `{{ | ansible.builtin.regex_replace('(\\d{2})(\\d{2}):(\\d{2})(\\d{2}):(\\d{2})(\\d{2})', '\\1:\\2:\\3:\\4:\\5:\\6') }}` + +EXAMPLES: |- + --- + rt: "{{ short_esi | arista.avd.generate_route_target }}" + +RETURN: + _value: + description: String based on route-target format like 03:03:02:02:01:01 + type: string From 14b8a251a60382c1d4141311a97f4df62e077379 Mon Sep 17 00:00:00 2001 From: Guillaume Mulocher Date: Tue, 16 Jul 2024 18:04:44 +0200 Subject: [PATCH 3/6] Refactor(eos_validate_state): Add warning for ansible test mode (#4173) Co-authored-by: Claus Holbech --- .../_emit_warning.md | 44 +++++++++++++++++++ .../emit_warning.md | 44 +++++++++++++++++++ .../arista/avd/docs/release-notes/4.x.x.md | 3 ++ .../arista/avd/docs/semantic-versioning.md | 1 + .../molecule/eos_validate_state/converge.yml | 1 - .../avd/plugins/action/_emit_warning.py | 27 ++++++++++++ .../avd/plugins/modules/_emit_warning.py | 28 ++++++++++++ .../avd/roles/eos_validate_state/README.md | 4 ++ .../eos_validate_state/anta_integration.md | 1 + .../tasks/ansible_tests.yml | 11 +++++ .../arista/avd/tests/sanity/ignore-2.15.txt | 1 + .../arista/avd/tests/sanity/ignore-2.16.txt | 1 + .../arista/avd/tests/sanity/ignore-2.17.txt | 1 + 13 files changed, 166 insertions(+), 1 deletion(-) create mode 100644 ansible_collections/arista/avd/docs/plugins/Modules_and_action_plugins/_emit_warning.md create mode 100644 ansible_collections/arista/avd/docs/plugins/Modules_and_action_plugins/emit_warning.md create mode 100644 ansible_collections/arista/avd/plugins/action/_emit_warning.py create mode 100644 ansible_collections/arista/avd/plugins/modules/_emit_warning.py diff --git a/ansible_collections/arista/avd/docs/plugins/Modules_and_action_plugins/_emit_warning.md b/ansible_collections/arista/avd/docs/plugins/Modules_and_action_plugins/_emit_warning.md new file mode 100644 index 00000000000..0a48ad9071c --- /dev/null +++ b/ansible_collections/arista/avd/docs/plugins/Modules_and_action_plugins/_emit_warning.md @@ -0,0 +1,44 @@ +--- +# This title is used for search results +title: arista.avd._emit_warning +--- + + +# _emit_warning + +!!! note + Always use the FQCN (Fully Qualified Collection Name) `arista.avd._emit_warning` when using this plugin. + +Internal module - DO NOT USE - Emit a warning in a task. + +## Synopsis + +Emit a warning in a task. + +## Parameters + +| Argument | Type | Required | Default | Value Restrictions | Description | +| -------- | ---- | -------- | ------- | ------------------ | ----------- | +| message | str | optional | None | | The warning message to emit. | + +## Examples + +```yaml +--- +- name: Emit a warning + arista.avd._emit_warning: + message |- + The warning message. + delegate_to: localhost + check_mode: false + run_once: true + changed_when: false +``` + +## Authors + +- Arista Networks (@aristanetworks) diff --git a/ansible_collections/arista/avd/docs/plugins/Modules_and_action_plugins/emit_warning.md b/ansible_collections/arista/avd/docs/plugins/Modules_and_action_plugins/emit_warning.md new file mode 100644 index 00000000000..78c432a45fb --- /dev/null +++ b/ansible_collections/arista/avd/docs/plugins/Modules_and_action_plugins/emit_warning.md @@ -0,0 +1,44 @@ +--- +# This title is used for search results +title: arista.avd.emit_warning +--- + + +# emit_warning + +!!! note + Always use the FQCN (Fully Qualified Collection Name) `arista.avd.emit_warning` when using this plugin. + +Emit a warning in a task. + +## Synopsis + +Emit a warning in a task. + +## Parameters + +| Argument | Type | Required | Default | Value Restrictions | Description | +| -------- | ---- | -------- | ------- | ------------------ | ----------- | +| message | str | optional | None | | The warning message to emit. | + +## Examples + +```yaml +--- +- name: Enit a warning + arista.avd.emit_warning: + message |- + The warning message. + delegate_to: localhost + check_mode: false + run_once: true + changed_when: false +``` + +## Authors + +- EMEA AS Team (@aristanetworks) diff --git a/ansible_collections/arista/avd/docs/release-notes/4.x.x.md b/ansible_collections/arista/avd/docs/release-notes/4.x.x.md index 29c3af73441..769874a6aa0 100644 --- a/ansible_collections/arista/avd/docs/release-notes/4.x.x.md +++ b/ansible_collections/arista/avd/docs/release-notes/4.x.x.md @@ -61,6 +61,9 @@ Pull request: - `arista.avd.validate_and_template` - `arista.avd.yaml_templates_to_facts` +- Starting AVD 5.0.0, `eos_validate_state` will use ANTA as backend, which will change the default behavior (same as setting `use_anta: true` in older versions). + Please review the changes described on the ANTA integration page. + ### Fixed issues in eos_cli_config_gen - Fix(eos_cli_config_gen): Fix the templates for event-handlers by @Shivani-gslab in https://github.com/aristanetworks/avd/pull/4055 diff --git a/ansible_collections/arista/avd/docs/semantic-versioning.md b/ansible_collections/arista/avd/docs/semantic-versioning.md index 506195991ab..36c0e700b17 100644 --- a/ansible_collections/arista/avd/docs/semantic-versioning.md +++ b/ansible_collections/arista/avd/docs/semantic-versioning.md @@ -63,6 +63,7 @@ All roles input variables follow SemVer. Any breaking changes will, at a minimum | Action: `validate_and_template` | ✘ | ✘ | Internal plugin, not intended for external use. | | Action: `verify_requirements` | ✘ | ✘ | Internal plugin, not intended for external use. | | Action: `yaml_templates_to_facts` | ✘ | ✘ | Internal plugin, not intended for external use. | +| Action: `_emit_warning` | ✘ | ✘ | Internal plugin, not intended for external use. | | Test: `contains` | ✅ | ✅ | | | Test: `defined` | ✅ | ✅ | | | Test: `global_vars` | ✅ | ✅ | | diff --git a/ansible_collections/arista/avd/molecule/eos_validate_state/converge.yml b/ansible_collections/arista/avd/molecule/eos_validate_state/converge.yml index fbbb8c60e51..cc6596ed77f 100644 --- a/ansible_collections/arista/avd/molecule/eos_validate_state/converge.yml +++ b/ansible_collections/arista/avd/molecule/eos_validate_state/converge.yml @@ -15,7 +15,6 @@ delegate_to: localhost ansible.builtin.import_role: name: arista.avd.eos_validate_state - # Save catalogs vars: use_anta: true save_catalog: true diff --git a/ansible_collections/arista/avd/plugins/action/_emit_warning.py b/ansible_collections/arista/avd/plugins/action/_emit_warning.py new file mode 100644 index 00000000000..c52eb00472b --- /dev/null +++ b/ansible_collections/arista/avd/plugins/action/_emit_warning.py @@ -0,0 +1,27 @@ +# Copyright (c) 2024 Arista Networks, Inc. +# Use of this source code is governed by the Apache License 2.0 +# that can be found in the LICENSE file. +"""Temporary file to emit a warning.""" + +from ansible.plugins.action import ActionBase +from ansible.utils.display import Display + +display = Display() + +__metaclass__ = type + + +class ActionModule(ActionBase): + def run(self, tmp=None, task_vars=None): + if task_vars is None: + task_vars = {} + + result = super().run(tmp, task_vars) + del tmp + + if self._task.args: + message = self._task.args.get("message") + + display.warning(message) + + return result diff --git a/ansible_collections/arista/avd/plugins/modules/_emit_warning.py b/ansible_collections/arista/avd/plugins/modules/_emit_warning.py new file mode 100644 index 00000000000..5acc1ab983b --- /dev/null +++ b/ansible_collections/arista/avd/plugins/modules/_emit_warning.py @@ -0,0 +1,28 @@ +# Copyright (c) 2024 Arista Networks, Inc. +# Use of this source code is governed by the Apache License 2.0 +# that can be found in the LICENSE file. +DOCUMENTATION = r""" +--- +module: _emit_warning +version_added: "4.9.0" +author: Arista Networks (@aristanetworks) +short_description: Internal module - DO NOT USE - Emit a warning in a task. +description: + - Emit a warning in a task. +options: + message: + description: The warning message to emit. + type: str +""" + +EXAMPLES = r""" +--- +- name: Emit a warning + arista.avd._emit_warning: + message |- + The warning message. + delegate_to: localhost + check_mode: false + run_once: true + changed_when: false +""" diff --git a/ansible_collections/arista/avd/roles/eos_validate_state/README.md b/ansible_collections/arista/avd/roles/eos_validate_state/README.md index 8801dd66409..fbf84620aea 100644 --- a/ansible_collections/arista/avd/roles/eos_validate_state/README.md +++ b/ansible_collections/arista/avd/roles/eos_validate_state/README.md @@ -10,6 +10,10 @@ title: Ansible Collection Role eos_validate_state # eos_validate_state +!!! warning + Starting AVD 5.0.0, `eos_validate_state` will use ANTA as backend, which will change the default behavior (same as setting `use_anta: true` in older versions). + Please review the changes described on the [ANTA integration page](./anta_integration.md) + ## Overview **eos_validate_state** is a role leveraged to validate Arista EOS devices' operational states. diff --git a/ansible_collections/arista/avd/roles/eos_validate_state/anta_integration.md b/ansible_collections/arista/avd/roles/eos_validate_state/anta_integration.md index cc48076bafe..b26ebe23ca0 100644 --- a/ansible_collections/arista/avd/roles/eos_validate_state/anta_integration.md +++ b/ansible_collections/arista/avd/roles/eos_validate_state/anta_integration.md @@ -12,6 +12,7 @@ title: Ansible Collection Role eos_validate_state - Integration with ANTA !!! note [ANTA](https://anta.arista.com/stable/) will be the future default framework leveraged by AVD for network testing and validation. Since it introduces small [breaking changes](#breaking-changes), you have to opt-in to leverage ANTA with `eos_validate_state` by configuring: `use_anta: true`. + Starting AVD 5.0.0, `eos_validate_state` will use ANTA as backend, which will change the default behavior (same as setting `use_anta: true` in older versions). # Overview diff --git a/ansible_collections/arista/avd/roles/eos_validate_state/tasks/ansible_tests.yml b/ansible_collections/arista/avd/roles/eos_validate_state/tasks/ansible_tests.yml index 859a261202f..91d56b824ac 100644 --- a/ansible_collections/arista/avd/roles/eos_validate_state/tasks/ansible_tests.yml +++ b/ansible_collections/arista/avd/roles/eos_validate_state/tasks/ansible_tests.yml @@ -5,6 +5,17 @@ ##################################### ## Run ansible eos_validate_state ## ##################################### +- name: "Warning when not using 'use_anta: true'" + arista.avd._emit_warning: + message: |- + Starting AVD 5.0.0, `eos_validate_state` will use ANTA as backend, which will change the default behavior (same as setting `use_anta: true` in older versions). + Please review the changes described on the ANTA integration page on https://avd.arista.com. + delegate_to: localhost + check_mode: false + changed_when: false + run_once: true + tags: + - always - name: Generate variables for testing ansible.builtin.template: diff --git a/ansible_collections/arista/avd/tests/sanity/ignore-2.15.txt b/ansible_collections/arista/avd/tests/sanity/ignore-2.15.txt index 612c268cc12..1deb7156eb1 100644 --- a/ansible_collections/arista/avd/tests/sanity/ignore-2.15.txt +++ b/ansible_collections/arista/avd/tests/sanity/ignore-2.15.txt @@ -12,3 +12,4 @@ plugins/modules/eos_validate_state_runner.py validate-modules:missing-gplv3-lice plugins/modules/eos_validate_state_reports.py validate-modules:missing-gplv3-license plugins/modules/cv_workflow.py validate-modules:missing-gplv3-license plugins/modules/eos_cli_config_gen.py validate-modules:missing-gplv3-license +plugins/modules/_emit_warning.py validate-modules:missing-gplv3-license diff --git a/ansible_collections/arista/avd/tests/sanity/ignore-2.16.txt b/ansible_collections/arista/avd/tests/sanity/ignore-2.16.txt index 612c268cc12..1deb7156eb1 100644 --- a/ansible_collections/arista/avd/tests/sanity/ignore-2.16.txt +++ b/ansible_collections/arista/avd/tests/sanity/ignore-2.16.txt @@ -12,3 +12,4 @@ plugins/modules/eos_validate_state_runner.py validate-modules:missing-gplv3-lice plugins/modules/eos_validate_state_reports.py validate-modules:missing-gplv3-license plugins/modules/cv_workflow.py validate-modules:missing-gplv3-license plugins/modules/eos_cli_config_gen.py validate-modules:missing-gplv3-license +plugins/modules/_emit_warning.py validate-modules:missing-gplv3-license diff --git a/ansible_collections/arista/avd/tests/sanity/ignore-2.17.txt b/ansible_collections/arista/avd/tests/sanity/ignore-2.17.txt index 612c268cc12..1deb7156eb1 100644 --- a/ansible_collections/arista/avd/tests/sanity/ignore-2.17.txt +++ b/ansible_collections/arista/avd/tests/sanity/ignore-2.17.txt @@ -12,3 +12,4 @@ plugins/modules/eos_validate_state_runner.py validate-modules:missing-gplv3-lice plugins/modules/eos_validate_state_reports.py validate-modules:missing-gplv3-license plugins/modules/cv_workflow.py validate-modules:missing-gplv3-license plugins/modules/eos_cli_config_gen.py validate-modules:missing-gplv3-license +plugins/modules/_emit_warning.py validate-modules:missing-gplv3-license From d83d3db140e6a677d0e3eeab80a69b03ab920080 Mon Sep 17 00:00:00 2001 From: JulioPDX Date: Tue, 16 Jul 2024 12:24:08 -0700 Subject: [PATCH 4/6] Doc: AVD with Ansible Automation Platform Guide (#3910) --- .../getting-started/aap-avd/aap-cvp-eos.svg | 1 + .../aap-avd/aap-dashboardpng.png | Bin 0 -> 82491 bytes .../getting-started/aap-avd/add-template.png | Bin 0 -> 51489 bytes .../getting-started/aap-avd/all-hosts.png | Bin 0 -> 95910 bytes .../getting-started/aap-avd/create-ee.png | Bin 0 -> 62340 bytes .../getting-started/aap-avd/create-source.png | Bin 0 -> 75138 bytes .../_media/getting-started/aap-avd/cvp-cc.png | Bin 0 -> 196280 bytes .../aap-avd/inv-job-output.png | Bin 0 -> 169862 bytes .../getting-started/aap-avd/inv-job-sync.png | Bin 0 -> 73606 bytes .../getting-started/aap-avd/inv-sync.png | Bin 0 -> 81166 bytes .../getting-started/aap-avd/job-output.png | Bin 0 -> 147204 bytes .../getting-started/aap-avd/job-updates.png | Bin 0 -> 74092 bytes .../getting-started/aap-avd/run-job.png | Bin 0 -> 55317 bytes .../getting-started/aap-avd/save-inv.png | Bin 0 -> 63617 bytes .../getting-started/aap-avd/save-project.png | Bin 0 -> 84591 bytes .../getting-started/aap-avd/select-add-ee.png | Bin 0 -> 90523 bytes .../aap-avd/select-add-inv.png | Bin 0 -> 48938 bytes .../aap-avd/select-add-project.png | Bin 0 -> 47943 bytes .../getting-started/aap-avd/select-ee.png | Bin 0 -> 81830 bytes .../getting-started/aap-avd/select-inv.png | Bin 0 -> 55372 bytes .../aap-avd/select-projects.png | Bin 0 -> 97799 bytes .../aap-avd/select-sources.png | Bin 0 -> 63158 bytes .../aap-avd/select-templates.png | Bin 0 -> 79371 bytes .../aap-avd/survey-enabled.png | Bin 0 -> 49270 bytes .../getting-started/aap-avd/survey-save.png | Bin 0 -> 56340 bytes .../getting-started/aap-avd/template-save.png | Bin 0 -> 81597 bytes .../aap-avd/template-survey.png | Bin 0 -> 92724 bytes .../avd/docs/getting-started/avd-aap.md | 398 ++++++++++++++++++ mkdocs.yml | 1 + 29 files changed, 400 insertions(+) create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/aap-cvp-eos.svg create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/aap-dashboardpng.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/add-template.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/all-hosts.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/create-ee.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/create-source.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/cvp-cc.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/inv-job-output.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/inv-job-sync.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/inv-sync.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/job-output.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/job-updates.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/run-job.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/save-inv.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/save-project.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/select-add-ee.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/select-add-inv.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/select-add-project.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/select-ee.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/select-inv.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/select-projects.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/select-sources.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/select-templates.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/survey-enabled.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/survey-save.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/template-save.png create mode 100644 ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/template-survey.png create mode 100644 ansible_collections/arista/avd/docs/getting-started/avd-aap.md diff --git a/ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/aap-cvp-eos.svg b/ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/aap-cvp-eos.svg new file mode 100644 index 00000000000..7c7a1c2ae89 --- /dev/null +++ b/ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/aap-cvp-eos.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/aap-dashboardpng.png b/ansible_collections/arista/avd/docs/_media/getting-started/aap-avd/aap-dashboardpng.png new file mode 100644 index 0000000000000000000000000000000000000000..c97cb8a40ac88f1dfba357fa8ff5650bde5c0605 GIT binary patch literal 82491 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�K^BNvav-nl(W7Cm*wXxsHhBec4p`2vvYBA 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