09c76e2380
The config_template comment parser will now respect all comments in INI files, as they are written. This will ensure spacing, paragraphs, and other comments bits that may be in an INI file remain intact, even when overriding options and sections. With this feature we'll now be able to insert options in OSLO config generated files without truncating or making a mess of the file structure. This is an internal enhancement and requires no change from the operator or from within any ansible task. To ensure enhanced comments are working, new tests have been added which will run though all of the `config_template` INI file functions using a mock service file. Existing tests for the old comment structure has been removed. This includes tests that were running redundant tasks for file diffs or expected the only style, merged, comment layout. All of the tests have been broken out into descriptive task files. This was largely done for readability. It was difficult to see what tests we had and how I needed to extend them to test the enhanced comments functionality given the INI type tests were all thoughout the `tests/test-common-tasks.yml`. Now that the files have been broken out developers will easily be able to audit our tests making it simple to extend. Change-Id: Ia6cdc215c35fa9ac45b718c211616a9887a74e37 Signed-off-by: Kevin Carter <kecarter@redhat.com>
46 lines
1.9 KiB
YAML
46 lines
1.9 KiB
YAML
---
|
|
# Copyright 2018, Rackspace US
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
# Test basic function of config_template
|
|
|
|
# Test content attribute with a dictionary input and config_type equal to 'json'
|
|
- name: Template test JSON template with content attribute
|
|
config_template:
|
|
dest: "/tmp/test_content_no_overrides.json"
|
|
config_overrides: {}
|
|
config_type: "json"
|
|
content: "{{ lookup('file', playbook_dir ~ '/templates/test.json') | from_json }}"
|
|
register: test_content_no_overrides_json
|
|
notify: test_content_no_overrides_json check diff
|
|
|
|
- name: Read test_content_no_overrides.json
|
|
slurp:
|
|
src: /tmp/test_content_no_overrides.json
|
|
register: content_no_overrides_file
|
|
|
|
- debug:
|
|
msg: "content_no_overrides.json - {{ content_no_overrides_file.content | b64decode | from_json }}"
|
|
|
|
- debug:
|
|
msg: "content_no_overrides.json.expected - {{ content_no_overrides_file_expected.content | b64decode | from_json }}"
|
|
|
|
# NOTE (alextricity25): The config_template module doesn't use ordered dicts when reading and writing json
|
|
# data, so we can't guarantee that the string literal of both file's content will be the same. Instead, we compare
|
|
# the content after transforming it into a dictionary.
|
|
- name: Compare file content
|
|
assert:
|
|
that:
|
|
- "(content_no_overrides_file.content | b64decode | from_json) == (content_no_overrides_file_expected.content | b64decode | from_json)"
|