Skip to content

Commit

Permalink
Refactor(plugins): Move jinja filter code for arista.avd.status_rende…
Browse files Browse the repository at this point in the history
…r to PyAVD (#4142)

Co-authored-by: Claus Holbech <[email protected]>
Co-authored-by: Guillaume Mulocher <[email protected]>
  • Loading branch information
3 people authored Jun 20, 2024
1 parent abf7650 commit 5d6858b
Show file tree
Hide file tree
Showing 7 changed files with 67 additions and 79 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,21 @@

__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.status_render"

try:
from pyavd.j2filters.status_render import status_render
except ImportError as e:
status_render = RaiseOnUse(
AnsibleFilterError(
f"The '{PLUGIN_NAME}' plugin requires the 'pyavd' Python library. Got import error",
orig_exc=e,
)
)

DOCUMENTATION = r"""
---
Expand Down Expand Up @@ -38,33 +53,6 @@


class FilterModule(object):
# STATIC EMOJI CODE
GH_CODE = {}
# Github MD code for Emoji checked box
GH_CODE["PASS"] = ":white_check_mark:"
# GH MD code for Emoji Fail
GH_CODE["FAIL"] = ":x:"

def status_render(self, state_string, rendering):
"""
status_render Convert Text to EMOJI code
Parameters
----------
state_string : str
Text to convert in EMOJI
rendering : string
Markdown Flavor to use for Emoji rendering.
Returns
-------
str
Value to render in markdown
"""
if rendering == "github":
return self.GH_CODE[state_string.upper()]
else:
return state_string

def filters(self):
return {"status_render": self.status_render}
return {"status_render": wrap_filter(PLUGIN_NAME)(status_render)}
12 changes: 0 additions & 12 deletions ansible_collections/arista/avd/tests/unit/filters/filter_utils.py

This file was deleted.

This file was deleted.

1 change: 1 addition & 0 deletions python-avd/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ fix-libs: ## Fix/remove various Ansible specifics things from python files
find $(PACKAGE_DIR) -name '*.py' -exec sed -i -e 's/ansible_collections\.arista\.avd\.plugins\.filter.generate_route_target/$(PYAVD_FILTER_IMPORT)\.generate_route_target/g' {} +
find $(PACKAGE_DIR) -name '*.py' -exec sed -i -e 's/ansible_collections\.arista\.avd\.plugins\.filter.hide_passwords/$(PYAVD_FILTER_IMPORT)\.hide_passwords/g' {} +
find $(PACKAGE_DIR) -name '*.py' -exec sed -i -e 's/ansible_collections\.arista\.avd\.plugins\.filter.list_compress/$(PYAVD_FILTER_IMPORT)\.list_compress/g' {} +
find $(PACKAGE_DIR) -name '*.py' -exec sed -i -e 's/ansible_collections\.arista\.avd\.plugins\.filter.status_render/$(PYAVD_FILTER_IMPORT)\.status_render/g' {} +

find $(PACKAGE_DIR) -name '*.py' -exec sed -i -e 's/ansible_collections\.arista\.avd\.plugins\.filter/$(VENDOR_IMPORT)\.j2\.filter/g' {} +

Expand Down
32 changes: 32 additions & 0 deletions python-avd/pyavd/j2filters/status_render.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
# 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 annotations


def status_render(state_string, rendering):
"""
status_render Convert Text to EMOJI code
Parameters
----------
state_string : str
Text to convert in EMOJI
rendering : string
Markdown Flavor to use for Emoji rendering.
Returns
-------
str
Value to render in markdown
"""
# STATIC EMOJI CODE
GH_CODE = {}
# Github MD code for Emoji checked box
GH_CODE["PASS"] = ":white_check_mark:"
# GH MD code for Emoji Fail
GH_CODE["FAIL"] = ":x:"

if rendering == "github":
return GH_CODE[state_string.upper()]
return state_string
2 changes: 2 additions & 0 deletions python-avd/pyavd/templater.py
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ def import_filters_and_tests(self) -> None:
from .j2filters.list_compress import list_compress
from .j2filters.natural_sort import natural_sort
from .j2filters.snmp_hash import snmp_hash
from .j2filters.status_render import status_render
from .j2tests.contains import contains
from .vendor.j2.filter.range_expand import range_expand
from .vendor.j2.test.defined import defined
Expand All @@ -101,6 +102,7 @@ def import_filters_and_tests(self) -> None:
"arista.avd.natural_sort": natural_sort,
"arista.avd.range_expand": range_expand,
"arista.avd.snmp_hash": snmp_hash,
"arista.avd.status_render": status_render,
}
)
self.environment.tests.update(
Expand Down
16 changes: 16 additions & 0 deletions python-avd/tests/pyavd/j2filters/test_status_render.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
# 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 annotations

import pytest
from pyavd.j2filters.status_render import status_render

STATE_STRINGS = [("PASS", "github", ":white_check_mark:"), ("fail", "github", ":x:"), ("FAIL", "test", "FAIL")]


class TestMarkdownRenderingFilter:
@pytest.mark.parametrize("state_string, rendering, markdown_code", STATE_STRINGS)
def test_status_render_valid(self, state_string, rendering, markdown_code):
resp = status_render(state_string, rendering)
assert resp == markdown_code

0 comments on commit 5d6858b

Please sign in to comment.