Skip to content

Commit

Permalink
Ensure we detect templating errors (#2558)
Browse files Browse the repository at this point in the history
* Ensure we detect templating errors

As ansible/ansible#78913 changed behavior
of Ansible on missing filters, we adapted the check so it would
continue to work with newer versions.

* chore: auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
  • Loading branch information
ssbarnea and pre-commit-ci[bot] authored Oct 6, 2022
1 parent b3e26a7 commit 6185f81
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 3 deletions.
1 change: 1 addition & 0 deletions src/ansiblelint/runner.py
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,7 @@ def worker(lintable: Lintable) -> list[MatchError]:
matches = list(
filter(
lambda match: not self.is_excluded(Lintable(match.filename))
and hasattr(match, "lintable")
and match.tag not in match.lintable.line_skips[match.linenumber],
matches,
)
Expand Down
11 changes: 8 additions & 3 deletions src/ansiblelint/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -118,19 +118,24 @@ def ansible_template(
) -> Any:
"""Render a templated string by mocking missing filters."""
templar = ansible_templar(basedir=basedir, templatevars=templatevars)
while True:
# pylint: disable=unused-variable
for i in range(3):
try:
return templar.template(varname, **kwargs)
except AnsibleError as exc:
if exc.message.startswith(
"template error while templating string: No filter named"
if (
exc.message.startswith("template error while templating string:")
and "'" in exc.message
):
missing_filter = exc.message.split("'")[1]
if missing_filter == "end of print statement":
raise
# Mock the filter to avoid and error from Ansible templating
# pylint: disable=protected-access
templar.environment.filters._delegatee[missing_filter] = lambda x: x
# Record the mocked filter so we can warn the user
if missing_filter not in options.mock_filters:
_logger.debug("Mocking missing filter %s", missing_filter)
options.mock_filters.append(missing_filter)
continue
raise
Expand Down

0 comments on commit 6185f81

Please sign in to comment.