I’ve been recently wondering about the ternary filter in Ansible. I’ve seen it used in a couple of places and it’s also mentioned in the documentation. As you probably know, it’s not a standard Jinja filter but one created in Ansible code.
I would like to understand why was the ternary filter created and why is it preferred (Ansible docs doesn’t even mention the alternative syntax) over the more pythonic way of using python style conditional expressions supported by the Jinja library.
# python style conditional expressions
- debug: msg="{{ variable if variable is defined else omit }}"
- debug: msg="{{ 'yes' if variable == 'inline' else 'no' }}"
Even though Ansible is written in Python, Python devs are not the main
target of the tool, so being 'pythonic' is not really an aim of it.
The `ternary` filter is easier for people that are not familiar with
Python, but non programmers and those used to ternary structures in
other languages.
I’m used to the different ternary structures from different programming languages and I find it hard to believe that the ternary filter is easier for non programmers. Is there any evidence of it being the case?
The python style syntax reads more like English and you can immediately see the control flow.
On the other hand, the first time I’ve seen the ternary filter I had to look up how it works. Is the first argument for the false or for the true condition.
You don’t have this problem with the other syntax.
If people find the filter useful then that’s fair enough. Everybody has a difference preference. I probably suffer from Python’s “There should be one – and preferably only one – obvious way to do it.”