Files
nairobi/spec/shared/models/map_validations.rb
Bertocq ed16a78f42 Enables RSpec/ExampleWording and fixes all issues
Both avoiding 'should' and repiting 'it' on the tests description
improves reading them and also makes all descriptions consistent.

Read about cop at http://www.rubydoc.info/gems/rubocop-rspec/RuboCop/Cop/RSpec/ExampleWording
2018-01-07 01:03:45 +01:00

67 lines
1.4 KiB
Ruby

shared_examples "map validations" do
let(:mappable) { build(model_name(described_class)) }
describe "validations" do
before(:each) do
Setting["feature.map"] = true
end
after(:each) 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