To be consistent about before/after arguments, as `:each` or `:example` are same and default scopes, best not to send an argument in those scenarios. Read about cop at http://www.rubydoc.info/gems/rubocop-rspec/RuboCop/Cop/RSpec/HookArgument
67 lines
1.4 KiB
Ruby
67 lines
1.4 KiB
Ruby
shared_examples "map validations" do
|
|
|
|
let(:mappable) { build(model_name(described_class)) }
|
|
|
|
describe "validations" do
|
|
|
|
before do
|
|
Setting["feature.map"] = true
|
|
end
|
|
|
|
after do
|
|
Setting["feature.map"] = nil
|
|
end
|
|
|
|
it "is valid with a map location" do
|
|
mappable.map_location = build(:map_location)
|
|
mappable.skip_map = nil
|
|
|
|
expect(mappable).to be_valid
|
|
end
|
|
|
|
it "is valid accepting that the mappable has no map" do
|
|
mappable.skip_map = "1"
|
|
mappable.map_location = nil
|
|
|
|
expect(mappable).to be_valid
|
|
end
|
|
|
|
it "is valid when the feature map is deactivated" do
|
|
Setting["feature.map"] = nil
|
|
|
|
mappable.map_location = nil
|
|
mappable.skip_map = nil
|
|
|
|
expect(mappable).to be_valid
|
|
end
|
|
|
|
it "is not valid without a map location" do
|
|
mappable.map_location = nil
|
|
mappable.skip_map = nil
|
|
|
|
expect(mappable).to_not be_valid
|
|
end
|
|
|
|
it "is not valid without accepting that the mappable has no map" do
|
|
mappable.skip_map = nil
|
|
|
|
expect(mappable).to_not be_valid
|
|
end
|
|
|
|
end
|
|
|
|
describe "cache" do
|
|
|
|
it "expires cache when the map is updated" do
|
|
map_location = create(:map_location)
|
|
mappable.map_location = map_location
|
|
mappable.save
|
|
|
|
expect { map_location.update(latitude: 12.34) }
|
|
.to change { mappable.reload.updated_at }
|
|
end
|
|
|
|
end
|
|
|
|
end
|