describe Nanoc::Int::OutdatednessStore do subject(:store) { described_class.new(site: site, reps: reps) } let(:site) { double(:site) } let(:reps) { Nanoc::Int::ItemRepRepo.new } let(:item) { Nanoc::Int::Item.new('foo', {}, '/foo.md') } let(:rep) { Nanoc::Int::ItemRep.new(item, :foo) } let(:site) do Nanoc::Int::Site.new( config: config, code_snippets: code_snippets, items: items, layouts: layouts, ) end let(:config) { Nanoc::Int::Configuration.new.with_defaults } let(:items) { [] } let(:layouts) { [] } let(:code_snippets) { [] } describe '#include?, #add and #remove' do subject { store.include?(rep) } context 'nothing added' do it { is_expected.not_to be } end context 'rep added' do before { store.add(rep) } it { is_expected.to be } end context 'rep added and removed' do before do store.add(rep) store.remove(rep) end it { is_expected.not_to be } end context 'rep added, removed, and added again' do before do store.add(rep) store.remove(rep) store.add(rep) end it { is_expected.to be } end end describe '#to_a' do subject { store.to_a } context 'nothing added' do it { is_expected.to be_empty } end context 'one rep added' do before { store.add(rep) } it { is_expected.to eql([rep]) } end end describe 'reloading' do subject do store.store store.load store.include?(rep) end context 'not added' do context 'rep part of new reps' do before { reps << rep } it { is_expected.not_to be } end context 'rep not part of new reps' do it { is_expected.not_to be } end end context 'added' do before { store.add(rep) } context 'rep part of new reps' do before { reps << rep } it { is_expected.to be } end context 'rep not part of new reps' do it { is_expected.not_to be } end end end end