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:
Sam Doran 2017-10-10 12:01:33 -04:00 committed by Toshio Kuratomi
parent a48532de5f
commit 2610b521bc
3 changed files with 97 additions and 39 deletions

View file

@ -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()

View file

@ -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

View file

@ -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'"