2023-11-03 09:05:29 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
RSpec.describe Jobs::ProblemCheck do
|
|
|
|
after do
|
|
|
|
Discourse.redis.flushdb
|
|
|
|
AdminDashboardData.reset_problem_checks
|
|
|
|
end
|
|
|
|
|
2023-11-06 08:57:02 +08:00
|
|
|
class TestCheck
|
|
|
|
def self.max_retries = 0
|
|
|
|
def self.retry_wait = 30.seconds
|
|
|
|
end
|
|
|
|
|
2023-11-03 09:05:29 +08:00
|
|
|
it "runs the scheduled problem check that has been added and adds the messages to the load_found_scheduled_check_problems array" do
|
2023-11-06 08:57:02 +08:00
|
|
|
AdminDashboardData.add_scheduled_problem_check(:test_identifier, TestCheck) do
|
2023-11-03 09:05:29 +08:00
|
|
|
AdminDashboardData::Problem.new("big problem")
|
|
|
|
end
|
|
|
|
|
|
|
|
described_class.new.execute(check_identifier: :test_identifier)
|
|
|
|
problems = AdminDashboardData.load_found_scheduled_check_problems
|
|
|
|
expect(problems.count).to eq(1)
|
|
|
|
expect(problems.first).to be_a(AdminDashboardData::Problem)
|
|
|
|
expect(problems.first.to_s).to eq("big problem")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "can handle the problem check returning multiple problems" do
|
2023-11-06 08:57:02 +08:00
|
|
|
AdminDashboardData.add_scheduled_problem_check(:test_identifier, TestCheck) do
|
2023-11-03 09:05:29 +08:00
|
|
|
[
|
|
|
|
AdminDashboardData::Problem.new("big problem"),
|
|
|
|
AdminDashboardData::Problem.new(
|
|
|
|
"yuge problem",
|
|
|
|
priority: "high",
|
|
|
|
identifier: "config_is_a_mess",
|
|
|
|
),
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
described_class.new.execute(check_identifier: :test_identifier)
|
|
|
|
problems = AdminDashboardData.load_found_scheduled_check_problems
|
|
|
|
expect(problems.map(&:to_s)).to match_array(["big problem", "yuge problem"])
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not add the same problem twice if the identifier already exists" do
|
2023-11-06 08:57:02 +08:00
|
|
|
AdminDashboardData.add_scheduled_problem_check(:test_identifier, TestCheck) do
|
2023-11-03 09:05:29 +08:00
|
|
|
[
|
|
|
|
AdminDashboardData::Problem.new(
|
|
|
|
"yuge problem",
|
|
|
|
priority: "high",
|
|
|
|
identifier: "config_is_a_mess",
|
|
|
|
),
|
|
|
|
AdminDashboardData::Problem.new(
|
|
|
|
"nasty problem",
|
|
|
|
priority: "high",
|
|
|
|
identifier: "config_is_a_mess",
|
|
|
|
),
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
described_class.new.execute(check_identifier: :test_identifier)
|
|
|
|
problems = AdminDashboardData.load_found_scheduled_check_problems
|
|
|
|
expect(problems.map(&:to_s)).to match_array(["yuge problem"])
|
|
|
|
end
|
|
|
|
|
2023-11-06 08:57:02 +08:00
|
|
|
it "schedules a retry if there are attempts remaining" do
|
|
|
|
AdminDashboardData.add_scheduled_problem_check(:test_identifier, TestCheck) do
|
|
|
|
AdminDashboardData::Problem.new("big problem")
|
|
|
|
end
|
|
|
|
|
|
|
|
TestCheck.stubs(:max_retries).returns(1)
|
|
|
|
|
|
|
|
expect_enqueued_with(
|
|
|
|
job: :problem_check,
|
|
|
|
args: {
|
|
|
|
check_identifier: :test_identifier,
|
|
|
|
retry_count: 1,
|
|
|
|
},
|
|
|
|
) { described_class.new.execute(check_identifier: :test_identifier) }
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not schedule a retry if there are no more attempts remaining" do
|
|
|
|
AdminDashboardData.add_scheduled_problem_check(:test_identifier, TestCheck) do
|
|
|
|
AdminDashboardData::Problem.new("big problem")
|
|
|
|
end
|
|
|
|
|
|
|
|
TestCheck.stubs(:max_retries).returns(1)
|
|
|
|
|
|
|
|
expect_not_enqueued_with(job: :problem_check) do
|
|
|
|
described_class.new.execute(check_identifier: :test_identifier, retry_count: 1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-11-03 09:05:29 +08:00
|
|
|
it "handles errors from a troublesome check" do
|
2023-11-06 08:57:02 +08:00
|
|
|
AdminDashboardData.add_scheduled_problem_check(:test_identifier, TestCheck) do
|
2023-11-03 09:05:29 +08:00
|
|
|
raise StandardError.new("something went wrong")
|
|
|
|
end
|
|
|
|
|
|
|
|
described_class.new.execute(check_identifier: :test_identifier)
|
|
|
|
expect(AdminDashboardData.load_found_scheduled_check_problems.count).to eq(0)
|
|
|
|
end
|
|
|
|
end
|