cde0158ef0fa89c209ca248b14680ba99f51d295
[puppet-modules/puppetlabs-apt.git] / spec / unit / facter / apt_security_updates_spec.rb
1 require 'spec_helper'
2
3 describe 'apt_security_updates fact' do
4   subject { Facter.fact(:apt_security_updates).value }
5
6   after(:each) { Facter.clear }
7
8   describe 'when apt has no updates' do
9     before(:each) do
10       allow(Facter.fact(:apt_has_updates)).to receive(:value).and_return(false)
11     end
12     it { is_expected.to be nil }
13   end
14
15   describe 'when apt has security updates' do
16     before(:each) do
17       allow(Facter.fact(:osfamily)).to receive(:value).and_return('Debian')
18       allow(File).to receive(:executable?) # Stub all other calls
19       allow(Facter::Util::Resolution).to receive(:exec) # Catch all other calls
20       allow(File).to receive(:executable?).with('/usr/bin/apt-get').and_return(true)
21       allow(Facter::Util::Resolution).to receive(:exec).with('/usr/bin/apt-get -s -o Debug::NoLocking=true upgrade 2>&1').and_return(apt_get_upgrade_output)
22     end
23
24     describe 'on Debian' do
25       let(:apt_get_upgrade_output) do
26         "Inst tzdata [2015f-0+deb8u1] (2015g-0+deb8u1 Debian:stable-updates [all])\n" \
27           "Conf tzdata (2015g-0+deb8u1 Debian:stable-updates [all])\n" \
28           "Inst unhide.rb [13-1.1] (22-2~bpo8+1 Debian Backports:jessie-backports [all])\n" \
29           "Conf unhide.rb (22-2~bpo8+1 Debian Backports:jessie-backports [all])\n" \
30           "Inst curl [7.52.1-5] (7.52.1-5+deb9u2 Debian-Security:9/stable [amd64]) []\n" \
31           "Conf curl (7.52.1-5+deb9u2 Debian-Security:9/stable [amd64])\n" \
32       end
33
34       it { is_expected.to eq(1) }
35     end
36
37     describe 'on Ubuntu' do
38       let(:apt_get_upgrade_output) do
39         "Inst tzdata [2016f-0ubuntu0.16.04] (2016j-0ubuntu0.16.04 Ubuntu:16.04/xenial-security, Ubuntu:16.04/xenial-updates [all])\n" \
40           "Conf tzdata (2016j-0ubuntu0.16.04 Ubuntu:16.04/xenial-security, Ubuntu:16.04/xenial-updates [all])\n" \
41           "Inst curl [7.47.0-1ubuntu2] (7.47.0-1ubuntu2.2 Ubuntu:16.04/xenial-security [amd64]) []\n" \
42           "Conf curl (7.47.0-1ubuntu2.2 Ubuntu:16.04/xenial-security [amd64])\n" \
43           "Inst procps [2:3.3.10-4ubuntu2] (2:3.3.10-4ubuntu2.3 Ubuntu:16.04/xenial-updates [amd64])\n" \
44           "Conf procps (2:3.3.10-4ubuntu2.3 Ubuntu:16.04/xenial-updates [amd64])\n"
45       end
46
47       it { is_expected.to eq(2) }
48     end
49   end
50 end