Extract component to render poll geozones
This way we remove a bit of duplication. These changes also affect the way geozones are rendered in a couple of minor ways, making them more consistent: * No empty list of geozones is rendered when there are no geozones (before these changes, an empty list was rendered in the index action but not in the show action) * The text clarifying the geozone restriction is always shown (before these changes, it was shown in the index action but not in the show action) We've added tests for these cases.
This commit is contained in:
@@ -63,6 +63,20 @@ describe Polls::PollComponent do
|
||||
end
|
||||
end
|
||||
|
||||
describe "geozones" do
|
||||
it "renders a list of geozones when the poll is geozone-restricted" do
|
||||
render_inline Polls::PollComponent.new(create(:poll, geozone_restricted_to: [create(:geozone)]))
|
||||
|
||||
expect(page).to have_css ".tags"
|
||||
end
|
||||
|
||||
it "does not render a list of geozones when the poll isn't geozone-restricted" do
|
||||
render_inline Polls::PollComponent.new(create(:poll))
|
||||
|
||||
expect(page).not_to have_css ".tags"
|
||||
end
|
||||
end
|
||||
|
||||
it "shows a link to poll stats if enabled" do
|
||||
poll = create(:poll, :expired, name: "Poll with stats", stats_enabled: true)
|
||||
|
||||
|
||||
17
spec/components/polls/poll_header_component_spec.rb
Normal file
17
spec/components/polls/poll_header_component_spec.rb
Normal file
@@ -0,0 +1,17 @@
|
||||
require "rails_helper"
|
||||
|
||||
describe Polls::PollHeaderComponent do
|
||||
describe "geozones" do
|
||||
it "shows a text when the poll is geozone-restricted" do
|
||||
render_inline Polls::PollHeaderComponent.new(create(:poll, geozone_restricted_to: [create(:geozone)]))
|
||||
|
||||
expect(page).to have_content "Only residents in the following areas can participate"
|
||||
end
|
||||
|
||||
it "does not show the text when the poll isn't geozone-restricted" do
|
||||
render_inline Polls::PollHeaderComponent.new(create(:poll))
|
||||
|
||||
expect(page).not_to have_content "Only residents in the following areas can participate"
|
||||
end
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user