summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSam Doran <sdoran@redhat.com>2019-10-10 11:06:08 -0400
committerToshio Kuratomi <a.badger@gmail.com>2019-10-10 08:06:08 -0700
commite05938e05eb69da2a8845c7ce381c02332c04ede (patch)
tree0af6e44508658ffc5ad6589f6b926a556519bb8c
parentd0a4f0fdbe3f54dd029430f0c943df4ec9fb5877 (diff)
downloadansible-e05938e05eb69da2a8845c7ce381c02332c04ede.tar.gz
[stable-2.9] cronvar - use correct binary name (#63279) (#63338)
* [stable-2.9] cronvar - use correct binary name (#63279) Fixes regression introduced by #62554 Add integration tests for cronvar. (cherry picked from commit 9d014778adcdbbfeca6531c2c4db4121e362c8d2) Co-authored-by: Sam Doran <sdoran@redhat.com> * cron: add integration tests (#59830) * cron: add integration tests Use faketime in order to reduce waiting time. Using opensuse15 container: Tuesday 30 July 2019 23:03:19 +0000 (0:00:05.410) 0:01:28.291 ********** =============================================================================== cron : install cron and faketime packages ------------------------------ 78.65s cron : wait 70 seconds max ---------------------------------------------- 5.41s Gathering Facts --------------------------------------------------------- 0.97s cron : enable cron service ---------------------------------------------- 0.72s cron : Use faketime with cron service ----------------------------------- 0.71s cron : command ---------------------------------------------------------- 0.41s cron : create directory for cron drop-in file --------------------------- 0.41s cron : add cron task ---------------------------------------------------- 0.40s cron : command ---------------------------------------------------------- 0.25s cron : command ---------------------------------------------------------- 0.25s cron : include_vars ----------------------------------------------------- 0.06s * cron test, simplify: use Environment instead ExecStart Thanks to mscherer for the suggestion. * clean up comment: remove reference to outdated path $OUTPUT_DIR is a plain path which doesn't reference any other environment variables * cron test: display elapsed time * cron test: display some logs in case of failure * cron test: handle FreeBSD * cron tests: add checks (cherry picked from commit 3c8abc0b824977d1941a307273e865aed49a2993)
-rw-r--r--changelogs/fragments/cronvar-correct-binary-name.yaml2
-rw-r--r--lib/ansible/modules/system/cronvar.py2
-rw-r--r--test/integration/targets/cron/aliases3
-rw-r--r--test/integration/targets/cron/defaults/cron.debian.yml4
-rw-r--r--test/integration/targets/cron/defaults/cron.fedora.yml4
-rw-r--r--test/integration/targets/cron/defaults/cron.freebsd.yml4
-rw-r--r--test/integration/targets/cron/defaults/cron.redhat.yml5
-rw-r--r--test/integration/targets/cron/defaults/cron.suse.yml4
-rw-r--r--test/integration/targets/cron/defaults/main.yml1
-rw-r--r--test/integration/targets/cron/meta/main.yml2
-rw-r--r--test/integration/targets/cron/tasks/main.yml101
-rw-r--r--test/integration/targets/cronvar/aliases3
-rw-r--r--test/integration/targets/cronvar/defaults/main.yml1
-rw-r--r--test/integration/targets/cronvar/meta/main.yml2
-rw-r--r--test/integration/targets/cronvar/tasks/main.yml109
-rw-r--r--test/integration/targets/setup_cron/defaults/main.yml1
-rw-r--r--test/integration/targets/setup_cron/tasks/main.yml70
-rw-r--r--test/integration/targets/setup_cron/vars/debian.yml3
-rw-r--r--test/integration/targets/setup_cron/vars/default.yml0
-rw-r--r--test/integration/targets/setup_cron/vars/fedora.yml3
-rw-r--r--test/integration/targets/setup_cron/vars/freebsd.yml3
-rw-r--r--test/integration/targets/setup_cron/vars/redhat.yml4
-rw-r--r--test/integration/targets/setup_cron/vars/suse.yml3
23 files changed, 333 insertions, 1 deletions
diff --git a/changelogs/fragments/cronvar-correct-binary-name.yaml b/changelogs/fragments/cronvar-correct-binary-name.yaml
new file mode 100644
index 0000000000..4472bfa9db
--- /dev/null
+++ b/changelogs/fragments/cronvar-correct-binary-name.yaml
@@ -0,0 +1,2 @@
+bugfixes:
+ - cronvar - use correct binary name (https://github.com/ansible/ansible/issues/63274)
diff --git a/lib/ansible/modules/system/cronvar.py b/lib/ansible/modules/system/cronvar.py
index eb7c7a6b7b..f66320bc44 100644
--- a/lib/ansible/modules/system/cronvar.py
+++ b/lib/ansible/modules/system/cronvar.py
@@ -126,7 +126,7 @@ class CronVar(object):
self.user = user
self.lines = None
self.wordchars = ''.join(chr(x) for x in range(128) if chr(x) not in ('=', "'", '"',))
- self.cron_cmd = self.module.get_bin_path('cronvar', required=True)
+ self.cron_cmd = self.module.get_bin_path('crontab', required=True)
if cron_file:
self.cron_file = ""
diff --git a/test/integration/targets/cron/aliases b/test/integration/targets/cron/aliases
new file mode 100644
index 0000000000..fe75653cad
--- /dev/null
+++ b/test/integration/targets/cron/aliases
@@ -0,0 +1,3 @@
+destructive
+shippable/posix/group4
+skip/osx
diff --git a/test/integration/targets/cron/defaults/cron.debian.yml b/test/integration/targets/cron/defaults/cron.debian.yml
new file mode 100644
index 0000000000..49abf6995f
--- /dev/null
+++ b/test/integration/targets/cron/defaults/cron.debian.yml
@@ -0,0 +1,4 @@
+---
+cron_pkg: cron
+cron_service: cron
+list_pkg_files: dpkg -L
diff --git a/test/integration/targets/cron/defaults/cron.fedora.yml b/test/integration/targets/cron/defaults/cron.fedora.yml
new file mode 100644
index 0000000000..3507db46ac
--- /dev/null
+++ b/test/integration/targets/cron/defaults/cron.fedora.yml
@@ -0,0 +1,4 @@
+---
+cron_pkg: cronie
+cron_service: crond
+list_pkg_files: rpm -ql
diff --git a/test/integration/targets/cron/defaults/cron.freebsd.yml b/test/integration/targets/cron/defaults/cron.freebsd.yml
new file mode 100644
index 0000000000..07063dc0fa
--- /dev/null
+++ b/test/integration/targets/cron/defaults/cron.freebsd.yml
@@ -0,0 +1,4 @@
+---
+cron_pkg:
+cron_service: cron
+list_pkg_files: pkg info --list-files
diff --git a/test/integration/targets/cron/defaults/cron.redhat.yml b/test/integration/targets/cron/defaults/cron.redhat.yml
new file mode 100644
index 0000000000..40a79f37c3
--- /dev/null
+++ b/test/integration/targets/cron/defaults/cron.redhat.yml
@@ -0,0 +1,5 @@
+---
+cron_pkg: cronie
+cron_service: crond
+faketime_pkg:
+list_pkg_files: rpm -ql
diff --git a/test/integration/targets/cron/defaults/cron.suse.yml b/test/integration/targets/cron/defaults/cron.suse.yml
new file mode 100644
index 0000000000..5e57a6e514
--- /dev/null
+++ b/test/integration/targets/cron/defaults/cron.suse.yml
@@ -0,0 +1,4 @@
+---
+cron_pkg: cron
+cron_service: cron
+list_pkg_files: rpm -ql
diff --git a/test/integration/targets/cron/defaults/main.yml b/test/integration/targets/cron/defaults/main.yml
new file mode 100644
index 0000000000..37e6fc3714
--- /dev/null
+++ b/test/integration/targets/cron/defaults/main.yml
@@ -0,0 +1 @@
+faketime_pkg: libfaketime
diff --git a/test/integration/targets/cron/meta/main.yml b/test/integration/targets/cron/meta/main.yml
new file mode 100644
index 0000000000..2d2436a168
--- /dev/null
+++ b/test/integration/targets/cron/meta/main.yml
@@ -0,0 +1,2 @@
+dependencies:
+ - setup_cron
diff --git a/test/integration/targets/cron/tasks/main.yml b/test/integration/targets/cron/tasks/main.yml
new file mode 100644
index 0000000000..cc892c8e06
--- /dev/null
+++ b/test/integration/targets/cron/tasks/main.yml
@@ -0,0 +1,101 @@
+- name: add cron task (check mode enabled, cron task not already created)
+ cron:
+ name: test cron task
+ job: 'date > {{ remote_dir }}/cron_canary1'
+ check_mode: yes
+ register: check_mode_enabled_state_present
+
+- assert:
+ that: check_mode_enabled_state_present is changed
+
+- name: add cron task (check mode disabled, task hasn't already been created)
+ cron:
+ name: test cron task
+ job: 'date > {{ remote_dir }}/cron_canary1'
+ register: add_cron_task
+
+- assert:
+ that: add_cron_task is changed
+
+- name: add cron task (check mode enabled, cron task already exists)
+ cron:
+ name: test cron task
+ job: 'date > {{ remote_dir }}/cron_canary1'
+ check_mode: yes
+ register: check_mode_enabled_state_present_cron_task_already_exists
+
+- assert:
+ that: check_mode_enabled_state_present_cron_task_already_exists is not changed
+
+- name: add cron task (check mode disabled, cron task already created)
+ cron:
+ name: test cron task
+ job: 'date > {{ remote_dir }}/cron_canary1'
+ register: cron_task_already_created
+
+- assert:
+ that: cron_task_already_created is not changed
+
+- block:
+ - name: wait for canary creation
+ wait_for:
+ path: '{{ remote_dir }}/cron_canary1'
+ timeout: '{{ 20 if faketime_pkg else 70 }}'
+ register: wait_canary
+ always:
+ - name: display some logs in case of failure
+ command: 'journalctl -u {{ cron_service }}'
+ when: wait_canary is failed and ansible_service_mgr == 'systemd'
+
+- debug:
+ msg: 'elapsed time waiting for canary: {{ wait_canary.elapsed }}'
+
+- name: Check check_mode
+ cron:
+ name: test cron task
+ job: 'date > {{ remote_dir }}/cron_canary1'
+ state: absent
+ check_mode: yes
+ register: check_check_mode
+
+- assert:
+ that: check_check_mode is changed
+
+- name: Remove a cron task
+ cron:
+ name: test cron task
+ job: 'date > {{ remote_dir }}/cron_canary1'
+ state: absent
+ register: remove_task
+
+- assert:
+ that: remove_task is changed
+
+- name: 'cron task missing: check idempotence (check mode enabled, state=absent)'
+ cron:
+ name: test cron task
+ job: 'date > {{ remote_dir }}/cron_canary1'
+ state: absent
+ register: check_mode_enabled_remove_task_idempotence
+
+- assert:
+ that: check_mode_enabled_remove_task_idempotence is not changed
+
+- name: 'cron task missing: check idempotence (check mode disabled, state=absent)'
+ cron:
+ name: test cron task
+ job: 'date > {{ remote_dir }}/cron_canary1'
+ state: absent
+ register: remove_task_idempotence
+
+- assert:
+ that: remove_task_idempotence is not changed
+
+- name: Check that removing a cron task with cron_file and without specifying an user is allowed (#58493)
+ cron:
+ cron_file: unexistent_cron_file
+ state: absent
+ register: remove_cron_file
+
+- assert:
+ that: remove_cron_file is not changed
diff --git a/test/integration/targets/cronvar/aliases b/test/integration/targets/cronvar/aliases
new file mode 100644
index 0000000000..fe75653cad
--- /dev/null
+++ b/test/integration/targets/cronvar/aliases
@@ -0,0 +1,3 @@
+destructive
+shippable/posix/group4
+skip/osx
diff --git a/test/integration/targets/cronvar/defaults/main.yml b/test/integration/targets/cronvar/defaults/main.yml
new file mode 100644
index 0000000000..a22230ab66
--- /dev/null
+++ b/test/integration/targets/cronvar/defaults/main.yml
@@ -0,0 +1 @@
+cron_config_path: /etc/cron.d
diff --git a/test/integration/targets/cronvar/meta/main.yml b/test/integration/targets/cronvar/meta/main.yml
new file mode 100644
index 0000000000..2d2436a168
--- /dev/null
+++ b/test/integration/targets/cronvar/meta/main.yml
@@ -0,0 +1,2 @@
+dependencies:
+ - setup_cron
diff --git a/test/integration/targets/cronvar/tasks/main.yml b/test/integration/targets/cronvar/tasks/main.yml
new file mode 100644
index 0000000000..e6fff1d9a9
--- /dev/null
+++ b/test/integration/targets/cronvar/tasks/main.yml
@@ -0,0 +1,109 @@
+- name: Create EMAIL cron var
+ cronvar:
+ name: EMAIL
+ value: doug@ansibmod.con.com
+ register: create_cronvar1
+
+- name: Create EMAIL cron var again
+ cronvar:
+ name: EMAIL
+ value: doug@ansibmod.con.com
+ register: create_cronvar2
+
+- name: Check cron var value
+ shell: crontab -l -u root | grep -c EMAIL=doug@ansibmod.con.com
+ register: varcheck1
+
+- name: Modify EMAIL cron var
+ cronvar:
+ name: EMAIL
+ value: jane@ansibmod.con.com
+ register: create_cronvar3
+
+- name: Check cron var value again
+ shell: crontab -l -u root | grep -c EMAIL=jane@ansibmod.con.com
+ register: varcheck2
+
+- name: Remove EMAIL cron var
+ cronvar:
+ name: EMAIL
+ state: absent
+ register: remove_cronvar1
+
+- name: Remove EMAIL cron var again
+ cronvar:
+ name: EMAIL
+ state: absent
+ register: remove_cronvar2
+
+- name: Check cron var value again
+ shell: crontab -l -u root | grep -c EMAIL
+ register: varcheck3
+ failed_when: varcheck3.rc == 0
+
+- name: Add cron var to custom file
+ cronvar:
+ name: TESTVAR
+ value: somevalue
+ cron_file: cronvar_test
+ register: custom_cronfile1
+
+- name: Add cron var to custom file again
+ cronvar:
+ name: TESTVAR
+ value: somevalue
+ cron_file: cronvar_test
+ register: custom_cronfile2
+
+- name: Check cron var value in custom file
+ command: grep -c TESTVAR=somevalue {{ cron_config_path }}/cronvar_test
+ register: custom_varcheck1
+
+- name: Change cron var in custom file
+ cronvar:
+ name: TESTVAR
+ value: newvalue
+ cron_file: cronvar_test
+ register: custom_cronfile3
+
+- name: Check cron var value in custom file
+ command: grep -c TESTVAR=newvalue {{ cron_config_path }}/cronvar_test
+ register: custom_varcheck2
+
+- name: Remove cron var from custom file
+ cronvar:
+ name: TESTVAR
+ value: newvalue
+ cron_file: cronvar_test
+ state: absent
+ register: custom_remove_cronvar1
+
+- name: Remove cron var from custom file again
+ cronvar:
+ name: TESTVAR
+ value: newvalue
+ cron_file: cronvar_test
+ state: absent
+ register: custom_remove_cronvar2
+
+- name: Check cron var value
+ command: grep -c TESTVAR=newvalue {{ cron_config_path }}/cronvar_test
+ register: custom_varcheck3
+ failed_when: custom_varcheck3.rc == 0
+
+- name: Esure cronvar tasks did the right thing
+ assert:
+ that:
+ - create_cronvar1 is changed
+ - create_cronvar2 is not changed
+ - create_cronvar3 is changed
+ - remove_cronvar1 is changed
+ - remove_cronvar2 is not changed
+ - varcheck1.stdout == '1'
+ - varcheck2.stdout == '1'
+ - varcheck3.stdout == '0'
+ - custom_remove_cronvar1 is changed
+ - custom_remove_cronvar2 is not changed
+ - custom_varcheck1.stdout == '1'
+ - custom_varcheck2.stdout == '1'
+ - custom_varcheck3.stdout == '0'
diff --git a/test/integration/targets/setup_cron/defaults/main.yml b/test/integration/targets/setup_cron/defaults/main.yml
new file mode 100644
index 0000000000..e4b0123da2
--- /dev/null
+++ b/test/integration/targets/setup_cron/defaults/main.yml
@@ -0,0 +1 @@
+remote_dir: "{{ lookup('env', 'OUTPUT_DIR') }}"
diff --git a/test/integration/targets/setup_cron/tasks/main.yml b/test/integration/targets/setup_cron/tasks/main.yml
new file mode 100644
index 0000000000..93dcefa56e
--- /dev/null
+++ b/test/integration/targets/setup_cron/tasks/main.yml
@@ -0,0 +1,70 @@
+- name: Include distribution specific variables
+ include_vars: "{{ lookup('first_found', search) }}"
+ vars:
+ search:
+ files:
+ - '{{ ansible_distribution | lower }}.yml'
+ - '{{ ansible_os_family | lower }}.yml'
+ - '{{ ansible_system | lower }}.yml'
+ - default.yml
+ paths:
+ - vars
+
+- name: install cron package
+ package:
+ name: '{{ cron_pkg }}'
+ when: cron_pkg | default(false, true)
+ register: cron_package_installed
+ until: cron_package_installed is success
+
+- when: faketime_pkg | default(false, true)
+ block:
+ - name: install cron and faketime packages
+ package:
+ name: '{{ faketime_pkg }}'
+ register: faketime_package_installed
+ until: faketime_package_installed is success
+
+ - name: Find libfaketime path
+ shell: '{{ list_pkg_files }} {{ faketime_pkg }} | grep -F libfaketime.so.1'
+ args:
+ warn: false
+ register: libfaketime_path
+
+ - when: ansible_service_mgr == 'systemd'
+ block:
+ - name: create directory for cron drop-in file
+ file:
+ path: '/etc/systemd/system/{{ cron_service }}.service.d'
+ state: directory
+ owner: root
+ group: root
+ mode: 0755
+
+ - name: Use faketime with cron service
+ copy:
+ content: |-
+ [Service]
+ Environment=LD_PRELOAD={{ libfaketime_path.stdout_lines[0].strip() }}
+ Environment="FAKETIME=+0y x10"
+ Environment=RANDOM_DELAY=0
+ dest: '/etc/systemd/system/{{ cron_service }}.service.d/faketime.conf'
+ owner: root
+ group: root
+ mode: 0644
+
+ - when: ansible_system == 'FreeBSD'
+ name: Use faketime with cron service
+ copy:
+ content: |-
+ cron_env='LD_PRELOAD={{ libfaketime_path.stdout_lines[0].strip() }} FAKETIME="+0y x10"'
+ dest: '/etc/rc.conf.d/cron'
+ owner: root
+ group: wheel
+ mode: 0644
+
+- name: enable cron service
+ service:
+ daemon-reload: "{{ (ansible_service_mgr == 'systemd') | ternary(true, omit) }}"
+ name: '{{ cron_service }}'
+ state: restarted
diff --git a/test/integration/targets/setup_cron/vars/debian.yml b/test/integration/targets/setup_cron/vars/debian.yml
new file mode 100644
index 0000000000..cd04871c5d
--- /dev/null
+++ b/test/integration/targets/setup_cron/vars/debian.yml
@@ -0,0 +1,3 @@
+cron_pkg: cron
+cron_service: cron
+list_pkg_files: dpkg -L
diff --git a/test/integration/targets/setup_cron/vars/default.yml b/test/integration/targets/setup_cron/vars/default.yml
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/test/integration/targets/setup_cron/vars/default.yml
diff --git a/test/integration/targets/setup_cron/vars/fedora.yml b/test/integration/targets/setup_cron/vars/fedora.yml
new file mode 100644
index 0000000000..b80a51b54d
--- /dev/null
+++ b/test/integration/targets/setup_cron/vars/fedora.yml
@@ -0,0 +1,3 @@
+cron_pkg: cronie
+cron_service: crond
+list_pkg_files: rpm -ql
diff --git a/test/integration/targets/setup_cron/vars/freebsd.yml b/test/integration/targets/setup_cron/vars/freebsd.yml
new file mode 100644
index 0000000000..41ed449395
--- /dev/null
+++ b/test/integration/targets/setup_cron/vars/freebsd.yml
@@ -0,0 +1,3 @@
+cron_pkg:
+cron_service: cron
+list_pkg_files: pkg info --list-files
diff --git a/test/integration/targets/setup_cron/vars/redhat.yml b/test/integration/targets/setup_cron/vars/redhat.yml
new file mode 100644
index 0000000000..2dff13de09
--- /dev/null
+++ b/test/integration/targets/setup_cron/vars/redhat.yml
@@ -0,0 +1,4 @@
+cron_pkg: cronie
+cron_service: crond
+faketime_pkg:
+list_pkg_files: rpm -ql
diff --git a/test/integration/targets/setup_cron/vars/suse.yml b/test/integration/targets/setup_cron/vars/suse.yml
new file mode 100644
index 0000000000..cd3677a6e8
--- /dev/null
+++ b/test/integration/targets/setup_cron/vars/suse.yml
@@ -0,0 +1,3 @@
+cron_pkg: cron
+cron_service: cron
+list_pkg_files: rpm -ql