2015-07-21 19:45:23 +02:00

46 lines
1.6 KiB
Ruby

require File.expand_path('../support/helpers', __FILE__)
describe_recipe 'unattended-upgrades::default' do
include Helpers::Unattended_upgrades
describe 'packages' do
it 'installs unattended-upgrades' do
package("unattended-upgrades").must_be_installed
end
end
describe 'files' do
let(:config) { file("/etc/apt/apt.conf.d/50unattended-upgrades") }
let(:autoconfig) { file("/etc/apt/apt.conf.d/20auto-upgrades") }
it 'should have correct file permissions' do
config.must_have(:mode, "644")
autoconfig.must_have(:mode, "644")
end
it 'should have correct owner' do
config.must_have(:owner, "root")
autoconfig.must_have(:owner, "root")
end
it 'should have correct group' do
config.must_have(:group, "root")
autoconfig.must_have(:group, "root")
end
it 'should contain the correct config' do
config.must_include "Unattended-Upgrade::Mail \"#{node['unattended-upgrades']['admin_email']}\";"
end
it 'should contain the security updates origin' do
# Although this test may fail on a setup with minitest-handler running on a live server - security updates really shouldn't be turned off
config.must_include '"${distro_id}:${distro_codename}-security";'
end
it 'should run unattended upgrades according to the schedule' do
# Test might fail if unattended upgrades is disabled via run interval setting - but why run this test if the software is turned off?
autoconfig.must_include "APT::Periodic::Unattended-Upgrade \"#{node['unattended-upgrades']['upgrade_interval']}\";"
end
end
end