aboutsummaryrefslogtreecommitdiff
path: root/spec/acceptance/tests/resource/cron/should_remove_leading_and_trailing_whitespace.rb
blob: b643156c30d6c2318f421fdc86559a67bd546965 (plain)
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 '(#656) leading and trailing whitespace in cron entries should should be stripped'
confine :except, platform: 'windows'
confine :except, platform: %r{^eos-} # See PUP-5500
confine :except, platform: %r{^fedora-28}
tag 'audit:medium',
    'audit:refactor', # Use block style `test_name`
    'audit:unit'

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 'create user account for testing cron entries'
  setup host

  step 'apply the resource on the host using puppet resource'
  on(host, puppet_resource('cron', 'crontest', 'user=tstuser', "command='   date > /dev/null    '", 'ensure=present')) do
    assert_match(%r{created}, stdout, "Did not create crontab for tstuser on #{host}")
  end

  step 'verify the added crontab entry has stripped whitespace'
  run_cron_on(host, :list, 'tstuser') do
    assert_match(%r{\* \* \* \* \* date > .dev.null}, stdout, "Incorrect crontab for tstuser on #{host}")
  end

  step 'apply the resource with trailing whitespace and check nothing happened'
  on(host, puppet_resource('cron', 'crontest', 'user=tstuser', "command='date > /dev/null    '", 'ensure=present')) do
    assert_no_match(%r{ensure: created}, stdout, "Rewrote the line with trailing space in crontab for tstuser on #{host}")
  end

  step 'apply the resource with leading whitespace and check nothing happened'
  on(host, puppet_resource('cron', 'crontest', 'user=tstuser', "command='     date > /dev/null'", 'ensure=present')) do
    assert_no_match(%r{ensure: created}, stdout, "Rewrote the line with trailing space in crontab for tstuser on #{host}")
  end
end