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:
parent
f8a4c983d1
commit
9bf31add6a
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue