Skip to content

Commit

Permalink
Merge pull request #15040 from opf/flaky-schedule_date_alerts_notific…
Browse files Browse the repository at this point in the history
…ations_job_spec

Flaky schedule date alerts notifications job spec
  • Loading branch information
toy authored Mar 20, 2024
2 parents 691c2d6 + e7b8837 commit 2acc3ad
Showing 1 changed file with 71 additions and 78 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -26,24 +26,24 @@
# See docs/COPYRIGHT.rdoc for more details.
#++

require 'spec_helper'
require "spec_helper"

RSpec.describe Notifications::ScheduleDateAlertsNotificationsJob, type: :job, with_ee: %i[date_alerts] do
include ActiveSupport::Testing::TimeHelpers

shared_let(:project) { create(:project, name: 'main') }
shared_let(:project) { create(:project, name: "main") }
# Paris and Berlin are both UTC+01:00 (CET) or UTC+02:00 (CEST)
shared_let(:timezone_paris) { ActiveSupport::TimeZone['Europe/Paris'] }
shared_let(:timezone_paris) { ActiveSupport::TimeZone["Europe/Paris"] }
# Kathmandu is UTC+05:45 (no DST)
shared_let(:timezone_kathmandu) { ActiveSupport::TimeZone['Asia/Kathmandu'] }
shared_let(:timezone_kathmandu) { ActiveSupport::TimeZone["Asia/Kathmandu"] }
shared_let(:user_paris) do
create(:user,
firstname: 'Paris',
firstname: "Paris",
preferences: { time_zone: timezone_paris.name })
end
shared_let(:user_kathmandu) do
create(:user,
firstname: 'Kathmandu',
firstname: "Kathmandu",
preferences: { time_zone: timezone_kathmandu.name })
end

Expand All @@ -60,14 +60,14 @@ def set_scheduled_time(scheduled_at)

# Converts "hh:mm" into { hour: h, min: m }
def time_hash(time)
%i[hour min].zip(time.split(':', 2).map(&:to_i)).to_h
%i[hour min].zip(time.split(":", 2).map(&:to_i)).to_h
end

def timezone_time(time, timezone)
timezone.now.change(time_hash(time))
end

def run_job(scheduled_at: '1:00', local_time: '1:04', timezone: timezone_paris)
def run_job(scheduled_at:, local_time:, timezone:)
set_scheduled_time(timezone_time(scheduled_at, timezone))
travel_to(timezone_time(local_time, timezone)) do
GoodJob.perform_inline
Expand All @@ -86,104 +86,97 @@ def deserialize_job(job)

def expect_job(job, *arguments)
job_data = deserialize_job(job)
expect(job_data['job_class']).to eql(job.job_class)
expect(job_data['arguments']).to match_array arguments
expect(job_data['executions']).to eq 0
expect(job_data["job_class"]).to eql(job.job_class)
expect(job_data["arguments"]).to match_array arguments
expect(job_data["executions"]).to eq 0
end

shared_examples_for 'job execution creates date alerts creation job' do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:04' }
let(:user) { user_paris }
shared_examples_for "job execution creates date alerts creation job" do
let(:job_class) { Notifications::CreateDateAlertsNotificationsJob.name }

it 'creates the job for the user' do
it "creates the job for the user" do
expect do
run_job(timezone:, scheduled_at:, local_time:) do
j = GoodJob::Job.where(job_class: "Notifications::CreateDateAlertsNotificationsJob")
j = GoodJob::Job.where(job_class:)
.order(created_at: :desc)
.last
expect_job(j, user)
end
end.to change(GoodJob::Job, :count).by 1
end.to change { GoodJob::Job.where(job_class:).count }.by 1
end
end

shared_examples_for 'job execution creates no date alerts creation job' do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:04' }

it 'creates no job' do
shared_examples_for "job execution creates no date alerts creation job" do
it "creates no job" do
expect do
run_job(timezone:, scheduled_at:, local_time:)
end.not_to change(GoodJob::Job, :count)
end
end

describe '#perform' do
context 'for users whose local time is 1:00 am (UTC+1) when the job is executed' do
it_behaves_like 'job execution creates date alerts creation job' do
describe "#perform" do
context "for users whose local time is 1:00 am (UTC+1) when the job is executed" do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:04' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:04" }
let(:user) { user_paris }
end
end

