We get rid of database cleaner, and JavaScript tests are faster because between tests we now rollback transactions instead of truncating the database.
104 lines
3.4 KiB
Ruby
104 lines
3.4 KiB
Ruby
require "rails_helper"
|
|
|
|
describe "Admin hidden budget investments" do
|
|
let(:budget) { create(:budget) }
|
|
let(:heading) { create(:budget_heading, budget: budget, price: 666666) }
|
|
|
|
before do
|
|
admin = create(:administrator)
|
|
login_as(admin.user)
|
|
end
|
|
|
|
scenario "Disabled with a feature flag" do
|
|
Setting["process.budgets"] = nil
|
|
|
|
expect { visit admin_hidden_budget_investments_path }.to raise_exception(FeatureFlags::FeatureDisabled)
|
|
end
|
|
|
|
scenario "List shows all relevant info" do
|
|
investment = create(:budget_investment, :hidden, heading: heading)
|
|
|
|
visit admin_hidden_budget_investments_path
|
|
|
|
expect(page).to have_content(investment.title)
|
|
expect(page).to have_content(investment.description)
|
|
end
|
|
|
|
scenario "Restore" do
|
|
investment = create(:budget_investment, :hidden, heading: heading)
|
|
|
|
visit admin_hidden_budget_investments_path
|
|
|
|
click_link "Restore"
|
|
|
|
expect(page).not_to have_content(investment.title)
|
|
|
|
investment.reload
|
|
|
|
expect(investment).to be_ignored_flag
|
|
end
|
|
|
|
scenario "Confirm hide" do
|
|
investment = create(:budget_investment, :hidden, heading: heading)
|
|
visit admin_hidden_budget_investments_path
|
|
|
|
click_link("Pending")
|
|
expect(page).to have_content(investment.title)
|
|
|
|
click_link "Confirm moderation"
|
|
|
|
expect(page).not_to have_content(investment.title)
|
|
|
|
click_link("Confirmed")
|
|
expect(page).to have_content(investment.title)
|
|
|
|
expect(investment.reload).to be_confirmed_hide
|
|
end
|
|
|
|
scenario "Current filter is properly highlighted" do
|
|
visit admin_hidden_budget_investments_path
|
|
expect(page).not_to have_link("All")
|
|
expect(page).to have_link("Pending")
|
|
expect(page).to have_link("Confirmed")
|
|
|
|
visit admin_hidden_budget_investments_path(filter: "without_confirmed_hide")
|
|
expect(page).to have_link("All")
|
|
expect(page).to have_link("Confirmed")
|
|
expect(page).not_to have_link("Pending")
|
|
|
|
visit admin_hidden_budget_investments_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 investments" do
|
|
create(:budget_investment, :hidden, heading: heading, title: "Unconfirmed investment")
|
|
create(:budget_investment, :hidden, :with_confirmed_hide, heading: heading, title: "Confirmed investment")
|
|
|
|
visit admin_hidden_budget_investments_path(filter: "without_confirmed_hide")
|
|
expect(page).to have_content("Unconfirmed investment")
|
|
expect(page).not_to have_content("Confirmed investment")
|
|
|
|
visit admin_hidden_budget_investments_path(filter: "all")
|
|
expect(page).to have_content("Unconfirmed investment")
|
|
expect(page).to have_content("Confirmed investment")
|
|
|
|
visit admin_hidden_budget_investments_path(filter: "with_confirmed_hide")
|
|
expect(page).not_to have_content("Unconfirmed investment")
|
|
expect(page).to have_content("Confirmed investment")
|
|
end
|
|
|
|
scenario "Action links remember the pagination setting and the filter" do
|
|
allow(Budget::Investment).to receive(:default_per_page).and_return(2)
|
|
4.times { create(:budget_investment, :hidden, :with_confirmed_hide, heading: heading) }
|
|
|
|
visit admin_hidden_budget_investments_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
|