mirror of
https://github.com/discourse/discourse-solved.git
synced 2025-10-24 11:08:51 +00:00
PERF: Remove N+1 queries on basic category serializer.
This commit is contained in:
parent
0fa41a8b38
commit
8beaa6c1d9
@ -333,7 +333,7 @@ SQL
|
||||
end
|
||||
|
||||
def include_custom_fields?
|
||||
SiteSetting.show_filter_by_solved_status && custom_fields.present?
|
||||
object.custom_field_preloaded?("enable_accepted_answers") && SiteSetting.show_filter_by_solved_status && custom_fields.present?
|
||||
end
|
||||
end
|
||||
|
||||
|
21
spec/serializers/basic_category_serializer_spec.rb
Normal file
21
spec/serializers/basic_category_serializer_spec.rb
Normal file
@ -0,0 +1,21 @@
|
||||
require 'rails_helper'
|
||||
|
||||
describe BasicCategorySerializer do
|
||||
let(:category) { Fabricate(:category) }
|
||||
let(:guardian) { Guardian.new }
|
||||
|
||||
before do
|
||||
SiteSetting.show_filter_by_solved_status = true
|
||||
category.custom_fields["enable_accepted_answers"] = true
|
||||
category.save_custom_fields
|
||||
end
|
||||
|
||||
it "should include custom fields only if its preloaded" do
|
||||
json = described_class.new(category, scope: guardian, root: false).as_json
|
||||
expect(json.to_s).not_to include("custom_fields")
|
||||
|
||||
category.expects(:custom_field_preloaded?).returns(true)
|
||||
json = described_class.new(category, scope: guardian, root: false).as_json
|
||||
expect(json.to_s).to include("custom_fields")
|
||||
end
|
||||
end
|
Loading…
x
Reference in New Issue
Block a user