Skip to content

Commit

Permalink
Don't allow future dates for start date
Browse files Browse the repository at this point in the history
IRP feedback from Richard Forrest

>  I am able to enter a contract start date in the future although I can't
>  enter a travel date in the future. Can both these fields only accept
>  dates in the past?

Updates the start date form to not permit dates in the future.
  • Loading branch information
rjlynch committed Jun 26, 2024
1 parent 3aabd0c commit 55f5c52
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 13 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
1 change: 1 addition & 0 deletions config/locales/en.yml
Original file line number Diff line number Diff line change
Expand Up @@ -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."
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@
)
end

let(:option) { nil }

def multi_part_date_parms(date)
return {} unless date.present?

Expand All @@ -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

Expand Down Expand Up @@ -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(
Expand Down

0 comments on commit 55f5c52

Please sign in to comment.