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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
|
# frozen_string_literal: true
require 'spec_helper_acceptance'
describe 'concat::fragment replace' do
attr_reader :basedir
before(:all) do
@basedir = setup_test_directory
end
describe 'when run should create fragment files' do
let(:pp1) do
<<-MANIFEST
concat { '#{basedir}/foo': }
concat::fragment { '1':
target => '#{basedir}/foo',
content => 'caller has replace unset run 1',
}
MANIFEST
end
let(:pp2) do
<<-MANIFEST
concat { '#{basedir}/foo': }
concat::fragment { '1':
target => '#{basedir}/foo',
content => 'caller has replace unset run 2',
}
MANIFEST
end
it 'applies the manifest twice with no stderr' do
idempotent_apply(pp1)
idempotent_apply(pp2)
expect(file("#{basedir}/foo")).to be_file
expect(file("#{basedir}/foo").content).not_to match 'caller has replace unset run 1'
expect(file("#{basedir}/foo").content).to match 'caller has replace unset run 2'
end
end
# should create fragment files
describe 'when run should replace its own fragment files when caller has File { replace=>true } set' do
let(:pp1) do
<<-MANIFEST
File { replace=>true }
concat { '#{basedir}/foo': }
concat::fragment { '1':
target => '#{basedir}/foo',
content => 'caller has replace true set run 1',
}
MANIFEST
end
let(:pp2) do
<<-MANIFEST
File { replace=>true }
concat { '#{basedir}/foo': }
concat::fragment { '1':
target => '#{basedir}/foo',
content => 'caller has replace true set run 2',
}
MANIFEST
end
it 'applies the manifest twice with no stderr' do
idempotent_apply(pp1)
idempotent_apply(pp2)
expect(file("#{basedir}/foo")).to be_file
expect(file("#{basedir}/foo").content).not_to match 'caller has replace true set run 1'
expect(file("#{basedir}/foo").content).to match 'caller has replace true set run 2'
end
end
# should replace its own fragment files when caller has File(replace=>true) set
describe 'when run should replace its own fragment files even when caller has File { replace=>false } set' do
let(:pp1) do
<<-MANIFEST
File { replace=>false }
concat { '#{basedir}/foo': }
concat::fragment { '1':
target => '#{basedir}/foo',
content => 'caller has replace false set run 1',
}
MANIFEST
end
let(:pp2) do
<<-MANIFEST
File { replace=>false }
concat { '#{basedir}/foo': }
concat::fragment { '1':
target => '#{basedir}/foo',
content => 'caller has replace false set run 2',
}
MANIFEST
end
it 'applies the manifest twice with no stderr' do
idempotent_apply(pp1)
idempotent_apply(pp2)
expect(file("#{basedir}/foo")).to be_file
expect(file("#{basedir}/foo").content).not_to match 'caller has replace false set run 1'
expect(file("#{basedir}/foo").content).to match 'caller has replace false set run 2'
end
end
# should replace its own fragment files even when caller has File(replace=>false) set
end
|