Merge branch 'dev' into add_meta
This commit is contained in:
		
						commit
						099eb606bd
					
				| @ -72,7 +72,7 @@ module FastJsonapi | |||||||
|             temp_hash[:links] = links_hash(record, params) if data_links.present? |             temp_hash[:links] = links_hash(record, params) if data_links.present? | ||||||
|             temp_hash |             temp_hash | ||||||
|           end |           end | ||||||
|           record_hash[:relationships] = record_hash[:relationships].merge(relationships_hash(record, uncachable_relationships_to_serialize, params)) if uncachable_relationships_to_serialize.present? |           record_hash[:relationships] = record_hash[:relationships].merge(relationships_hash(record, uncachable_relationships_to_serialize, fieldset, params)) if uncachable_relationships_to_serialize.present? | ||||||
|           record_hash[:meta] = meta_hash(record, params) if meta_to_serialize.present? |           record_hash[:meta] = meta_hash(record, params) if meta_to_serialize.present? | ||||||
|           record_hash |           record_hash | ||||||
|         else |         else | ||||||
| @ -130,7 +130,7 @@ module FastJsonapi | |||||||
| 
 | 
 | ||||||
|             included_objects.each do |inc_obj| |             included_objects.each do |inc_obj| | ||||||
|               if remaining_items(items) |               if remaining_items(items) | ||||||
|                 serializer_records = serializer.get_included_records(inc_obj, remaining_items(items), known_included_objects, fieldsets) |                 serializer_records = serializer.get_included_records(inc_obj, remaining_items(items), known_included_objects, fieldsets, params) | ||||||
|                 included_records.concat(serializer_records) unless serializer_records.empty? |                 included_records.concat(serializer_records) unless serializer_records.empty? | ||||||
|               end |               end | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -310,6 +310,23 @@ describe FastJsonapi::ObjectSerializer do | |||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |   context 'when serializing included, params should be available in any serializer' do | ||||||
|  |     subject(:serializable_hash) do | ||||||
|  |       options = {} | ||||||
|  |       options[:include] = [:"actors.awards"] | ||||||
|  |       options[:params] = { include_award_year: true } | ||||||
|  |       MovieSerializer.new(movie, options).serializable_hash | ||||||
|  |     end | ||||||
|  |     let(:actor) { movie.actors.first } | ||||||
|  |     let(:award) { actor.awards.first } | ||||||
|  |     let(:year) { award.year } | ||||||
|  | 
 | ||||||
|  |     it 'passes params to deeply nested includes' do | ||||||
|  |       expect(year).to_not be_blank | ||||||
|  |       expect(serializable_hash[:included][0][:attributes][:year]).to eq year | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   context 'when is_collection option present' do |   context 'when is_collection option present' do | ||||||
|     subject { MovieSerializer.new(resource, is_collection_options).serializable_hash } |     subject { MovieSerializer.new(resource, is_collection_options).serializable_hash } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -80,6 +80,7 @@ RSpec.shared_context 'movie class' do | |||||||
|             a.id = i |             a.id = i | ||||||
|             a.title = "Test Award #{i}" |             a.title = "Test Award #{i}" | ||||||
|             a.actor_id = id |             a.actor_id = id | ||||||
|  |             a.year = 1990 + i | ||||||
|           end |           end | ||||||
|         end |         end | ||||||
|       end |       end | ||||||
| @ -110,7 +111,7 @@ RSpec.shared_context 'movie class' do | |||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     class Award |     class Award | ||||||
|       attr_accessor :id, :title, :actor_id |       attr_accessor :id, :title, :actor_id, :year | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     class State |     class State | ||||||
| @ -225,6 +226,11 @@ RSpec.shared_context 'movie class' do | |||||||
|     class AwardSerializer |     class AwardSerializer | ||||||
|       include FastJsonapi::ObjectSerializer |       include FastJsonapi::ObjectSerializer | ||||||
|       attributes :id, :title |       attributes :id, :title | ||||||
|  |       attribute :year, if: Proc.new { |record, params| | ||||||
|  |         params[:include_award_year].present? ?  | ||||||
|  |           params[:include_award_year] :  | ||||||
|  |           false | ||||||
|  |       } | ||||||
|       belongs_to :actor |       belongs_to :actor | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user