aboutsummaryrefslogtreecommitdiff
path: root/spec/acceptance/tests/resource/cron/should_remove_cron.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/acceptance/tests/resource/cron/should_remove_cron.rb')
-rw-r--r--spec/acceptance/tests/resource/cron/should_remove_cron.rb39
1 files changed, 39 insertions, 0 deletions
diff --git a/spec/acceptance/tests/resource/cron/should_remove_cron.rb b/spec/acceptance/tests/resource/cron/should_remove_cron.rb
new file mode 100644
index 0000000..1320272
--- /dev/null
+++ b/spec/acceptance/tests/resource/cron/should_remove_cron.rb
@@ -0,0 +1,39 @@
+test_name "puppet should remove a crontab entry as expected"
+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 "apply the resource on the host using puppet resource"
+ on(host, puppet_resource("cron", "crontest", "user=tstuser",
+ "command=/bin/true", "ensure=absent")) do
+ assert_match(/crontest\D+ensure:\s+removed/, stdout, "Didn't remove crobtab entry for tstuser on #{host}")
+ end
+
+ step "verify that crontab -l contains what you expected"
+ run_cron_on(host, :list, 'tstuser') do
+ assert_no_match(/\/bin\/true/, stderr, "Error: Found entry for tstuser on #{host}")
+ end
+
+end