context 'for users whose local time is 1:00 am (UTC+05:45) when the job is executed' do
it_behaves_like 'job execution creates date alerts creation job' do
context "for users whose local time is 1:00 am (UTC+05:45) when the job is executed" do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_kathmandu }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:04' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:04" }
let(:user) { user_kathmandu }
end
end

context 'without enterprise token', with_ee: false do
it_behaves_like 'job execution creates no date alerts creation job' do
context "without enterprise token", with_ee: false do
it_behaves_like "job execution creates no date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:04' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:04" }
end
end

context 'when scheduled and executed at 01:00 am local time' do
it_behaves_like 'job execution creates date alerts creation job' do
context "when scheduled and executed at 01:00 am local time" do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:00' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:00" }
let(:user) { user_paris }
end
end

context 'when scheduled and executed at 01:14 am local time' do
it_behaves_like 'job execution creates date alerts creation job' do
context "when scheduled and executed at 01:14 am local time" do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:14' }
let(:local_time) { '1:14' }
let(:scheduled_at) { "1:14" }
let(:local_time) { "1:14" }
let(:user) { user_paris }
end
end

context 'when scheduled and executed at 01:15 am local time' do
it_behaves_like 'job execution creates no date alerts creation job' do
context "when scheduled and executed at 01:15 am local time" do
it_behaves_like "job execution creates no date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:15' }
let(:local_time) { '1:15' }
let(:scheduled_at) { "1:15" }
let(:local_time) { "1:15" }
end
end

context 'when scheduled at 01:00 am local time and executed at 01:37 am local time' do
it_behaves_like 'job execution creates date alerts creation job' do
context "when scheduled at 01:00 am local time and executed at 01:37 am local time" do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:37' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:37" }
let(:user) { user_paris }
end
end

context 'with a user having only due_date active in notification settings' do
context "with a user having only due_date active in notification settings" do
before do
NotificationSetting
.where(user: user_paris)
Expand All @@ -192,15 +185,15 @@ def expect_job(job, *arguments)
overdue: nil)
end

it_behaves_like 'job execution creates date alerts creation job' do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:00' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:00" }
let(:user) { user_paris }
end
end

context 'with a user having only start_date active in notification settings' do
context "with a user having only start_date active in notification settings" do
before do
NotificationSetting
.where(user: user_paris)
Expand All @@ -209,15 +202,15 @@ def expect_job(job, *arguments)
overdue: nil)
end

it_behaves_like 'job execution creates date alerts creation job' do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:00' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:00" }
let(:user) { user_paris }
end
end

context 'with a user having only overdue active in notification settings' do
context "with a user having only overdue active in notification settings" do
before do
NotificationSetting
.where(user: user_paris)
Expand All @@ -226,15 +219,15 @@ def expect_job(job, *arguments)
overdue: 1)
end

it_behaves_like 'job execution creates date alerts creation job' do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:00' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:00" }
let(:user) { user_paris }
end
end

context 'without a user having notification settings' do
context "without a user having notification settings" do
before do
NotificationSetting
.where(user: user_paris)
Expand All @@ -243,14 +236,14 @@ def expect_job(job, *arguments)
overdue: nil)
end

it_behaves_like 'job execution creates no date alerts creation job' do
it_behaves_like "job execution creates no date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:00' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:00" }
end
end

context 'with a user having only a project active notification settings' do
context "with a user having only a project active notification settings" do
before do
NotificationSetting
.where(user: user_paris)
Expand All @@ -266,23 +259,23 @@ def expect_job(job, *arguments)
overdue: nil)
end

it_behaves_like 'job execution creates date alerts creation job' do
it_behaves_like "job execution creates date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:00' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:00" }
let(:user) { user_paris }
end
end

context 'with a locked user' do
context "with a locked user" do
before do
user_paris.locked!
end

it_behaves_like 'job execution creates no date alerts creation job' do
it_behaves_like "job execution creates no date alerts creation job" do
let(:timezone) { timezone_paris }
let(:scheduled_at) { '1:00' }
let(:local_time) { '1:00' }
let(:scheduled_at) { "1:00" }
let(:local_time) { "1:00" }
end
end
end
Expand Down

0 comments on commit 2acc3ad

Please sign in to comment.