mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-07-23 05:10:22 -07:00
Fix regression in jinja2 include search path (#18617)
* Fix regression in jinja2 include search path
Since commit 3c39bb5
, the 'ansible_search_path' variable is used to set
jinja2's search path for {% include %} directives. However, this path is
the the proper one because our templates live in 'templates' subdirs in
our search path.
This is a regression because previously, our include search path would
include the dirname of the currently interpreted file, which worked most
of the time.
fixes #18526
* Fix template lookup search path
Improve fix in commit c96c853 so that the search path contain both
template-suffixed paths as well as original paths.
ref PR #18617
* Add integration test for template lookups
Tests regression at #18526
This test fails on current devel branch and succeeds on PR #18617
This commit is contained in:
parent
9b1ce5dfb9
commit
bf48383610
4 changed files with 21 additions and 0 deletions
|
@ -49,6 +49,14 @@ class LookupModule(LookupBase):
|
||||||
# set jinja2 internal search path for includes
|
# set jinja2 internal search path for includes
|
||||||
if 'ansible_search_path' in variables:
|
if 'ansible_search_path' in variables:
|
||||||
searchpath = variables['ansible_search_path']
|
searchpath = variables['ansible_search_path']
|
||||||
|
# our search paths aren't actually the proper ones for jinja includes.
|
||||||
|
# We want to search into the 'templates' subdir of each search path in
|
||||||
|
# addition to our original search paths.
|
||||||
|
newsearchpath = []
|
||||||
|
for p in searchpath:
|
||||||
|
newsearchpath.append(os.path.join(p, 'templates'))
|
||||||
|
newsearchpath.append(p)
|
||||||
|
searchpath = newsearchpath
|
||||||
else:
|
else:
|
||||||
searchpath = [self._loader._basedir, os.path.dirname(lookupfile)]
|
searchpath = [self._loader._basedir, os.path.dirname(lookupfile)]
|
||||||
self._templar.environment.loader.searchpath = searchpath
|
self._templar.environment.loader.searchpath = searchpath
|
||||||
|
|
|
@ -268,3 +268,14 @@
|
||||||
- product.results[6]['item'] == ["C", "1"]
|
- product.results[6]['item'] == ["C", "1"]
|
||||||
- product.results[7]['item'] == ["C", "2"]
|
- product.results[7]['item'] == ["C", "2"]
|
||||||
- product.results[8]['item'] == ["C", "3"]
|
- product.results[8]['item'] == ["C", "3"]
|
||||||
|
|
||||||
|
# Template lookups
|
||||||
|
|
||||||
|
# ref #18526
|
||||||
|
- name: Test that we have a proper jinja search path in template lookup
|
||||||
|
set_fact:
|
||||||
|
hello_world: "{{ lookup('template', 'hello.txt') }}"
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- "hello_world|trim == 'Hello world!'"
|
||||||
|
|
1
test/integration/targets/lookups/templates/hello.txt
Normal file
1
test/integration/targets/lookups/templates/hello.txt
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Hello {% include 'world.txt' %}!
|
1
test/integration/targets/lookups/templates/world.txt
Normal file
1
test/integration/targets/lookups/templates/world.txt
Normal file
|
@ -0,0 +1 @@
|
||||||
|
world
|
Loading…
Add table
Add a link
Reference in a new issue