mirror of
				https://github.com/discourse/discourse-solved.git
				synced 2025-10-23 02:28:48 +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