Files
grecia/spec/features/moderation_spec.rb
Javi Martín da121ebc53 Remove redundant setting resets in after blocks
Settings are stored in the database, and so any changes to the settings
done during the tests are automatically rolled back between one test and
the next one.

There were also a few places where we weren't using an `after` block but
changing the setting at the end of the test.
2019-09-23 13:47:45 +02:00

116 lines
3.1 KiB
Ruby

require "rails_helper"
describe "Moderation" do
let(:user) { create(:user) }
scenario "Access as regular user is not authorized" do
login_as(user)
visit root_path
expect(page).not_to have_link("Moderation")
visit moderation_root_path
expect(page).not_to have_current_path(moderation_root_path)
expect(page).to have_current_path(root_path)
expect(page).to have_content "You do not have permission to access this page"
end
scenario "Access as valuator is not authorized" do
create(:valuator, user: user)
login_as(user)
visit root_path
expect(page).not_to have_link("Moderation")
visit moderation_root_path
expect(page).not_to have_current_path(moderation_root_path)
expect(page).to have_current_path(root_path)
expect(page).to have_content "You do not have permission to access this page"
end
scenario "Access as manager is not authorized" do
create(:manager, user: user)
login_as(user)
visit root_path
expect(page).not_to have_link("Moderation")
visit moderation_root_path
expect(page).not_to have_current_path(moderation_root_path)
expect(page).to have_current_path(root_path)
expect(page).to have_content "You do not have permission to access this page"
end
scenario "Access as poll officer is not authorized" do
create(:poll_officer, user: user)
login_as(user)
visit root_path
expect(page).not_to have_link("Moderation")
visit moderation_root_path
expect(page).not_to have_current_path(moderation_root_path)
expect(page).to have_current_path(root_path)
expect(page).to have_content "You do not have permission to access this page"
end
scenario "Access as a moderator is authorized" do
create(:moderator, user: user)
login_as(user)
visit root_path
expect(page).to have_link("Moderation")
click_on "Moderation"
expect(page).to have_current_path(moderation_root_path)
expect(page).not_to have_content "You do not have permission to access this page"
end
scenario "Access as an administrator is authorized" do
create(:administrator, user: user)
login_as(user)
visit root_path
expect(page).to have_link("Moderation")
click_on "Moderation"
expect(page).to have_current_path(moderation_root_path)
expect(page).not_to have_content "You do not have permission to access this page"
end
scenario "Moderation access links" do
create(:moderator, user: user)
login_as(user)
visit root_path
expect(page).to have_link("Moderation")
expect(page).not_to have_link("Administration")
expect(page).not_to have_link("Valuation")
end
context "Moderation dashboard" do
before do
Setting["org_name"] = "OrgName"
end
scenario "Contains correct elements" do
create(:moderator, user: user)
login_as(user)
visit root_path
click_link "Moderation"
expect(page).to have_link("Go back to OrgName")
expect(page).to have_current_path(moderation_root_path)
expect(page).to have_css("#moderation_menu")
expect(page).not_to have_css("#admin_menu")
expect(page).not_to have_css("#valuation_menu")
end
end
end