Files
grecia/spec/features/admin/hidden_users_spec.rb
Javi Martín db97f9d08c Add and apply rubocop rules for empty lines
We were very inconsistent regarding these rules.

Personally I prefer no empty lines around blocks, clases, etc... as
recommended by the Ruby style guide [1], and they're the default values
in rubocop, so those are the settings I'm applying.

The exception is the `private` access modifier, since we were leaving
empty lines around it most of the time. That's the default rubocop rule
as well. Personally I don't have a strong preference about this one.


[1] https://rubystyle.guide/#empty-lines-around-bodies
2019-10-24 17:11:47 +02:00

96 lines
2.9 KiB
Ruby

require "rails_helper"
describe "Admin hidden users" do
before do
admin = create(:administrator)
login_as(admin.user)
end
scenario "Show user activity" do
user = create(:user, :hidden)
debate1 = create(:debate, :hidden, author: user)
debate2 = create(:debate, author: user)
comment1 = create(:comment, :hidden, user: user, commentable: debate2, body: "You have the manners of a beggar")
comment2 = create(:comment, user: user, commentable: debate2, body: "Not Spam")
visit admin_hidden_user_path(user)
expect(page).to have_content(debate1.title)
expect(page).to have_content(debate2.title)
expect(page).to have_content(comment1.body)
expect(page).to have_content(comment2.body)
end
scenario "Restore" do
user = create(:user, :hidden)
visit admin_hidden_users_path
click_link "Restore"
expect(page).not_to have_content(user.username)
expect(user.reload).not_to be_hidden
end
scenario "Confirm hide" do
user = create(:user, :hidden)
visit admin_hidden_users_path
click_link "Confirm moderation"
expect(page).not_to have_content(user.username)
click_link("Confirmed")
expect(page).to have_content(user.username)
expect(user.reload).to be_confirmed_hide
end
scenario "Current filter is properly highlighted" do
visit admin_hidden_users_path
expect(page).not_to have_link("Pending")
expect(page).to have_link("All")
expect(page).to have_link("Confirmed")
visit admin_hidden_users_path(filter: "Pending")
expect(page).not_to have_link("Pending")
expect(page).to have_link("All")
expect(page).to have_link("Confirmed")
visit admin_hidden_users_path(filter: "all")
expect(page).to have_link("Pending")
expect(page).not_to have_link("All")
expect(page).to have_link("Confirmed")
visit admin_hidden_users_path(filter: "with_confirmed_hide")
expect(page).to have_link("All")
expect(page).to have_link("Pending")
expect(page).not_to have_link("Confirmed")
end
scenario "Filtering users" do
create(:user, :hidden, username: "Unconfirmed")
create(:user, :hidden, :with_confirmed_hide, username: "Confirmed user")
visit admin_hidden_users_path(filter: "all")
expect(page).to have_content("Unconfirmed")
expect(page).to have_content("Confirmed user")
visit admin_hidden_users_path(filter: "with_confirmed_hide")
expect(page).not_to have_content("Unconfirmed")
expect(page).to have_content("Confirmed user")
end
scenario "Action links remember the pagination setting and the filter" do
per_page = Kaminari.config.default_per_page
(per_page + 2).times { create(:user, :hidden, :with_confirmed_hide) }
visit admin_hidden_users_path(filter: "with_confirmed_hide", page: 2)
click_on("Restore", match: :first, exact: true)
expect(current_url).to include("filter=with_confirmed_hide")
expect(current_url).to include("page=2")
end
end