brew/Library/Homebrew/test/cache_store_spec.rb

144 lines
3.9 KiB
Ruby
Raw Normal View History

require "cache_store"
describe CacheStoreDatabase do
2018-09-20 09:07:56 +01:00
subject { described_class.new(:sample) }
describe "self.use" do
let(:type) { :test }
2018-05-22 15:31:58 -04:00
it "creates a new `DatabaseCache` instance" do
cache_store = double("cache_store", close_if_open!: nil)
2018-09-20 09:07:56 +01:00
expect(described_class).to receive(:new).with(type).and_return(cache_store)
2018-05-22 15:31:58 -04:00
expect(cache_store).to receive(:close_if_open!)
2018-09-20 09:07:56 +01:00
described_class.use(type) { |_db| }
end
end
describe "#set" do
let(:db) { double("db", :[]= => nil) }
2018-09-20 09:07:56 +01:00
before do
allow(File).to receive(:write)
allow(subject).to receive(:created?).and_return(true)
expect(db).to receive(:has_key?).with(:foo).and_return(false)
2018-05-25 23:19:13 +02:00
allow(subject).to receive(:db).and_return(db)
end
it "sets the value in the `CacheStoreDatabase`" do
2018-09-20 09:07:56 +01:00
expect(db).not_to have_key(:foo)
subject.set(:foo, "bar")
end
end
describe "#get" do
context "database created" do
let(:db) { double("db", :[] => "bar") }
2018-09-20 09:07:56 +01:00
before do
allow(subject).to receive(:created?).and_return(true)
expect(db).to receive(:has_key?).with(:foo).and_return(true)
2018-05-25 23:19:13 +02:00
allow(subject).to receive(:db).and_return(db)
end
it "gets value in the `CacheStoreDatabase` corresponding to the key" do
expect(db).to have_key(:foo)
2018-05-22 15:31:58 -04:00
expect(subject.get(:foo)).to eq("bar")
end
end
context "database not created" do
let(:db) { double("db", :[] => nil) }
2018-09-20 09:07:56 +01:00
before do
allow(subject).to receive(:created?).and_return(false)
2018-05-25 23:19:13 +02:00
allow(subject).to receive(:db).and_return(db)
end
it "does not get value in the `CacheStoreDatabase` corresponding to key" do
2018-09-20 09:07:56 +01:00
expect(subject.get(:foo)).not_to be("bar")
end
it "does not call `db[]` if `CacheStoreDatabase.created?` is `false`" do
expect(db).not_to receive(:[])
subject.get(:foo)
end
end
end
describe "#delete" do
context "database created" do
let(:db) { double("db", :[] => { foo: "bar" }) }
2018-09-20 09:07:56 +01:00
before do
allow(subject).to receive(:created?).and_return(true)
2018-05-25 23:19:13 +02:00
allow(subject).to receive(:db).and_return(db)
end
it "deletes value in the `CacheStoreDatabase` corresponding to the key" do
expect(db).to receive(:delete).with(:foo)
subject.delete(:foo)
end
end
context "database not created" do
let(:db) { double("db", delete: nil) }
2018-09-20 09:07:56 +01:00
before do
allow(subject).to receive(:created?).and_return(false)
2018-05-25 23:19:13 +02:00
allow(subject).to receive(:db).and_return(db)
end
it "does not call `db.delete` if `CacheStoreDatabase.created?` is `false`" do
expect(db).not_to receive(:delete)
subject.delete(:foo)
end
end
end
describe "#close_if_open!" do
context "database open" do
it "does not raise an error when `close` is called on the database" do
2018-09-20 09:07:56 +01:00
expect { subject.close_if_open! }.not_to raise_error(NoMethodError)
end
end
context "database not open" do
2018-09-20 09:07:56 +01:00
before do
subject.instance_variable_set(:@db, nil)
end
it "does not raise an error when `close` is called on the database" do
2018-09-20 09:07:56 +01:00
expect { subject.close_if_open! }.not_to raise_error(NoMethodError)
end
end
end
describe "#created?" do
let(:cache_path) { Pathname("path/to/homebrew/cache/sample.json") }
2018-09-20 09:07:56 +01:00
before do
2018-05-25 23:19:13 +02:00
allow(subject).to receive(:cache_path).and_return(cache_path)
end
context "`cache_path.exist?` returns `true`" do
2018-09-20 09:07:56 +01:00
before do
allow(cache_path).to receive(:exist?).and_return(true)
end
it "returns `true`" do
expect(subject.created?).to be(true)
end
end
context "`cache_path.exist?` returns `false`" do
2018-09-20 09:07:56 +01:00
before do
allow(cache_path).to receive(:exist?).and_return(false)
end
it "returns `false`" do
expect(subject.created?).to be(false)
end
end
end
end