require "rails_helper" RSpec.describe LocationDeactivationPeriod do let(:validator) { LocationDeactivationPeriodValidator.new } let(:previous_collection_start_date) { Time.zone.local(2022, 4, 1) } let(:current_collection_start_date) { Time.zone.local(2023, 4, 1) } let(:location) { FactoryBot.create(:location, startdate: previous_collection_start_date - 2.years) } let(:record) { FactoryBot.create(:location_deactivation_period, deactivation_date: current_collection_start_date, location:) } describe "#validate" do before do allow(FormHandler.instance).to receive(:previous_collection_start_date).and_return(previous_collection_start_date) allow(FormHandler.instance).to receive(:current_collection_start_date).and_return(current_collection_start_date) end context "when not in a crossover period" do before do allow(FormHandler.instance).to receive(:in_edit_crossover_period?).and_return(false) end context "with a deactivation date before the current collection period" do it "adds an error" do record.deactivation_date = current_collection_start_date - 1.year location.location_deactivation_periods.clear validator.validate(record) expect(record.errors[:deactivation_date]).to include "The date must be on or after the 1 April 2023" end end context "with a deactivation date in the current collection period" do it "does not add an error" do record.deactivation_date = current_collection_start_date + 1.day location.location_deactivation_periods.clear validator.validate(record) expect(record.errors).to be_empty end end end context "when in a crossover period" do before do allow(FormHandler.instance).to receive(:in_edit_crossover_period?).and_return(true) end context "with a deactivation date before the previous collection period" do it "does not add an error" do record.deactivation_date = previous_collection_start_date - 2.years location.location_deactivation_periods.clear validator.validate(record) expect(record.errors[:deactivation_date]).to include "The date must be on or after the 1 April 2022" end end context "with a deactivation date in the previous collection period" do it "does not add an error" do record.deactivation_date = previous_collection_start_date + 1.day location.location_deactivation_periods.clear validator.validate(record) expect(record.errors).to be_empty end end context "with a deactivation date in the current collection period" do it "does not add an error" do record.deactivation_date = current_collection_start_date + 1.day location.location_deactivation_periods.clear validator.validate(record) expect(record.errors).to be_empty end end context "but the location was created in the current collection period" do let(:location) { FactoryBot.create(:location, startdate:) } let(:startdate) { current_collection_start_date + 2.days } let(:record) { FactoryBot.create(:location_deactivation_period, deactivation_date: current_collection_start_date + 3.days, location:) } context "with a deactivation date in the previous collection period" do it "adds an error" do record.deactivation_date = previous_collection_start_date + 1.day location.location_deactivation_periods.clear validator.validate(record) start_date = startdate.to_formatted_s(:govuk_date) expect(record.errors[:deactivation_date]).to include "The location cannot be deactivated before #{start_date}, the date when it was first available" end end end end end end