1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
test_name "puppet should update existing crontab entry"
confine :except, :platform => 'windows'
confine :except, :platform => /^eos-/ # See PUP-5500
confine :except, :platform => /^fedora-28/
tag 'audit:medium',
'audit:refactor', # Use block style `test_name`
'audit:acceptance' # Could be done at the integration (or unit) layer though
# actual changing of resources could irreparably damage a
# host running this, or require special permissions.
require 'puppet/acceptance/common_utils'
extend Puppet::Acceptance::CronUtils
teardown do
step "Cron: cleanup"
agents.each do |agent|
clean agent
end
end
agents.each do |host|
step "ensure the user exist via puppet"
setup host
step "create the existing job by hand..."
run_cron_on(host,:add,'tstuser',"* * * * * /bin/true")
step "verify that crontab -l contains what you expected"
run_cron_on(host,:list,'tstuser') do
assert_match(/\* \* \* \* \* \/bin\/true/, stdout, "Didn't find correct crobtab entry for tstuser on #{host}")
end
step "apply the resource change on the host"
on(host, puppet_resource("cron", "crontest", "user=tstuser", "command=/bin/true", "ensure=present", "hour='0-6'")) do
assert_match(/hour\s+=>\s+\['0-6'\]/, stdout, "Modifying cron entry failed for tstuser on #{host}")
end
step "verify that crontab -l contains what you expected"
run_cron_on(host,:list,'tstuser') do
assert_match(/\* 0-6 \* \* \* \/bin\/true/, stdout, "Didn't find correctly modified time entry in crobtab entry for tstuser on #{host}")
end
end
|