FIX: do not memoize score types (#30657)

Score types are dynamic because of custom flags. Therefore we cannot memorize them on class level as it is not multisite safe.
This commit is contained in:
Krzysztof Kotlarek 2025-01-09 13:20:59 +11:00 committed by GitHub
parent f8a4c983d1
commit 9bf31add6a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 40 additions and 3 deletions

View File

@ -11,7 +11,7 @@ class ReviewableScore < ActiveRecord::Base
# To keep things simple the types correspond to `PostActionType` for backwards # To keep things simple the types correspond to `PostActionType` for backwards
# compatibility, but we can add extra reasons for scores. # compatibility, but we can add extra reasons for scores.
def self.types def self.types
@types ||= PostActionType.flag_types.merge(PostActionType.score_types) PostActionType.flag_types.merge(PostActionType.score_types).merge(@api_types || {})
end end
def self.type_title(type) def self.type_title(type)
@ -23,14 +23,15 @@ class ReviewableScore < ActiveRecord::Base
# When extending post action flags, we need to call this method in order to # When extending post action flags, we need to call this method in order to
# get the latests flags. # get the latests flags.
def self.reload_types def self.reload_types
@types = nil @api_types = nil
types types
end end
def self.add_new_types(type_names) def self.add_new_types(type_names)
@api_types ||= {}
next_id = types.values.max + 1 next_id = types.values.max + 1
type_names.each_with_index { |name, idx| @types[name] = next_id + idx } type_names.each_with_index { |name, idx| @api_types[name] = next_id + idx }
end end
def self.score_transitions def self.score_transitions

View File

@ -4,6 +4,18 @@ RSpec.describe "Custom flags in multisite", type: :multisite do
describe "PostACtionType#all_flags" do describe "PostACtionType#all_flags" do
it "does not share flag definitions between sites" do it "does not share flag definitions between sites" do
flag_1 = Flag.create!(name: "test flag 1", position: 99, applies_to: ["Post"]) flag_1 = Flag.create!(name: "test flag 1", position: 99, applies_to: ["Post"])
expect(ReviewableScore.types).to eq(
{
notify_user: 6,
off_topic: 3,
inappropriate: 4,
spam: 8,
illegal: 10,
notify_moderators: 7,
custom_test_flag_1: flag_1.id,
needs_approval: 9,
},
)
test_multisite_connection("second") do test_multisite_connection("second") do
flag_2 = Flag.create!(name: "test flag 2", position: 99, applies_to: ["Post"]) flag_2 = Flag.create!(name: "test flag 2", position: 99, applies_to: ["Post"])
@ -11,12 +23,36 @@ RSpec.describe "Custom flags in multisite", type: :multisite do
expect(PostActionType.all_flags.last).to eq( expect(PostActionType.all_flags.last).to eq(
flag_2.attributes.except("created_at", "updated_at").transform_keys(&:to_sym), flag_2.attributes.except("created_at", "updated_at").transform_keys(&:to_sym),
) )
expect(ReviewableScore.types).to eq(
{
notify_user: 6,
off_topic: 3,
inappropriate: 4,
spam: 8,
illegal: 10,
notify_moderators: 7,
custom_test_flag_2: flag_2.id,
needs_approval: 9,
},
)
end end
PostActionType.new.expire_cache PostActionType.new.expire_cache
expect(PostActionType.all_flags.last).to eq( expect(PostActionType.all_flags.last).to eq(
flag_1.attributes.except("created_at", "updated_at").transform_keys(&:to_sym), flag_1.attributes.except("created_at", "updated_at").transform_keys(&:to_sym),
) )
expect(ReviewableScore.types).to eq(
{
notify_user: 6,
off_topic: 3,
inappropriate: 4,
spam: 8,
illegal: 10,
notify_moderators: 7,
custom_test_flag_1: flag_1.id,
needs_approval: 9,
},
)
end end
end end
end end