2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2022-07-28 10:27:38 +08:00
|
|
|
RSpec.describe AdminDashboardData do
|
2021-12-20 07:59:11 +08:00
|
|
|
after do
|
|
|
|
AdminDashboardData.reset_problem_checks
|
|
|
|
Discourse.redis.flushdb
|
|
|
|
end
|
2013-03-20 11:18:00 +08:00
|
|
|
|
2021-12-20 07:59:11 +08:00
|
|
|
describe "adding scheduled checks" do
|
|
|
|
it "does not add duplicate problems with the same identifier" do
|
2024-03-14 10:55:01 +08:00
|
|
|
prob1 = ProblemCheck::Problem.new("test problem", identifier: "test")
|
|
|
|
prob2 = ProblemCheck::Problem.new("test problem 2", identifier: "test")
|
2021-12-20 07:59:11 +08:00
|
|
|
AdminDashboardData.add_found_scheduled_check_problem(prob1)
|
|
|
|
AdminDashboardData.add_found_scheduled_check_problem(prob2)
|
|
|
|
expect(AdminDashboardData.load_found_scheduled_check_problems.map(&:to_s)).to eq(
|
|
|
|
["test problem"],
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not error when loading malformed problems saved in redis" do
|
2023-11-03 09:05:29 +08:00
|
|
|
Discourse.redis.rpush(AdminDashboardData::SCHEDULED_PROBLEM_STORAGE_KEY, "{ 'badjson")
|
2021-12-20 07:59:11 +08:00
|
|
|
expect(AdminDashboardData.load_found_scheduled_check_problems).to eq([])
|
|
|
|
end
|
|
|
|
|
|
|
|
it "clears a specific problem by identifier" do
|
2024-03-14 10:55:01 +08:00
|
|
|
prob1 = ProblemCheck::Problem.new("test problem 1", identifier: "test")
|
2021-12-20 07:59:11 +08:00
|
|
|
AdminDashboardData.add_found_scheduled_check_problem(prob1)
|
|
|
|
AdminDashboardData.clear_found_problem("test")
|
|
|
|
expect(AdminDashboardData.load_found_scheduled_check_problems).to eq([])
|
|
|
|
end
|
|
|
|
|
|
|
|
it "defaults to low priority, and uses low priority if an invalid priority is passed" do
|
2024-03-14 10:55:01 +08:00
|
|
|
prob1 = ProblemCheck::Problem.new("test problem 1")
|
|
|
|
prob2 = ProblemCheck::Problem.new("test problem 2", priority: "superbad")
|
2021-12-20 07:59:11 +08:00
|
|
|
expect(prob1.priority).to eq("low")
|
|
|
|
expect(prob2.priority).to eq("low")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "stats cache" do
|
|
|
|
include_examples "stats cacheable"
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#problem_message_check" do
|
2024-05-31 17:07:19 +08:00
|
|
|
let(:key) { "new_key" }
|
2021-12-20 07:59:11 +08:00
|
|
|
|
|
|
|
after { described_class.clear_problem_message(key) }
|
|
|
|
|
|
|
|
it "returns nil if message has not been added" do
|
|
|
|
expect(described_class.problem_message_check(key)).to be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns a message if it was added" do
|
|
|
|
described_class.add_problem_message(key)
|
|
|
|
expect(described_class.problem_message_check(key)).to eq(
|
|
|
|
I18n.t(key, base_path: Discourse.base_path),
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns a message if it was added with an expiry" do
|
|
|
|
described_class.add_problem_message(key, 300)
|
|
|
|
expect(described_class.problem_message_check(key)).to eq(
|
|
|
|
I18n.t(key, base_path: Discourse.base_path),
|
|
|
|
)
|
2015-08-26 08:07:40 +08:00
|
|
|
end
|
|
|
|
end
|
2013-04-30 10:43:21 +08:00
|
|
|
end
|