diff --git a/app/forms/journeys/get_a_teacher_relocation_payment/start_date_form.rb b/app/forms/journeys/get_a_teacher_relocation_payment/start_date_form.rb index 517ea0d99e..c391b86a4d 100644 --- a/app/forms/journeys/get_a_teacher_relocation_payment/start_date_form.rb +++ b/app/forms/journeys/get_a_teacher_relocation_payment/start_date_form.rb @@ -3,12 +3,18 @@ module GetATeacherRelocationPayment class StartDateForm < Form include ActiveRecord::AttributeAssignment + attribute :start_date, :date + validates :start_date, presence: { message: i18n_error_message(:presence) } - attribute :start_date, :date + validates :start_date, + comparison: { + less_than: ->(_) { Date.tomorrow }, + message: i18n_error_message(:date_not_in_future) + }, if: :start_date def initialize(journey_session:, journey:, params:) super diff --git a/config/locales/en.yml b/config/locales/en.yml index 7086055252..3a416d6f07 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -723,6 +723,7 @@ en: question: "Enter the start date of your contract" errors: presence: "Enter your contract start date" + date_not_in_future: "Start date cannot be in the future" subject: question: "What subject are you employed to teach at your school?" hint: "Physics, general or combined science including physics, and languages can be combined with other subjects but must make up at least 50% of your time in the classroom." diff --git a/spec/forms/journeys/get_a_teacher_relocation_payment/start_date_form_spec.rb b/spec/forms/journeys/get_a_teacher_relocation_payment/start_date_form_spec.rb index b5419c2725..de82e23aff 100644 --- a/spec/forms/journeys/get_a_teacher_relocation_payment/start_date_form_spec.rb +++ b/spec/forms/journeys/get_a_teacher_relocation_payment/start_date_form_spec.rb @@ -9,6 +9,8 @@ ) end + let(:option) { nil } + def multi_part_date_parms(date) return {} unless date.present? @@ -31,27 +33,25 @@ def multi_part_date_parms(date) subject { form } context "with an invalid date" do - let(:option) { nil } - it { is_expected.not_to be_valid } end context "with a date in the future" do - let(:option) { Date.tomorrow } - - it { is_expected.to be_valid } + it do + is_expected.not_to( + allow_value(Date.tomorrow) + .for(:start_date) + .with_message("Start date cannot be in the future") + ) + end end context "with a date in the present" do - let(:option) { Date.today } - - it { is_expected.to be_valid } + it { is_expected.to allow_value(Date.today).for(:start_date) } end context "with a date in the past" do - let(:option) { Date.yesterday } - - it { is_expected.to be_valid } + it { is_expected.to allow_value(Date.yesterday).for(:start_date) } end end @@ -90,7 +90,7 @@ def multi_part_date_parms(date) end describe "#save" do - let(:option) { Date.tomorrow } + let(:option) { Date.yesterday } it "updates the journey session" do expect { expect(form.save).to be(true) }.to(