mirror of
https://github.com/ansible-collections/community.general.git
synced 2026-03-26 21:33:12 +00:00
* osx_defaults: add dict support * add changelog frag * osx_defaults: fix dict idempotency by using plutil -extract for type-preserving read The previous approach piped `defaults read` output (old-style plist text) through `plutil -convert json`. Old-style plist loses boolean type info (booleans appear as 1/0, indistinguishable from integers), causing the comparison to fail and reporting changed=True on every run. Fix by exporting the domain binary plist to a temp file and using `plutil -extract key json` which correctly preserves all plist types (booleans stay true/false, integers stay integers, etc.). Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com> * change param from bool to str * Apply suggestion from review * Update plugins/modules/osx_defaults.py Co-authored-by: Felix Fontein <felix@fontein.de> --------- Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com> Co-authored-by: Felix Fontein <felix@fontein.de>
350 lines
8.2 KiB
YAML
350 lines
8.2 KiB
YAML
---
|
|
####################################################################
|
|
# WARNING: These are designed specifically for Ansible tests #
|
|
# and should not be used as examples of how to write Ansible roles #
|
|
####################################################################
|
|
|
|
# Test code for the osx_defaults module.
|
|
# Copyright (c) 2019, Abhijeet Kasurde <akasurde@redhat.com>
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
- name: Check if name is required for present
|
|
osx_defaults:
|
|
domain: NSGlobalDomain
|
|
key: AppleMeasurementUnits
|
|
type: string
|
|
state: present
|
|
register: missing_value
|
|
ignore_errors: true
|
|
|
|
- name: Test if state and value are required together
|
|
assert:
|
|
that:
|
|
- "'following are missing: value' in missing_value['msg']"
|
|
|
|
- name: Change value of AppleMeasurementUnits to centimeter in check_mode
|
|
osx_defaults:
|
|
domain: NSGlobalDomain
|
|
key: AppleMeasurementUnits
|
|
type: string
|
|
value: Centimeter
|
|
state: present
|
|
register: measure_task_check_mode
|
|
check_mode: true
|
|
|
|
- name: Test if AppleMeasurementUnits value is changed to Centimeters in check_mode
|
|
assert:
|
|
that:
|
|
- measure_task_check_mode.changed
|
|
|
|
- name: Find the current value of AppleMeasurementUnits
|
|
osx_defaults:
|
|
domain: NSGlobalDomain
|
|
key: AppleMeasurementUnits
|
|
state: list
|
|
register: apple_measure_value
|
|
|
|
- debug:
|
|
msg: "{{ apple_measure_value['value'] }}"
|
|
|
|
- set_fact:
|
|
new_value: "Centimeters"
|
|
when: apple_measure_value['value'] == 'Inches' or apple_measure_value['value'] == None
|
|
|
|
- set_fact:
|
|
new_value: "Inches"
|
|
when: apple_measure_value['value'] == 'Centimeters'
|
|
|
|
- name: Change value of AppleMeasurementUnits to {{ new_value }}
|
|
osx_defaults:
|
|
domain: NSGlobalDomain
|
|
key: AppleMeasurementUnits
|
|
type: string
|
|
value: "{{ new_value }}"
|
|
state: present
|
|
register: change_value
|
|
|
|
- name: Test if AppleMeasurementUnits value is changed to {{ new_value }}
|
|
assert:
|
|
that:
|
|
- change_value.changed
|
|
|
|
- name: Again change value of AppleMeasurementUnits to {{ new_value }}
|
|
osx_defaults:
|
|
domain: NSGlobalDomain
|
|
key: AppleMeasurementUnits
|
|
type: string
|
|
value: "{{ new_value }}"
|
|
state: present
|
|
register: change_value
|
|
|
|
- name: Again test if AppleMeasurementUnits value is not changed to {{ new_value }}
|
|
assert:
|
|
that:
|
|
- not change_value.changed
|
|
|
|
- name: Check a fake setting for delete operation
|
|
osx_defaults:
|
|
domain: com.ansible.fake_value
|
|
key: ExampleKeyToRemove
|
|
state: list
|
|
register: list_fake_value
|
|
|
|
- debug:
|
|
msg: "{{ list_fake_value }}"
|
|
|
|
- name: Check if fake value is listed
|
|
assert:
|
|
that:
|
|
- not list_fake_value.changed
|
|
|
|
- name: Create a fake setting for delete operation
|
|
osx_defaults:
|
|
domain: com.ansible.fake_value
|
|
key: ExampleKeyToRemove
|
|
state: present
|
|
value: sample
|
|
register: present_fake_value
|
|
|
|
- debug:
|
|
msg: "{{ present_fake_value }}"
|
|
|
|
- name: Check if fake is created
|
|
assert:
|
|
that:
|
|
- present_fake_value.changed
|
|
when: present_fake_value.changed
|
|
|
|
- name: List a fake setting
|
|
osx_defaults:
|
|
domain: com.ansible.fake_value
|
|
key: ExampleKeyToRemove
|
|
state: list
|
|
register: list_fake
|
|
|
|
- debug:
|
|
msg: "{{ list_fake }}"
|
|
|
|
- name: Delete a fake setting
|
|
osx_defaults:
|
|
domain: com.ansible.fake_value
|
|
key: ExampleKeyToRemove
|
|
state: absent
|
|
register: absent_task
|
|
|
|
- debug:
|
|
msg: "{{ absent_task }}"
|
|
|
|
- name: Check if fake setting is deleted
|
|
assert:
|
|
that:
|
|
- absent_task.changed
|
|
when: present_fake_value.changed
|
|
|
|
- name: Try deleting a fake setting again
|
|
osx_defaults:
|
|
domain: com.ansible.fake_value
|
|
key: ExampleKeyToRemove
|
|
state: absent
|
|
register: absent_task
|
|
|
|
- debug:
|
|
msg: "{{ absent_task }}"
|
|
|
|
- name: Check if fake setting is not deleted
|
|
assert:
|
|
that:
|
|
- not absent_task.changed
|
|
|
|
- name: Delete operation in check_mode
|
|
osx_defaults:
|
|
domain: com.ansible.fake_value
|
|
key: ExampleKeyToRemove
|
|
state: absent
|
|
register: absent_check_mode_task
|
|
check_mode: true
|
|
|
|
- debug:
|
|
msg: "{{ absent_check_mode_task }}"
|
|
|
|
- name: Check delete operation with check mode
|
|
assert:
|
|
that:
|
|
- not absent_check_mode_task.changed
|
|
|
|
|
|
- name: Use different data types and check if it works with them
|
|
osx_defaults:
|
|
domain: com.ansible.fake_values
|
|
key: "{{ item.key }}"
|
|
type: "{{ item.type }}"
|
|
value: "{{ item.value }}"
|
|
state: present
|
|
with_items: &data_type
|
|
- { type: 'int', value: 1, key: 'sample_int'}
|
|
- { type: 'integer', value: 1, key: 'sample_int_2'}
|
|
- { type: 'integer', value: -1, key: 'negative_int'}
|
|
- { type: 'bool', value: true, key: 'sample_bool'}
|
|
- { type: 'boolean', value: true, key: 'sample_bool_2'}
|
|
- { type: 'date', value: "2019-02-19 10:10:10", key: 'sample_date'}
|
|
- { type: 'float', value: 1.2, key: 'sample_float'}
|
|
- { type: 'string', value: 'sample', key: 'sample_string'}
|
|
- { type: 'array', value: ['1', '2'], key: 'sample_array'}
|
|
register: test_data_types
|
|
|
|
- assert:
|
|
that: "item is changed"
|
|
with_items: "{{ test_data_types.results }}"
|
|
|
|
- name: Use different data types and delete them
|
|
osx_defaults:
|
|
domain: com.ansible.fake_values
|
|
key: "{{ item.key }}"
|
|
value: "{{ item.value }}"
|
|
type: "{{ item.type }}"
|
|
state: absent
|
|
with_items: *data_type
|
|
register: test_data_types
|
|
|
|
- assert:
|
|
that: "item is changed"
|
|
with_items: "{{ test_data_types.results }}"
|
|
|
|
|
|
- name: Ensure test key does not exist
|
|
osx_defaults:
|
|
domain: com.ansible.fake_array_value
|
|
key: ExampleArrayKey
|
|
state: absent
|
|
|
|
- name: add array value for the first time
|
|
osx_defaults:
|
|
domain: com.ansible.fake_array_value
|
|
key: ExampleArrayKey
|
|
value:
|
|
- 'Value with spaces'
|
|
type: array
|
|
array_add: true
|
|
register: test_array_add
|
|
|
|
- assert:
|
|
that: test_array_add.changed
|
|
|
|
- name: add for the second time, should be skipped
|
|
osx_defaults:
|
|
domain: com.ansible.fake_array_value
|
|
key: ExampleArrayKey
|
|
value:
|
|
- 'Value with spaces'
|
|
type: array
|
|
array_add: true
|
|
register: test_array_add
|
|
|
|
- assert:
|
|
that: not test_array_add.changed
|
|
|
|
- name: Clean up test key
|
|
osx_defaults:
|
|
domain: com.ansible.fake_array_value
|
|
key: ExampleArrayKey
|
|
state: absent
|
|
register: test_array_add
|
|
|
|
- assert:
|
|
that: test_array_add.changed
|
|
|
|
|
|
- name: Ensure dict test key does not exist
|
|
osx_defaults:
|
|
domain: com.ansible.fake_dict_value
|
|
key: ExampleDictKey
|
|
state: absent
|
|
|
|
- name: Write dict value for the first time
|
|
osx_defaults:
|
|
domain: com.ansible.fake_dict_value
|
|
key: ExampleDictKey
|
|
type: dict
|
|
value:
|
|
General: true
|
|
OpenWith: true
|
|
register: test_dict_write
|
|
|
|
- assert:
|
|
that: test_dict_write.changed
|
|
|
|
- name: Write same dict value again, should not change
|
|
osx_defaults:
|
|
domain: com.ansible.fake_dict_value
|
|
key: ExampleDictKey
|
|
type: dict
|
|
value:
|
|
General: true
|
|
OpenWith: true
|
|
register: test_dict_write
|
|
|
|
- assert:
|
|
that: not test_dict_write.changed
|
|
|
|
- name: Write different dict value, should change
|
|
osx_defaults:
|
|
domain: com.ansible.fake_dict_value
|
|
key: ExampleDictKey
|
|
type: dict
|
|
value:
|
|
General: true
|
|
OpenWith: false
|
|
register: test_dict_write
|
|
|
|
- assert:
|
|
that: test_dict_write.changed
|
|
|
|
- name: Add new key via dict_add
|
|
osx_defaults:
|
|
domain: com.ansible.fake_dict_value
|
|
key: ExampleDictKey
|
|
type: dict
|
|
dict_mode: add
|
|
value:
|
|
Privileges: true
|
|
register: test_dict_add
|
|
|
|
- assert:
|
|
that: test_dict_add.changed
|
|
|
|
- name: Add same key via dict_add again, should not change
|
|
osx_defaults:
|
|
domain: com.ansible.fake_dict_value
|
|
key: ExampleDictKey
|
|
type: dict
|
|
dict_mode: add
|
|
value:
|
|
Privileges: true
|
|
register: test_dict_add
|
|
|
|
- assert:
|
|
that: not test_dict_add.changed
|
|
|
|
- name: Use dict_add on non-existent key, should create it
|
|
osx_defaults:
|
|
domain: com.ansible.fake_dict_value
|
|
key: ExampleDictKeyNew
|
|
type: dict
|
|
dict_mode: add
|
|
value:
|
|
Alpha: true
|
|
register: test_dict_add_new
|
|
|
|
- assert:
|
|
that: test_dict_add_new.changed
|
|
|
|
- name: Clean up dict test keys
|
|
osx_defaults:
|
|
domain: com.ansible.fake_dict_value
|
|
key: "{{ item }}"
|
|
state: absent
|
|
loop:
|
|
- ExampleDictKey
|
|
- ExampleDictKeyNew
|