[PR #6294/cb3ca05b backport][stable-6] one_vm: fix syntax error when creating VMs with a more complex template (#6342)
one_vm: fix syntax error when creating VMs with a more complex template (#6294)
* one_vm: fix syntax error when creating VMs with a more complex template
with more complex templates that make use of quoted strings the new
"render" method fails to produce a template that is accepted by
OpenNebula. ==> escape double quotes in strings to make OpenNebula
happy again.
I also tested whether newlines need to be escaped, looks like they are
fine as they are.
Fixes #6225
* module_utils/opennebula: skip empty values in render
(cherry picked from commit cb3ca05bd1
)
Co-authored-by: Georg Gadinger <nilsding@nilsding.org>
pull/6346/head
parent
a5824a2a9d
commit
590ff351b4
|
@ -0,0 +1,2 @@
|
||||||
|
bugfixes:
|
||||||
|
- one_vm - fix syntax error when creating VMs with a more complex template (https://github.com/ansible-collections/community.general/issues/6225).
|
|
@ -45,6 +45,8 @@ def render(to_render):
|
||||||
"""Converts dictionary to OpenNebula template."""
|
"""Converts dictionary to OpenNebula template."""
|
||||||
def recurse(to_render):
|
def recurse(to_render):
|
||||||
for key, value in sorted(to_render.items()):
|
for key, value in sorted(to_render.items()):
|
||||||
|
if value is None:
|
||||||
|
continue
|
||||||
if isinstance(value, dict):
|
if isinstance(value, dict):
|
||||||
yield '{0:}=[{1:}]'.format(key, ','.join(recurse(value)))
|
yield '{0:}=[{1:}]'.format(key, ','.join(recurse(value)))
|
||||||
continue
|
continue
|
||||||
|
@ -52,6 +54,9 @@ def render(to_render):
|
||||||
for item in value:
|
for item in value:
|
||||||
yield '{0:}=[{1:}]'.format(key, ','.join(recurse(item)))
|
yield '{0:}=[{1:}]'.format(key, ','.join(recurse(item)))
|
||||||
continue
|
continue
|
||||||
|
if isinstance(value, str):
|
||||||
|
yield '{0:}="{1:}"'.format(key, value.replace('\\', '\\\\').replace('"', '\\"'))
|
||||||
|
continue
|
||||||
yield '{0:}="{1:}"'.format(key, value)
|
yield '{0:}="{1:}"'.format(key, value)
|
||||||
return '\n'.join(recurse(to_render))
|
return '\n'.join(recurse(to_render))
|
||||||
|
|
||||||
|
|
|
@ -75,6 +75,18 @@ RENDER_VALID = [
|
||||||
NIC=[NAME="NIC1",NETWORK_ID="1"]
|
NIC=[NAME="NIC1",NETWORK_ID="1"]
|
||||||
''').strip()
|
''').strip()
|
||||||
),
|
),
|
||||||
|
(
|
||||||
|
{
|
||||||
|
'EMPTY_VALUE': None,
|
||||||
|
'SCHED_REQUIREMENTS': 'CLUSTER_ID="100"',
|
||||||
|
'BACKSLASH_ESCAPED': "this is escaped: \\n; this isn't: \"\nend",
|
||||||
|
},
|
||||||
|
textwrap.dedent('''
|
||||||
|
BACKSLASH_ESCAPED="this is escaped: \\\\n; this isn't: \\"
|
||||||
|
end"
|
||||||
|
SCHED_REQUIREMENTS="CLUSTER_ID=\\"100\\""
|
||||||
|
''').strip()
|
||||||
|
),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue