Remove sysctl entries when state=absent (#31486)
* Remove sysctl entry when state=absent * Cleanup sysctl integration test syntax * Correct grammar on error message * Add sysctl integration test for state=absent
This commit is contained in:
parent
a48532de5f
commit
2610b521bc
3 changed files with 97 additions and 39 deletions
|
@ -165,6 +165,9 @@ class SysctlModule(object):
|
||||||
self.write_file = True
|
self.write_file = True
|
||||||
elif self.file_values[thisname] is None and self.args['state'] == "absent":
|
elif self.file_values[thisname] is None and self.args['state'] == "absent":
|
||||||
self.changed = False
|
self.changed = False
|
||||||
|
elif self.file_values[thisname] and self.args['state'] == "absent":
|
||||||
|
self.changed = True
|
||||||
|
self.write_file = True
|
||||||
elif self.file_values[thisname] != self.args['value']:
|
elif self.file_values[thisname] != self.args['value']:
|
||||||
self.changed = True
|
self.changed = True
|
||||||
self.write_file = True
|
self.write_file = True
|
||||||
|
@ -394,6 +397,6 @@ def main():
|
||||||
|
|
||||||
module.exit_json(changed=result.changed)
|
module.exit_json(changed=result.changed)
|
||||||
|
|
||||||
# import module snippets
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
|
|
@ -9,3 +9,4 @@
|
||||||
#
|
#
|
||||||
# For more information, see sysctl.conf(5) and sysctl.d(5).
|
# For more information, see sysctl.conf(5) and sysctl.d(5).
|
||||||
vm.swappiness=1
|
vm.swappiness=1
|
||||||
|
kernel.panic=2
|
||||||
|
|
|
@ -16,13 +16,18 @@
|
||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
- set_fact: output_dir_test={{output_dir}}/test_sysctl
|
- set_fact:
|
||||||
|
output_dir_test: "{{ output_dir }}/test_sysctl"
|
||||||
|
|
||||||
- name: make sure our testing sub-directory does not exist
|
- name: make sure our testing sub-directory does not exist
|
||||||
file: path="{{ output_dir_test }}" state=absent
|
file:
|
||||||
|
path: "{{ output_dir_test }}"
|
||||||
|
state: absent
|
||||||
|
|
||||||
- name: create our testing sub-directory
|
- name: create our testing sub-directory
|
||||||
file: path="{{ output_dir_test }}" state=directory
|
file:
|
||||||
|
path: "{{ output_dir_test }}"
|
||||||
|
state: directory
|
||||||
|
|
||||||
##
|
##
|
||||||
## sysctl - file manipulation
|
## sysctl - file manipulation
|
||||||
|
@ -38,33 +43,77 @@
|
||||||
name: vm.swappiness
|
name: vm.swappiness
|
||||||
value: 5
|
value: 5
|
||||||
state: present
|
state: present
|
||||||
reload: False
|
reload: no
|
||||||
sysctl_file: "{{ output_dir_test }}/sysctl.conf"
|
sysctl_file: "{{ output_dir_test }}/sysctl.conf"
|
||||||
register: sysctl_test0
|
register: sysctl_test0
|
||||||
- debug: var=sysctl_test0
|
|
||||||
|
- debug:
|
||||||
|
var: sysctl_test0
|
||||||
|
verbosity: 1
|
||||||
|
|
||||||
- name: get file content
|
- name: get file content
|
||||||
shell: "cat {{ output_dir_test }}/sysctl.conf | egrep -v ^\\#"
|
shell: "cat {{ output_dir_test }}/sysctl.conf | egrep -v ^\\#"
|
||||||
register: sysctl_content0
|
register: sysctl_content0
|
||||||
- debug: var=sysctl_content0
|
|
||||||
|
- debug:
|
||||||
|
var: sysctl_content0
|
||||||
|
verbosity: 1
|
||||||
|
|
||||||
- name: Set vm.swappiness to 5 again
|
- name: Set vm.swappiness to 5 again
|
||||||
sysctl:
|
sysctl:
|
||||||
name: vm.swappiness
|
name: vm.swappiness
|
||||||
value: 5
|
value: 5
|
||||||
state: present
|
state: present
|
||||||
reload: False
|
reload: no
|
||||||
sysctl_file: "{{ output_dir_test }}/sysctl.conf"
|
sysctl_file: "{{ output_dir_test }}/sysctl.conf"
|
||||||
register: sysctl_test1
|
register: sysctl_test1
|
||||||
|
|
||||||
- name: validate results
|
- name: validate results
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- 'sysctl_test0.changed is defined'
|
- sysctl_test0 | changed
|
||||||
- 'sysctl_test1.changed is defined'
|
- not sysctl_test1 | changed
|
||||||
- 'sysctl_test0.changed'
|
- 'sysctl_content0.stdout_lines[sysctl_content0.stdout_lines.index("vm.swappiness=5")] == "vm.swappiness=5"'
|
||||||
- 'not sysctl_test1.changed'
|
|
||||||
- 'sysctl_content0.stdout_lines == ["vm.swappiness=5"]'
|
- name: Remove kernel.panic
|
||||||
|
sysctl:
|
||||||
|
name: kernel.panic
|
||||||
|
value: 2
|
||||||
|
reload: no
|
||||||
|
state: absent
|
||||||
|
sysctl_file: "{{ output_dir_test }}/sysctl.conf"
|
||||||
|
register: sysctl_test2
|
||||||
|
|
||||||
|
- name: get file content
|
||||||
|
shell: "cat {{ output_dir_test }}/sysctl.conf | egrep -v ^\\#"
|
||||||
|
register: sysctl_content2
|
||||||
|
|
||||||
|
- debug:
|
||||||
|
var: item
|
||||||
|
verbosity: 1
|
||||||
|
with_items:
|
||||||
|
- "{{ sysctl_test2 }}"
|
||||||
|
- "{{ sysctl_content2 }}"
|
||||||
|
|
||||||
|
- name: Validate results for key removal
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- sysctl_test2 | changed
|
||||||
|
- "'kernel.panic' not in sysctl_content2.stdout_lines"
|
||||||
|
|
||||||
|
- name: Test remove kernel.panic again
|
||||||
|
sysctl:
|
||||||
|
name: kernel.panic
|
||||||
|
value: 2
|
||||||
|
state: absent
|
||||||
|
reload: no
|
||||||
|
sysctl_file: "{{ output_dir_test }}/sysctl.conf"
|
||||||
|
register: sysctl_test2_change_test
|
||||||
|
|
||||||
|
- name: Assert that no change was made
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- not sysctl_test2_change_test | changed
|
||||||
|
|
||||||
##
|
##
|
||||||
## sysctl - sysctl_set
|
## sysctl - sysctl_set
|
||||||
|
@ -75,20 +124,25 @@
|
||||||
name: net.ipv4.ip_forward
|
name: net.ipv4.ip_forward
|
||||||
value: 1
|
value: 1
|
||||||
sysctl_set: yes
|
sysctl_set: yes
|
||||||
reload: False
|
reload: no
|
||||||
register: sysctl_test2
|
register: sysctl_test3
|
||||||
- debug: var=sysctl_test2
|
|
||||||
|
|
||||||
- name: check with sysctl command
|
- name: check with sysctl command
|
||||||
shell: sysctl net.ipv4.ip_forward
|
shell: sysctl net.ipv4.ip_forward
|
||||||
register: sysctl_check2
|
register: sysctl_check3
|
||||||
|
|
||||||
- name: validate results for test 2
|
- debug:
|
||||||
|
var: item
|
||||||
|
verbosity: 1
|
||||||
|
with_items:
|
||||||
|
- "{{ sysctl_test3 }}"
|
||||||
|
- "{{ sysctl_check3 }}"
|
||||||
|
|
||||||
|
- name: validate results for test 3
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- 'sysctl_test2.changed is defined'
|
- sysctl_test3 | changed
|
||||||
- 'sysctl_test2.changed'
|
- 'sysctl_check3.stdout_lines == ["net.ipv4.ip_forward = 1"]'
|
||||||
- 'sysctl_check2.stdout_lines == ["net.ipv4.ip_forward = 1"]'
|
|
||||||
|
|
||||||
- name: Try sysctl with no name
|
- name: Try sysctl with no name
|
||||||
sysctl:
|
sysctl:
|
||||||
|
@ -101,7 +155,7 @@
|
||||||
- name: validate nameless results
|
- name: validate nameless results
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- "sysctl_no_name|failed"
|
- sysctl_no_name | failed
|
||||||
- "sysctl_no_name.msg == 'name cannot be None'"
|
- "sysctl_no_name.msg == 'name cannot be None'"
|
||||||
|
|
||||||
- name: Try sysctl with no value
|
- name: Try sysctl with no value
|
||||||
|
@ -115,5 +169,5 @@
|
||||||
- name: validate nameless results
|
- name: validate nameless results
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- "sysctl_no_value|failed"
|
- sysctl_no_value | failed
|
||||||
- "sysctl_no_value.msg == 'value cannot be None'"
|
- "sysctl_no_value.msg == 'value cannot be None'"
|
Loading…
Reference in a new issue