125 lines
4.8 KiB
Ruby
125 lines
4.8 KiB
Ruby
shared_examples "relationable" do |relationable_model_name|
|
|
|
|
let(:relationable) { create(relationable_model_name) }
|
|
let(:related1) { create([:proposal, :debate].sample) }
|
|
let(:related2) { create([:proposal, :debate].sample) }
|
|
let(:user) { create(:user) }
|
|
|
|
scenario 'related contents are listed' do
|
|
related_content = create(:related_content, parent_relationable: relationable, child_relationable: related1, author: build(:user))
|
|
|
|
visit eval("#{relationable.class.name.downcase}_path(relationable)")
|
|
within("#related-content-list") do
|
|
expect(page).to have_content(related1.title)
|
|
end
|
|
|
|
visit eval("#{related1.class.name.downcase}_path(related1)")
|
|
within("#related-content-list") do
|
|
expect(page).to have_content(relationable.title)
|
|
end
|
|
end
|
|
|
|
scenario 'related contents list is not rendered if there are no relations' do
|
|
visit eval("#{relationable.class.name.downcase}_path(relationable)")
|
|
expect(page).to_not have_css("#related-content-list")
|
|
end
|
|
|
|
scenario 'related contents can be added' do
|
|
login_as(user)
|
|
visit eval("#{relationable.class.name.downcase}_path(relationable)")
|
|
|
|
expect(page).to have_selector('#related_content', visible: false)
|
|
click_on("Add related content")
|
|
expect(page).to have_selector('#related_content', visible: true)
|
|
|
|
within("#related_content") do
|
|
fill_in 'url', with: "#{Setting['url']}/#{related1.class.name.downcase.pluralize}/#{related1.to_param}"
|
|
click_button "Add"
|
|
end
|
|
|
|
within("#related-content-list") do
|
|
expect(page).to have_content(related1.title)
|
|
end
|
|
|
|
visit eval("#{related1.class.name.downcase}_path(related1)")
|
|
|
|
within("#related-content-list") do
|
|
expect(page).to have_content(relationable.title)
|
|
end
|
|
|
|
within("#related_content") do
|
|
fill_in 'url', with: "#{Setting['url']}/#{related2.class.name.downcase.pluralize}/#{related2.to_param}"
|
|
click_button "Add"
|
|
end
|
|
|
|
within("#related-content-list") do
|
|
expect(page).to have_content(related2.title)
|
|
end
|
|
end
|
|
|
|
scenario 'if related content URL is invalid returns error' do
|
|
login_as(user)
|
|
visit eval("#{relationable.class.name.downcase}_path(relationable)")
|
|
|
|
click_on("Add related content")
|
|
|
|
within("#related_content") do
|
|
fill_in 'url', with: "http://invalidurl.com"
|
|
click_button "Add"
|
|
end
|
|
|
|
expect(page).to have_content("Link not valid. Remember to start with #{Setting[:url]}.")
|
|
end
|
|
|
|
scenario 'related content can be scored positively', :js do
|
|
related_content = create(:related_content, parent_relationable: relationable, child_relationable: related1, author: build(:user))
|
|
|
|
login_as(user)
|
|
visit eval("#{relationable.class.name.downcase}_path(relationable)")
|
|
|
|
within("#related-content-list") do
|
|
find("#related-content-#{related_content.opposite_related_content.id}").hover
|
|
find("#score-positive-related-#{related_content.opposite_related_content.id}").click
|
|
expect(page).to_not have_css("#score-positive-related-#{related_content.opposite_related_content.id}")
|
|
end
|
|
|
|
expect(related_content.related_content_scores.find_by(user_id: user.id, related_content_id: related_content.id).value).to eq(1)
|
|
expect(related_content.opposite_related_content.related_content_scores.find_by(user_id: user.id, related_content_id: related_content.opposite_related_content.id).value).to eq(1)
|
|
|
|
end
|
|
|
|
scenario 'related content can be scored negatively', :js do
|
|
related_content = create(:related_content, parent_relationable: relationable, child_relationable: related1, author: build(:user))
|
|
|
|
login_as(user)
|
|
visit eval("#{relationable.class.name.downcase}_path(relationable)")
|
|
|
|
within("#related-content-list") do
|
|
find("#related-content-#{related_content.opposite_related_content.id}").hover
|
|
find("#score-negative-related-#{related_content.opposite_related_content.id}").click
|
|
expect(page).to_not have_css("#score-negative-related-#{related_content.opposite_related_content.id}")
|
|
end
|
|
|
|
expect(related_content.related_content_scores.find_by(user_id: user.id, related_content_id: related_content.id).value).to eq(-1)
|
|
expect(related_content.opposite_related_content.related_content_scores.find_by(user_id: user.id, related_content_id: related_content.opposite_related_content.id).value).to eq(-1)
|
|
end
|
|
|
|
scenario 'if related content has negative score it will be hidden' do
|
|
related_content = create(:related_content, parent_relationable: relationable, child_relationable: related1, author: build(:user))
|
|
|
|
2.times do
|
|
related_content.send("score_positive", build(:user))
|
|
end
|
|
|
|
6.times do
|
|
related_content.send("score_negative", build(:user))
|
|
end
|
|
|
|
login_as(user)
|
|
|
|
visit eval("#{relationable.class.name.downcase}_path(relationable)")
|
|
|
|
expect(page).to_not have_css("#related-content-list")
|
|
end
|
|
end
|