Fix maximum width of the DIB Multiline-YAML
The dib_env_vars variable in the Bifrost's dib.yml file can contain the DIB_BLOCK_DEVICE_CONFIG environment variable which is always the Multiline-YAML data. By default, the format of the data is not preserved while the configuration is merged and saved for the bifrost-deploy container. This is because Ansible uses the PyYAML library which has a default 80 symbol string length limit. The official Ansible documentation [1] recommends using to_yaml or to_nice_yaml filters with width parameter. This change adds the same ability to the merge_yaml Ansible plugin. 1. https://docs.ansible.com/ansible/latest/user_guide/playbooks_filters.html#formatting-data-yaml-and-json The related change for the diskimage-builder to solve the issue with incorrect data provided by Kolla-Ansible is also provided: I3b74ede69eb064ad813a9108ec68a228e549e8bb Closes-Bug: #2014980 Related-Bug: #2014981 Change-Id: Id79445c0311916ac6c1beb3986e14f652ee5a63c Signed-off-by: Maksim Malchuk <maksim.malchuk@gmail.com>
This commit is contained in:
parent
b142b0ae7a
commit
47862b56bd
@ -55,6 +55,14 @@ options:
|
|||||||
default: False
|
default: False
|
||||||
required: False
|
required: False
|
||||||
type: bool
|
type: bool
|
||||||
|
yaml_width:
|
||||||
|
description:
|
||||||
|
- The maximum width of the YAML document. By default, Ansible uses the
|
||||||
|
PyYAML library which has a default 80 symbol string length limit.
|
||||||
|
To change the limit, the new value can be used here.
|
||||||
|
default: None
|
||||||
|
required: False
|
||||||
|
type: int
|
||||||
author: Sean Mooney
|
author: Sean Mooney
|
||||||
'''
|
'''
|
||||||
|
|
||||||
@ -68,6 +76,7 @@ Merge multiple yaml files:
|
|||||||
sources:
|
sources:
|
||||||
- "/tmp/default.yml"
|
- "/tmp/default.yml"
|
||||||
- "/tmp/override.yml"
|
- "/tmp/override.yml"
|
||||||
|
yaml_width: 131072
|
||||||
dest:
|
dest:
|
||||||
- "/tmp/out.yml"
|
- "/tmp/out.yml"
|
||||||
'''
|
'''
|
||||||
@ -113,6 +122,7 @@ class ActionModule(action.ActionBase):
|
|||||||
output = {}
|
output = {}
|
||||||
sources = self._task.args.get('sources', None)
|
sources = self._task.args.get('sources', None)
|
||||||
extend_lists = self._task.args.get('extend_lists', False)
|
extend_lists = self._task.args.get('extend_lists', False)
|
||||||
|
yaml_width = self._task.args.get('yaml_width', None)
|
||||||
if not isinstance(sources, list):
|
if not isinstance(sources, list):
|
||||||
sources = [sources]
|
sources = [sources]
|
||||||
for source in sources:
|
for source in sources:
|
||||||
@ -127,11 +137,13 @@ class ActionModule(action.ActionBase):
|
|||||||
try:
|
try:
|
||||||
result_file = os.path.join(local_tempdir, 'source')
|
result_file = os.path.join(local_tempdir, 'source')
|
||||||
with open(result_file, 'w') as f:
|
with open(result_file, 'w') as f:
|
||||||
f.write(yaml.dump(output, default_flow_style=False))
|
f.write(yaml.dump(output, default_flow_style=False,
|
||||||
|
width=yaml_width))
|
||||||
|
|
||||||
new_task = self._task.copy()
|
new_task = self._task.copy()
|
||||||
new_task.args.pop('sources', None)
|
new_task.args.pop('sources', None)
|
||||||
new_task.args.pop('extend_lists', None)
|
new_task.args.pop('extend_lists', None)
|
||||||
|
new_task.args.pop('yaml_width', None)
|
||||||
new_task.args.update(
|
new_task.args.update(
|
||||||
dict(
|
dict(
|
||||||
src=result_file
|
src=result_file
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
- "{{ node_custom_config }}/{{ item }}.yml"
|
- "{{ node_custom_config }}/{{ item }}.yml"
|
||||||
- "{{ node_custom_config }}/bifrost/{{ item }}.yml"
|
- "{{ node_custom_config }}/bifrost/{{ item }}.yml"
|
||||||
dest: "{{ node_config_directory }}/bifrost/{{ item }}.yml"
|
dest: "{{ node_config_directory }}/bifrost/{{ item }}.yml"
|
||||||
|
yaml_width: 131072
|
||||||
mode: "0660"
|
mode: "0660"
|
||||||
become: true
|
become: true
|
||||||
with_items:
|
with_items:
|
||||||
|
Loading…
Reference in New Issue
Block a user