1 # frozen_string_literal: true
5 describe 'apt_has_updates fact' do
6 subject { Facter.fact(:apt_has_updates).value }
8 before(:each) { Facter.clear }
10 describe 'on non-Debian distro' do
12 allow(Facter.fact(:osfamily)).to receive(:value).once.and_return('Redhat')
15 it { is_expected.to be_nil }
18 describe 'on Debian based distro missing apt-get' do
20 allow(Facter.fact(:osfamily)).to receive(:value).once.and_return('Debian')
21 allow(File).to receive(:executable?) # Stub all other calls
22 allow(File).to receive(:executable?).with('/usr/bin/apt-get').and_return(false)
25 it { is_expected.to be_nil }
28 describe 'on Debian based distro' do
30 allow(Facter.fact(:osfamily)).to receive(:value).and_return('Debian')
31 allow(File).to receive(:executable?) # Stub all other calls
32 allow(Facter::Core::Execution).to receive(:execute) # Catch all other calls
33 allow(File).to receive(:executable?).with('/usr/bin/apt-get').and_return(true)
34 apt_output = "Inst tzdata [2015f-0+deb8u1] (2015g-0+deb8u1 Debian:stable-updates [all])\n" \
35 "Conf tzdata (2015g-0+deb8u1 Debian:stable-updates [all])\n" \
36 "Inst unhide.rb [13-1.1] (22-2~bpo8+1 Debian Backports:-backports [all])\n" \
37 "Conf unhide.rb (22-2~bpo8+1 Debian Backports:-backports [all])\n"
38 allow(Facter::Core::Execution).to receive(:execute).with('/usr/bin/apt-get -s -o Debug::NoLocking=true upgrade 2>&1').and_return(apt_output)
41 it { is_expected.to be true }