The user experience with JavaScript enabled is actually very bad; there's a usability issue here because it's impossible to change an answer once a "radio button" is selected, which goes against the standard practice on basically any HTML form. Issue 4123 already mentions this problem. Until we fix it, we're disabling JavaScript in these tests.
116 lines
3.9 KiB
Ruby
116 lines
3.9 KiB
Ruby
require "rails_helper"
|
|
|
|
describe "Legislation" do
|
|
context "process debate page" do
|
|
let(:process) do
|
|
create(:legislation_process,
|
|
debate_start_date: Date.current - 3.days,
|
|
debate_end_date: Date.current + 2.days)
|
|
end
|
|
|
|
before do
|
|
create(:legislation_question, process: process, title: "Question 1")
|
|
create(:legislation_question, process: process, title: "Question 2")
|
|
create(:legislation_question, process: process, title: "Question 3")
|
|
end
|
|
|
|
scenario "shows question list" do
|
|
visit legislation_process_path(process)
|
|
|
|
expect(page).to have_content("Participate in the debate")
|
|
|
|
expect(page).to have_content("Question 1")
|
|
expect(page).to have_content("Question 2")
|
|
expect(page).to have_content("Question 3")
|
|
|
|
click_link "Question 1"
|
|
|
|
expect(page).to have_content("Question 1")
|
|
expect(page).to have_content("Next question")
|
|
|
|
click_link "Next question"
|
|
|
|
expect(page).to have_content("Question 2")
|
|
expect(page).to have_content("Next question")
|
|
|
|
click_link "Next question"
|
|
|
|
expect(page).to have_content("Question 3")
|
|
expect(page).not_to have_content("Next question")
|
|
end
|
|
|
|
scenario "shows question page" do
|
|
visit legislation_process_question_path(process, process.questions.first)
|
|
|
|
expect(page).to have_content("Question 1")
|
|
expect(page).to have_content("Open answers (0)")
|
|
end
|
|
|
|
scenario "shows next question link in question page" do
|
|
visit legislation_process_question_path(process, process.questions.first)
|
|
|
|
expect(page).to have_content("Question 1")
|
|
expect(page).to have_content("Next question")
|
|
|
|
click_link "Next question"
|
|
|
|
expect(page).to have_content("Question 2")
|
|
expect(page).to have_content("Next question")
|
|
|
|
click_link "Next question"
|
|
|
|
expect(page).to have_content("Question 3")
|
|
expect(page).not_to have_content("Next question")
|
|
end
|
|
|
|
scenario "answer question", :no_js do
|
|
question = process.questions.first
|
|
create(:legislation_question_option, question: question, value: "Yes")
|
|
create(:legislation_question_option, question: question, value: "No")
|
|
option = create(:legislation_question_option, question: question, value: "I don't know")
|
|
user = create(:user, :level_two)
|
|
|
|
login_as(user)
|
|
|
|
visit legislation_process_question_path(process, question)
|
|
|
|
expect(page).to have_selector(:radio_button, "Yes")
|
|
expect(page).to have_selector(:radio_button, "No")
|
|
expect(page).to have_selector(:radio_button, "I don't know")
|
|
expect(page).to have_selector(:link_or_button, "Submit answer")
|
|
|
|
choose("I don't know")
|
|
click_button "Submit answer"
|
|
|
|
within(:css, "label.is-active") do
|
|
expect(page).to have_content("I don't know")
|
|
expect(page).not_to have_content("Yes")
|
|
expect(page).not_to have_content("No")
|
|
end
|
|
expect(page).not_to have_selector(:link_or_button, "Submit answer")
|
|
|
|
expect(question.reload.answers_count).to eq(1)
|
|
expect(option.reload.answers_count).to eq(1)
|
|
end
|
|
|
|
scenario "cannot answer question when phase not open", :no_js do
|
|
process.update!(debate_end_date: Date.current - 1.day)
|
|
question = process.questions.first
|
|
create(:legislation_question_option, question: question, value: "Yes")
|
|
create(:legislation_question_option, question: question, value: "No")
|
|
create(:legislation_question_option, question: question, value: "I don't know")
|
|
user = create(:user, :level_two)
|
|
|
|
login_as(user)
|
|
|
|
visit legislation_process_question_path(process, question)
|
|
|
|
expect(page).to have_selector(:radio_button, "Yes", disabled: true)
|
|
expect(page).to have_selector(:radio_button, "No", disabled: true)
|
|
expect(page).to have_selector(:radio_button, "I don't know", disabled: true)
|
|
|
|
expect(page).not_to have_selector(:link_or_button, "Submit answer")
|
|
end
|
|
end
|
|
end
|