From 55097ac643c7429f38a284bb156e0c88d144e7bd Mon Sep 17 00:00:00 2001 From: decabeza Date: Wed, 16 May 2018 13:14:45 +0200 Subject: [PATCH] Updates specs for show to valuators checkbox --- .../features/admin/budget_investments_spec.rb | 92 ++++++++++++++++++- 1 file changed, 91 insertions(+), 1 deletion(-) diff --git a/spec/features/admin/budget_investments_spec.rb b/spec/features/admin/budget_investments_spec.rb index 4a1beaacd..1cc2c36a3 100644 --- a/spec/features/admin/budget_investments_spec.rb +++ b/spec/features/admin/budget_investments_spec.rb @@ -1056,7 +1056,7 @@ feature 'Admin budget investments' do visit admin_budget_budget_investments_path(budget) - expect(page).not_to have_css("#budget_investment_visible_to_valuators") + expect(page).to have_css("#budget_investment_visible_to_valuators") within('#filter-subnav') { click_link 'Under valuation' } @@ -1127,4 +1127,94 @@ feature 'Admin budget investments' do end end + context "Mark as visible to valuators" do + + let(:valuator) { create(:valuator) } + let(:admin) { create(:administrator) } + + let(:group) { create(:budget_group, budget: budget) } + let(:heading) { create(:budget_heading, group: group) } + + let(:investment1) { create(:budget_investment, heading: heading) } + let(:investment2) { create(:budget_investment, heading: heading) } + + scenario "Mark as visible to valuator", :js do + investment1.valuators << valuator + investment2.valuators << valuator + investment1.update(administrator: admin) + investment2.update(administrator: admin) + + visit admin_budget_budget_investments_path(budget) + + within("#budget_investment_#{investment1.id}") do + check "budget_investment_visible_to_valuators" + end + + visit admin_budget_budget_investments_path(budget) + within('#filter-subnav') { click_link 'Under valuation' } + + within("#budget_investment_#{investment1.id}") do + expect(find("#budget_investment_visible_to_valuators")).to be_checked + end + end + + scenario "Unmark as visible to valuator", :js do + budget.update(phase: 'valuating') + + valuator = create(:valuator) + admin = create(:administrator) + + group = create(:budget_group, budget: budget) + heading = create(:budget_heading, group: group) + + investment1 = create(:budget_investment, heading: heading, visible_to_valuators: true) + investment2 = create(:budget_investment, heading: heading, visible_to_valuators: true) + + investment1.valuators << valuator + investment2.valuators << valuator + investment1.update(administrator: admin) + investment2.update(administrator: admin) + + visit admin_budget_budget_investments_path(budget) + within('#filter-subnav') { click_link 'Under valuation' } + + within("#budget_investment_#{investment1.id}") do + uncheck "budget_investment_visible_to_valuators" + end + + visit admin_budget_budget_investments_path(budget) + + within("#budget_investment_#{investment1.id}") do + expect(find("#budget_investment_visible_to_valuators")).not_to be_checked + end + end + + scenario "Showing the valuating checkbox" do + investment1 = create(:budget_investment, budget: budget, visible_to_valuators: true) + investment2 = create(:budget_investment, budget: budget, visible_to_valuators: false) + + investment1.valuators << create(:valuator) + investment2.valuators << create(:valuator) + investment2.valuators << create(:valuator) + investment1.update(administrator: create(:administrator)) + investment2.update(administrator: create(:administrator)) + + visit admin_budget_budget_investments_path(budget) + + expect(page).to have_css("#budget_investment_visible_to_valuators") + + within('#filter-subnav') { click_link 'Under valuation' } + + within("#budget_investment_#{investment1.id}") do + valuating_checkbox = find('#budget_investment_visible_to_valuators') + expect(valuating_checkbox).to be_checked + end + + within("#budget_investment_#{investment2.id}") do + valuating_checkbox = find('#budget_investment_visible_to_valuators') + expect(valuating_checkbox).not_to be_checked + end + end + end + end