mirror of https://github.com/ansible/ansible.git
cronvar - use correct binary name (#63279)
Fixes regression introduced by #62554 Add integration tests for cronvarpull/63311/head
parent
ce402f003f
commit
9d014778ad
@ -0,0 +1,2 @@
|
|||||||
|
bugfixes:
|
||||||
|
- cronvar - use correct binary name (https://github.com/ansible/ansible/issues/63274)
|
||||||
@ -1,2 +1 @@
|
|||||||
---
|
|
||||||
faketime_pkg: libfaketime
|
faketime_pkg: libfaketime
|
||||||
|
|||||||
@ -0,0 +1,2 @@
|
|||||||
|
dependencies:
|
||||||
|
- setup_cron
|
||||||
@ -1,173 +1,101 @@
|
|||||||
- include_vars: "{{ lookup('first_found', search) }}"
|
- name: add cron task (check mode enabled, cron task not already created)
|
||||||
vars:
|
cron:
|
||||||
search:
|
name: test cron task
|
||||||
files:
|
job: 'date > {{ remote_dir }}/cron_canary1'
|
||||||
- 'cron.{{ ansible_system | lower }}.yml'
|
check_mode: yes
|
||||||
- 'cron.{{ ansible_distribution | lower }}.yml'
|
register: check_mode_enabled_state_present
|
||||||
- 'cron.{{ ansible_os_family | lower }}.yml'
|
|
||||||
paths:
|
- assert:
|
||||||
- '../defaults/'
|
that: check_mode_enabled_state_present is changed
|
||||||
|
|
||||||
- vars:
|
- name: add cron task (check mode disabled, task hasn't already been created)
|
||||||
remote_dir: "{{ lookup('env', 'OUTPUT_DIR') }}"
|
cron:
|
||||||
block:
|
name: test cron task
|
||||||
- name: install cron package
|
job: 'date > {{ remote_dir }}/cron_canary1'
|
||||||
package:
|
register: add_cron_task
|
||||||
name: '{{ cron_pkg }}'
|
|
||||||
when: cron_pkg|default(false, true)
|
- assert:
|
||||||
register: cron_package_installed
|
that: add_cron_task is changed
|
||||||
until: cron_package_installed is success
|
|
||||||
|
- name: add cron task (check mode enabled, cron task already exists)
|
||||||
- when: faketime_pkg|default(false, true)
|
cron:
|
||||||
block:
|
name: test cron task
|
||||||
- name: install cron and faketime packages
|
job: 'date > {{ remote_dir }}/cron_canary1'
|
||||||
package:
|
check_mode: yes
|
||||||
name: '{{ faketime_pkg }}'
|
register: check_mode_enabled_state_present_cron_task_already_exists
|
||||||
register: faketime_package_installed
|
|
||||||
until: faketime_package_installed is success
|
- assert:
|
||||||
|
that: check_mode_enabled_state_present_cron_task_already_exists is not changed
|
||||||
- name: Find libfaketime path
|
|
||||||
shell: '{{ list_pkg_files }} {{ faketime_pkg }} | grep -F libfaketime.so.1'
|
- name: add cron task (check mode disabled, cron task already created)
|
||||||
args:
|
cron:
|
||||||
warn: false
|
name: test cron task
|
||||||
register: libfaketime_path
|
job: 'date > {{ remote_dir }}/cron_canary1'
|
||||||
|
register: cron_task_already_created
|
||||||
- when: ansible_service_mgr == 'systemd'
|
|
||||||
block:
|
- assert:
|
||||||
- name: create directory for cron drop-in file
|
that: cron_task_already_created is not changed
|
||||||
file:
|
|
||||||
path: '/etc/systemd/system/{{ cron_service }}.service.d'
|
- block:
|
||||||
state: directory
|
- name: wait for canary creation
|
||||||
owner: root
|
wait_for:
|
||||||
group: root
|
path: '{{ remote_dir }}/cron_canary1'
|
||||||
mode: 0755
|
timeout: '{{ 20 if faketime_pkg else 70 }}'
|
||||||
|
register: wait_canary
|
||||||
- name: Use faketime with cron service
|
always:
|
||||||
copy:
|
- name: display some logs in case of failure
|
||||||
content: |-
|
command: 'journalctl -u {{ cron_service }}'
|
||||||
[Service]
|
when: wait_canary is failed and ansible_service_mgr == 'systemd'
|
||||||
Environment=LD_PRELOAD={{ libfaketime_path.stdout_lines[0].strip() }}
|
|
||||||
Environment="FAKETIME=+0y x10"
|
- debug:
|
||||||
Environment=RANDOM_DELAY=0
|
msg: 'elapsed time waiting for canary: {{ wait_canary.elapsed }}'
|
||||||
dest: '/etc/systemd/system/{{ cron_service }}.service.d/faketime.conf'
|
|
||||||
owner: root
|
- name: Check check_mode
|
||||||
group: root
|
cron:
|
||||||
mode: 0644
|
name: test cron task
|
||||||
|
job: 'date > {{ remote_dir }}/cron_canary1'
|
||||||
- when: ansible_system == 'FreeBSD'
|
state: absent
|
||||||
name: Use faketime with cron service
|
check_mode: yes
|
||||||
copy:
|
register: check_check_mode
|
||||||
content: |-
|
|
||||||
cron_env='LD_PRELOAD={{ libfaketime_path.stdout_lines[0].strip() }} FAKETIME="+0y x10"'
|
- assert:
|
||||||
dest: '/etc/rc.conf.d/cron'
|
that: check_check_mode is changed
|
||||||
owner: root
|
|
||||||
group: wheel
|
- name: Remove a cron task
|
||||||
mode: 0644
|
cron:
|
||||||
|
name: test cron task
|
||||||
- name: enable cron service
|
job: 'date > {{ remote_dir }}/cron_canary1'
|
||||||
service:
|
state: absent
|
||||||
daemon-reload: "{{ (ansible_service_mgr == 'systemd')|ternary(true, omit) }}"
|
register: remove_task
|
||||||
name: '{{ cron_service }}'
|
|
||||||
state: restarted
|
- assert:
|
||||||
|
that: remove_task is changed
|
||||||
- name: add cron task (check mode enabled, cron task not already created)
|
|
||||||
cron:
|
- name: 'cron task missing: check idempotence (check mode enabled, state=absent)'
|
||||||
name: test cron task
|
cron:
|
||||||
job: 'date > {{ remote_dir }}/cron_canary1'
|
name: test cron task
|
||||||
check_mode: yes
|
job: 'date > {{ remote_dir }}/cron_canary1'
|
||||||
register: check_mode_enabled_state_present
|
state: absent
|
||||||
|
register: check_mode_enabled_remove_task_idempotence
|
||||||
- assert:
|
|
||||||
that: check_mode_enabled_state_present is changed
|
- assert:
|
||||||
|
that: check_mode_enabled_remove_task_idempotence is not changed
|
||||||
- name: add cron task (check mode disabled, task hasn't already been created)
|
|
||||||
cron:
|
- name: 'cron task missing: check idempotence (check mode disabled, state=absent)'
|
||||||
name: test cron task
|
cron:
|
||||||
job: 'date > {{ remote_dir }}/cron_canary1'
|
name: test cron task
|
||||||
register: add_cron_task
|
job: 'date > {{ remote_dir }}/cron_canary1'
|
||||||
|
state: absent
|
||||||
- assert:
|
register: remove_task_idempotence
|
||||||
that: add_cron_task is changed
|
|
||||||
|
- assert:
|
||||||
- name: add cron task (check mode enabled, cron task already exists)
|
that: remove_task_idempotence is not changed
|
||||||
cron:
|
|
||||||
name: test cron task
|
- name: Check that removing a cron task with cron_file and without specifying an user is allowed (#58493)
|
||||||
job: 'date > {{ remote_dir }}/cron_canary1'
|
cron:
|
||||||
check_mode: yes
|
cron_file: unexistent_cron_file
|
||||||
register: check_mode_enabled_state_present_cron_task_already_exists
|
state: absent
|
||||||
|
register: remove_cron_file
|
||||||
- assert:
|
|
||||||
that: check_mode_enabled_state_present_cron_task_already_exists is not changed
|
- assert:
|
||||||
|
that: remove_cron_file 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
|
|
||||||
|
|||||||
@ -0,0 +1,3 @@
|
|||||||
|
destructive
|
||||||
|
shippable/posix/group4
|
||||||
|
skip/osx
|
||||||
@ -0,0 +1 @@
|
|||||||
|
cron_config_path: /etc/cron.d
|
||||||
@ -0,0 +1,2 @@
|
|||||||
|
dependencies:
|
||||||
|
- setup_cron
|
||||||
@ -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'
|
||||||
@ -0,0 +1 @@
|
|||||||
|
remote_dir: "{{ lookup('env', 'OUTPUT_DIR') }}"
|
||||||
@ -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
|
||||||
@ -1,4 +1,3 @@
|
|||||||
---
|
|
||||||
cron_pkg: cron
|
cron_pkg: cron
|
||||||
cron_service: cron
|
cron_service: cron
|
||||||
list_pkg_files: dpkg -L
|
list_pkg_files: dpkg -L
|
||||||
@ -1,4 +1,3 @@
|
|||||||
---
|
|
||||||
cron_pkg: cronie
|
cron_pkg: cronie
|
||||||
cron_service: crond
|
cron_service: crond
|
||||||
list_pkg_files: rpm -ql
|
list_pkg_files: rpm -ql
|
||||||
@ -1,4 +1,3 @@
|
|||||||
---
|
|
||||||
cron_pkg:
|
cron_pkg:
|
||||||
cron_service: cron
|
cron_service: cron
|
||||||
list_pkg_files: pkg info --list-files
|
list_pkg_files: pkg info --list-files
|
||||||
@ -1,4 +1,3 @@
|
|||||||
---
|
|
||||||
cron_pkg: cronie
|
cron_pkg: cronie
|
||||||
cron_service: crond
|
cron_service: crond
|
||||||
faketime_pkg:
|
faketime_pkg:
|
||||||
@ -1,4 +1,3 @@
|
|||||||
---
|
|
||||||
cron_pkg: cron
|
cron_pkg: cron
|
||||||
cron_service: cron
|
cron_service: cron
|
||||||
list_pkg_files: rpm -ql
|
list_pkg_files: rpm -ql
|
||||||
Loading…
Reference in New Issue