discourse/spec/models/user_notification_schedule_spec.rb
Daniel Waterworth 6e161d3e75
DEV: Allow fab! without block ()
The most common thing that we do with fab! is:

    fab!(:thing) { Fabricate(:thing) }

This commit adds a shorthand for this which is just simply:

    fab!(:thing)

i.e. If you omit the block, then, by default, you'll get a `Fabricate`d object using the fabricator of the same name.
2023-11-09 16:47:59 -06:00

58 lines
1.7 KiB
Ruby

# frozen_string_literal: true
RSpec.describe UserNotificationSchedule do
fab!(:user)
describe "validations" do
it "is invalid when no times are specified" do
schedule = UserNotificationSchedule.create({ user: user, enabled: true })
expect(schedule.errors.attribute_names).to eq(
%i[
day_0_start_time
day_0_end_time
day_1_start_time
day_1_end_time
day_2_start_time
day_2_end_time
day_3_start_time
day_3_end_time
day_4_start_time
day_4_end_time
day_5_start_time
day_5_end_time
day_6_start_time
day_6_end_time
],
)
end
it "is invalid when a start time is below -1" do
schedule =
UserNotificationSchedule.new({ user: user }.merge(UserNotificationSchedule::DEFAULT))
schedule.day_0_start_time = -2
schedule.save
expect(schedule.errors.count).to eq(1)
expect(schedule.errors[:day_0_start_time]).to be_present
end
it "invalid when an end time is greater than 1440" do
schedule =
UserNotificationSchedule.new({ user: user }.merge(UserNotificationSchedule::DEFAULT))
schedule.day_0_end_time = 1441
schedule.save
expect(schedule.errors.count).to eq(1)
expect(schedule.errors[:day_0_end_time]).to be_present
end
it "invalid when the start time is greater than the end time" do
schedule =
UserNotificationSchedule.new({ user: user }.merge(UserNotificationSchedule::DEFAULT))
schedule.day_0_start_time = 1000
schedule.day_0_end_time = 800
schedule.save
expect(schedule.errors.count).to eq(1)
expect(schedule.errors[:day_0_start_time]).to be_present
end
end
end