active_model_serializers 0.10.0 → 0.10.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (109) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +2 -4
  3. data/.travis.yml +1 -0
  4. data/CHANGELOG.md +39 -2
  5. data/Gemfile +1 -1
  6. data/README.md +21 -24
  7. data/Rakefile +3 -3
  8. data/active_model_serializers.gemspec +19 -23
  9. data/docs/general/adapters.md +4 -2
  10. data/docs/general/configuration_options.md +6 -1
  11. data/docs/general/deserialization.md +1 -1
  12. data/docs/general/fields.md +31 -0
  13. data/docs/general/rendering.md +7 -2
  14. data/docs/general/serializers.md +62 -3
  15. data/docs/howto/add_pagination_links.md +2 -3
  16. data/docs/integrations/ember-and-json-api.md +25 -10
  17. data/docs/jsonapi/schema.md +1 -1
  18. data/lib/action_controller/serialization.rb +4 -3
  19. data/lib/active_model/serializer/adapter/base.rb +2 -0
  20. data/lib/active_model/serializer/array_serializer.rb +8 -5
  21. data/lib/active_model/serializer/associations.rb +6 -7
  22. data/lib/active_model/serializer/belongs_to_reflection.rb +0 -3
  23. data/lib/active_model/serializer/caching.rb +67 -112
  24. data/lib/active_model/serializer/collection_serializer.rb +30 -10
  25. data/lib/active_model/serializer/configuration.rb +1 -0
  26. data/lib/active_model/serializer/error_serializer.rb +11 -7
  27. data/lib/active_model/serializer/errors_serializer.rb +25 -20
  28. data/lib/active_model/serializer/has_many_reflection.rb +0 -3
  29. data/lib/active_model/serializer/has_one_reflection.rb +0 -3
  30. data/lib/active_model/serializer/lint.rb +134 -130
  31. data/lib/active_model/serializer/reflection.rb +3 -3
  32. data/lib/active_model/serializer/version.rb +1 -1
  33. data/lib/active_model/serializer.rb +57 -15
  34. data/lib/active_model_serializers/adapter/attributes.rb +2 -67
  35. data/lib/active_model_serializers/adapter/base.rb +38 -38
  36. data/lib/active_model_serializers/adapter/json_api/link.rb +1 -1
  37. data/lib/active_model_serializers/adapter/json_api/pagination_links.rb +8 -1
  38. data/lib/active_model_serializers/adapter/json_api.rb +36 -28
  39. data/lib/active_model_serializers/adapter.rb +6 -0
  40. data/lib/active_model_serializers/deprecate.rb +1 -2
  41. data/lib/active_model_serializers/deserialization.rb +2 -0
  42. data/lib/active_model_serializers/model.rb +3 -1
  43. data/lib/active_model_serializers/railtie.rb +3 -1
  44. data/lib/active_model_serializers/register_jsonapi_renderer.rb +44 -31
  45. data/lib/active_model_serializers/serialization_context.rb +10 -3
  46. data/lib/active_model_serializers.rb +6 -0
  47. data/lib/generators/rails/serializer_generator.rb +3 -3
  48. data/lib/grape/active_model_serializers.rb +7 -5
  49. data/lib/grape/formatters/active_model_serializers.rb +19 -2
  50. data/lib/grape/helpers/active_model_serializers.rb +1 -0
  51. data/test/action_controller/adapter_selector_test.rb +4 -4
  52. data/test/action_controller/explicit_serializer_test.rb +5 -4
  53. data/test/action_controller/json/include_test.rb +106 -27
  54. data/test/action_controller/json_api/errors_test.rb +6 -7
  55. data/test/action_controller/json_api/linked_test.rb +29 -24
  56. data/test/action_controller/json_api/pagination_test.rb +19 -19
  57. data/test/action_controller/serialization_test.rb +10 -7
  58. data/test/active_model_serializers/json_pointer_test.rb +15 -13
  59. data/test/active_model_serializers/key_transform_test.rb +254 -252
  60. data/test/active_model_serializers/model_test.rb +6 -4
  61. data/test/active_model_serializers/register_jsonapi_renderer_test_isolated.rb +143 -0
  62. data/test/active_model_serializers/serialization_context_test_isolated.rb +23 -10
  63. data/test/adapter/json/collection_test.rb +14 -0
  64. data/test/adapter/json/transform_test.rb +14 -14
  65. data/test/adapter/json_api/collection_test.rb +4 -3
  66. data/test/adapter/json_api/errors_test.rb +17 -19
  67. data/test/adapter/json_api/has_many_test.rb +18 -18
  68. data/test/adapter/json_api/json_api_test.rb +5 -7
  69. data/test/adapter/json_api/linked_test.rb +9 -6
  70. data/test/adapter/json_api/links_test.rb +3 -1
  71. data/test/adapter/json_api/pagination_links_test.rb +19 -7
  72. data/test/adapter/json_api/relationships_test.rb +9 -4
  73. data/test/adapter/json_api/resource_identifier_test.rb +7 -2
  74. data/test/adapter/json_api/resource_meta_test.rb +3 -3
  75. data/test/adapter/json_api/transform_test.rb +251 -250
  76. data/test/adapter/json_api/type_test.rb +1 -1
  77. data/test/adapter/json_test.rb +8 -7
  78. data/test/adapter/null_test.rb +1 -2
  79. data/test/adapter/polymorphic_test.rb +5 -5
  80. data/test/adapter_test.rb +1 -1
  81. data/test/benchmark/app.rb +1 -1
  82. data/test/benchmark/bm_caching.rb +15 -15
  83. data/test/benchmark/bm_transform.rb +16 -5
  84. data/test/benchmark/controllers.rb +16 -17
  85. data/test/benchmark/fixtures.rb +72 -72
  86. data/test/cache_test.rb +101 -45
  87. data/test/collection_serializer_test.rb +2 -2
  88. data/test/fixtures/poro.rb +8 -7
  89. data/test/grape_test.rb +152 -56
  90. data/test/lint_test.rb +1 -1
  91. data/test/logger_test.rb +13 -11
  92. data/test/serializable_resource_test.rb +18 -22
  93. data/test/serializers/associations_test.rb +10 -10
  94. data/test/serializers/attribute_test.rb +1 -1
  95. data/test/serializers/attributes_test.rb +1 -1
  96. data/test/serializers/fieldset_test.rb +1 -1
  97. data/test/serializers/meta_test.rb +12 -6
  98. data/test/serializers/root_test.rb +1 -1
  99. data/test/serializers/serializer_for_test.rb +3 -1
  100. data/test/support/isolated_unit.rb +5 -2
  101. data/test/support/rails5_shims.rb +8 -2
  102. data/test/support/rails_app.rb +0 -9
  103. data/test/support/serialization_testing.rb +7 -5
  104. metadata +54 -24
  105. data/.rubocop_todo.yml +0 -167
  106. data/lib/active_model/serializer/include_tree.rb +0 -111
  107. data/test/include_tree/from_include_args_test.rb +0 -26
  108. data/test/include_tree/from_string_test.rb +0 -94
  109. data/test/include_tree/include_args_to_hash_test.rb +0 -64
@@ -7,10 +7,9 @@ module ActiveModel
7
7
  included do
8
8
  with_options instance_writer: false, instance_reader: false do |serializer|
9
9
  serializer.class_attribute :_cache # @api private : the cache store
10
- serializer.class_attribute :_fragmented # @api private : @see ::fragmented
11
10
  serializer.class_attribute :_cache_key # @api private : when present, is first item in cache_key. Ignored if the serializable object defines #cache_key.
12
- serializer.class_attribute :_cache_only # @api private : when fragment caching, whitelists cached_attributes. Cannot combine with except
13
- serializer.class_attribute :_cache_except # @api private : when fragment caching, blacklists cached_attributes. Cannot combine with only
11
+ serializer.class_attribute :_cache_only # @api private : when fragment caching, whitelists fetch_attributes. Cannot combine with except
12
+ serializer.class_attribute :_cache_except # @api private : when fragment caching, blacklists fetch_attributes. Cannot combine with only
14
13
  serializer.class_attribute :_cache_options # @api private : used by CachedSerializer, passed to _cache.fetch
15
14
  # _cache_options include:
16
15
  # expires_in
@@ -19,7 +18,7 @@ module ActiveModel
19
18
  # race_condition_ttl
20
19
  # Passed to ::_cache as
21
20
  # serializer.cache_store.fetch(cache_key, @klass._cache_options)
22
- # Passed as second argument to serializer.cache_store.fetch(cache_key, self.class._cache_options)
21
+ # Passed as second argument to serializer.cache_store.fetch(cache_key, serializer_class._cache_options)
23
22
  serializer.class_attribute :_cache_digest_file_path # @api private : Derived at inheritance
24
23
  end
25
24
  end
@@ -69,19 +68,15 @@ module ActiveModel
69
68
  _cache_options && _cache_options[:skip_digest]
70
69
  end
71
70
 
72
- def cached_attributes
73
- _cache_only ? _cache_only : _attributes - _cache_except
74
- end
75
-
76
- def non_cached_attributes
77
- _attributes - cached_attributes
78
- end
79
-
80
- # @api private
81
- # Used by FragmentCache on the CachedSerializer
82
- # to call attribute methods on the fragmented cached serializer.
83
- def fragmented(serializer)
84
- self._fragmented = serializer
71
+ def fragmented_attributes
72
+ cached = _cache_only ? _cache_only : _attributes - _cache_except
73
+ cached = cached.map! { |field| _attributes_keys.fetch(field, field) }
74
+ non_cached = _attributes - cached
75
+ non_cached = non_cached.map! { |field| _attributes_keys.fetch(field, field) }
76
+ {
77
+ cached: cached,
78
+ non_cached: non_cached
79
+ }
85
80
  end
86
81
 
87
82
  # Enables a serializer to be automatically cached
@@ -163,10 +158,10 @@ module ActiveModel
163
158
 
164
159
  # Read cache from cache_store
165
160
  # @return [Hash]
166
- def cache_read_multi(collection_serializer, adapter_instance, include_tree)
161
+ def cache_read_multi(collection_serializer, adapter_instance, include_directive)
167
162
  return {} if ActiveModelSerializers.config.cache_store.blank?
168
163
 
169
- keys = object_cache_keys(collection_serializer, adapter_instance, include_tree)
164
+ keys = object_cache_keys(collection_serializer, adapter_instance, include_directive)
170
165
 
171
166
  return {} if keys.blank?
172
167
 
@@ -176,15 +171,15 @@ module ActiveModel
176
171
  # Find all cache_key for the collection_serializer
177
172
  # @param serializers [ActiveModel::Serializer::CollectionSerializer]
178
173
  # @param adapter_instance [ActiveModelSerializers::Adapter::Base]
179
- # @param include_tree [ActiveModel::Serializer::IncludeTree]
174
+ # @param include_directive [JSONAPI::IncludeDirective]
180
175
  # @return [Array] all cache_key of collection_serializer
181
- def object_cache_keys(collection_serializer, adapter_instance, include_tree)
176
+ def object_cache_keys(collection_serializer, adapter_instance, include_directive)
182
177
  cache_keys = []
183
178
 
184
179
  collection_serializer.each do |serializer|
185
180
  cache_keys << object_cache_key(serializer, adapter_instance)
186
181
 
187
- serializer.associations(include_tree).each do |association|
182
+ serializer.associations(include_directive).each do |association|
188
183
  if association.serializer.respond_to?(:each)
189
184
  association.serializer.each do |sub_serializer|
190
185
  cache_keys << object_cache_key(sub_serializer, adapter_instance)
@@ -202,116 +197,72 @@ module ActiveModel
202
197
  def object_cache_key(serializer, adapter_instance)
203
198
  return unless serializer.present? && serializer.object.present?
204
199
 
205
- serializer.class.cache_enabled? ? serializer.cache_key(adapter_instance) : nil
200
+ (serializer.class.cache_enabled? || serializer.class.fragment_cache_enabled?) ? serializer.cache_key(adapter_instance) : nil
206
201
  end
207
202
  end
208
203
 
209
- # Get attributes from @cached_attributes
210
- # @return [Hash] cached attributes
211
- # def cached_attributes(fields, adapter_instance)
212
- def cached_fields(fields, adapter_instance)
213
- cache_check(adapter_instance) do
214
- attributes(fields)
204
+ ### INSTANCE METHODS
205
+ def fetch_attributes(fields, cached_attributes, adapter_instance)
206
+ if serializer_class.cache_enabled?
207
+ key = cache_key(adapter_instance)
208
+ cached_attributes.fetch(key) do
209
+ serializer_class.cache_store.fetch(key, serializer_class._cache_options) do
210
+ attributes(fields, true)
211
+ end
212
+ end
213
+ elsif serializer_class.fragment_cache_enabled?
214
+ fetch_attributes_fragment(adapter_instance, cached_attributes)
215
+ else
216
+ attributes(fields, true)
215
217
  end
216
218
  end
217
219
 
218
- def cache_check(adapter_instance)
219
- if self.class.cache_enabled?
220
- self.class.cache_store.fetch(cache_key(adapter_instance), self.class._cache_options) do
220
+ def fetch(adapter_instance, cache_options = serializer_class._cache_options)
221
+ if serializer_class.cache_store
222
+ serializer_class.cache_store.fetch(cache_key(adapter_instance), cache_options) do
221
223
  yield
222
224
  end
223
- elsif self.class.fragment_cache_enabled?
224
- fetch_fragment_cache(adapter_instance)
225
225
  else
226
226
  yield
227
227
  end
228
228
  end
229
229
 
230
- # 1. Create a CachedSerializer and NonCachedSerializer from the serializer class
231
- # 2. Serialize the above two with the given adapter
232
- # 3. Pass their serializations to the adapter +::fragment_cache+
233
- #
234
- # It will split the serializer into two, one that will be cached and one that will not
235
- #
236
- # Given a resource name
237
- # 1. Dynamically creates a CachedSerializer and NonCachedSerializer
238
- # for a given class 'name'
239
- # 2. Call
240
- # CachedSerializer.cache(serializer._cache_options)
241
- # CachedSerializer.fragmented(serializer)
242
- # NonCachedSerializer.cache(serializer._cache_options)
243
- # 3. Build a hash keyed to the +cached+ and +non_cached+ serializers
244
- # 4. Call +cached_attributes+ on the serializer class and the above hash
245
- # 5. Return the hash
246
- #
247
- # @example
248
- # When +name+ is <tt>User::Admin</tt>
249
- # creates the Serializer classes (if they don't exist).
250
- # CachedUser_AdminSerializer
251
- # NonCachedUser_AdminSerializer
252
- #
253
- # Given a hash of its cached and non-cached serializers
254
- # 1. Determine cached attributes from serializer class options
255
- # 2. Add cached attributes to cached Serializer
256
- # 3. Add non-cached attributes to non-cached Serializer
257
- def fetch_fragment_cache(adapter_instance)
258
- serializer_class_name = self.class.name.gsub('::'.freeze, '_'.freeze)
259
- self.class._cache_options ||= {}
260
- self.class._cache_options[:key] = self.class._cache_key if self.class._cache_key
261
-
262
- cached_serializer = _get_or_create_fragment_cached_serializer(serializer_class_name)
263
- cached_hash = ActiveModelSerializers::SerializableResource.new(
264
- object,
265
- serializer: cached_serializer,
266
- adapter: adapter_instance.class
267
- ).serializable_hash
268
-
269
- non_cached_serializer = _get_or_create_fragment_non_cached_serializer(serializer_class_name)
270
- non_cached_hash = ActiveModelSerializers::SerializableResource.new(
271
- object,
272
- serializer: non_cached_serializer,
273
- adapter: adapter_instance.class
274
- ).serializable_hash
275
-
230
+ # 1. Determine cached fields from serializer class options
231
+ # 2. Get non_cached_fields and fetch cache_fields
232
+ # 3. Merge the two hashes using adapter_instance#fragment_cache
233
+ # rubocop:disable Metrics/AbcSize
234
+ def fetch_attributes_fragment(adapter_instance, cached_attributes = {})
235
+ serializer_class._cache_options ||= {}
236
+ serializer_class._cache_options[:key] = serializer_class._cache_key if serializer_class._cache_key
237
+ fields = serializer_class.fragmented_attributes
238
+
239
+ non_cached_fields = fields[:non_cached].dup
240
+ non_cached_hash = attributes(non_cached_fields, true)
241
+ include_directive = JSONAPI::IncludeDirective.new(non_cached_fields - non_cached_hash.keys)
242
+ non_cached_hash.merge! resource_relationships({}, { include_directive: include_directive }, adapter_instance)
243
+
244
+ cached_fields = fields[:cached].dup
245
+ key = cache_key(adapter_instance)
246
+ cached_hash =
247
+ cached_attributes.fetch(key) do
248
+ serializer_class.cache_store.fetch(key, serializer_class._cache_options) do
249
+ hash = attributes(cached_fields, true)
250
+ include_directive = JSONAPI::IncludeDirective.new(cached_fields - hash.keys)
251
+ hash.merge! resource_relationships({}, { include_directive: include_directive }, adapter_instance)
252
+ end
253
+ end
276
254
  # Merge both results
277
255
  adapter_instance.fragment_cache(cached_hash, non_cached_hash)
278
256
  end
279
-
280
- def _get_or_create_fragment_cached_serializer(serializer_class_name)
281
- cached_serializer = _get_or_create_fragment_serializer "Cached#{serializer_class_name}"
282
- cached_serializer.cache(self.class._cache_options)
283
- cached_serializer.type(self.class._type)
284
- cached_serializer.fragmented(self)
285
- self.class.cached_attributes.each do |attribute|
286
- options = self.class._attributes_keys[attribute] || {}
287
- cached_serializer.attribute(attribute, options)
288
- end
289
- cached_serializer
290
- end
291
-
292
- def _get_or_create_fragment_non_cached_serializer(serializer_class_name)
293
- non_cached_serializer = _get_or_create_fragment_serializer "NonCached#{serializer_class_name}"
294
- non_cached_serializer.type(self.class._type)
295
- non_cached_serializer.fragmented(self)
296
- self.class.non_cached_attributes.each do |attribute|
297
- options = self.class._attributes_keys[attribute] || {}
298
- non_cached_serializer.attribute(attribute, options)
299
- end
300
- non_cached_serializer
301
- end
302
-
303
- def _get_or_create_fragment_serializer(name)
304
- return Object.const_get(name) if Object.const_defined?(name)
305
- Object.const_set(name, Class.new(ActiveModel::Serializer))
306
- end
257
+ # rubocop:enable Metrics/AbcSize
307
258
 
308
259
  def cache_key(adapter_instance)
309
260
  return @cache_key if defined?(@cache_key)
310
261
 
311
262
  parts = []
312
263
  parts << object_cache_key
313
- parts << adapter_instance.cached_name
314
- parts << self.class._cache_digest unless self.class._skip_digest?
264
+ parts << adapter_instance.cache_key
265
+ parts << serializer_class._cache_digest unless serializer_class._skip_digest?
315
266
  @cache_key = parts.join('/')
316
267
  end
317
268
 
@@ -320,14 +271,18 @@ module ActiveModel
320
271
  def object_cache_key
321
272
  if object.respond_to?(:cache_key)
322
273
  object.cache_key
323
- elsif (serializer_cache_key = (self.class._cache_key || self.class._cache_options[:key]))
274
+ elsif (serializer_cache_key = (serializer_class._cache_key || serializer_class._cache_options[:key]))
324
275
  object_time_safe = object.updated_at
325
276
  object_time_safe = object_time_safe.strftime('%Y%m%d%H%M%S%9N') if object_time_safe.respond_to?(:strftime)
326
277
  "#{serializer_cache_key}/#{object.id}-#{object_time_safe}"
327
278
  else
328
- fail UndefinedCacheKey, "#{object.class} must define #cache_key, or the 'key:' option must be passed into '#{self.class}.cache'"
279
+ fail UndefinedCacheKey, "#{object.class} must define #cache_key, or the 'key:' option must be passed into '#{serializer_class}.cache'"
329
280
  end
330
281
  end
282
+
283
+ def serializer_class
284
+ @serializer_class ||= self.class
285
+ end
331
286
  end
332
287
  end
333
288
  end
@@ -11,22 +11,23 @@ module ActiveModel
11
11
  @object = resources
12
12
  @options = options
13
13
  @root = options[:root]
14
- serializer_context_class = options.fetch(:serializer_context_class, ActiveModel::Serializer)
15
- @serializers = resources.map do |resource|
16
- serializer_class = options.fetch(:serializer) { serializer_context_class.serializer_for(resource) }
17
-
18
- if serializer_class.nil? # rubocop:disable Style/GuardClause
19
- fail NoSerializerError, "No serializer found for resource: #{resource.inspect}"
20
- else
21
- serializer_class.new(resource, options.except(:serializer))
22
- end
23
- end
14
+ @serializers = serializers_from_resources
24
15
  end
25
16
 
26
17
  def success?
27
18
  true
28
19
  end
29
20
 
21
+ # @api private
22
+ def serializable_hash(adapter_options, options, adapter_instance)
23
+ include_directive = ActiveModel::Serializer.include_directive_from_options(adapter_options)
24
+ adapter_options[:cached_attributes] ||= ActiveModel::Serializer.cache_read_multi(self, adapter_instance, include_directive)
25
+ adapter_opts = adapter_options.merge(include_directive: include_directive)
26
+ serializers.map do |serializer|
27
+ serializer.serializable_hash(adapter_opts, options, adapter_instance)
28
+ end
29
+ end
30
+
30
31
  # TODO: unify naming of root, json_key, and _type. Right now, a serializer's
31
32
  # json_key comes from the root option or the object's model name, by default.
32
33
  # But, if a dev defines a custom `json_key` method with an explicit value,
@@ -59,6 +60,25 @@ module ActiveModel
59
60
  protected
60
61
 
61
62
  attr_reader :serializers, :options
63
+
64
+ private
65
+
66
+ def serializers_from_resources
67
+ serializer_context_class = options.fetch(:serializer_context_class, ActiveModel::Serializer)
68
+ object.map do |resource|
69
+ serializer_from_resource(resource, serializer_context_class, options)
70
+ end
71
+ end
72
+
73
+ def serializer_from_resource(resource, serializer_context_class, options)
74
+ serializer_class = options.fetch(:serializer) { serializer_context_class.serializer_for(resource) }
75
+
76
+ if serializer_class.nil? # rubocop:disable Style/GuardClause
77
+ fail NoSerializerError, "No serializer found for resource: #{resource.inspect}"
78
+ else
79
+ serializer_class.new(resource, options.except(:serializer))
80
+ end
81
+ end
62
82
  end
63
83
  end
64
84
  end
@@ -19,6 +19,7 @@ module ActiveModel
19
19
  collection_serializer
20
20
  end
21
21
 
22
+ config.default_includes = '*'
22
23
  config.adapter = :attributes
23
24
  config.jsonapi_resource_type = :plural
24
25
  config.jsonapi_version = '1.0'
@@ -1,10 +1,14 @@
1
- class ActiveModel::Serializer::ErrorSerializer < ActiveModel::Serializer
2
- # @return [Hash<field_name,Array<error_message>>]
3
- def as_json
4
- object.errors.messages
5
- end
1
+ module ActiveModel
2
+ class Serializer
3
+ class ErrorSerializer < ActiveModel::Serializer
4
+ # @return [Hash<field_name,Array<error_message>>]
5
+ def as_json
6
+ object.errors.messages
7
+ end
6
8
 
7
- def success?
8
- false
9
+ def success?
10
+ false
11
+ end
12
+ end
9
13
  end
10
14
  end
@@ -1,27 +1,32 @@
1
1
  require 'active_model/serializer/error_serializer'
2
- class ActiveModel::Serializer::ErrorsSerializer
3
- include Enumerable
4
- delegate :each, to: :@serializers
5
- attr_reader :object, :root
6
2
 
7
- def initialize(resources, options = {})
8
- @root = options[:root]
9
- @object = resources
10
- @serializers = resources.map do |resource|
11
- serializer_class = options.fetch(:serializer) { ActiveModel::Serializer::ErrorSerializer }
12
- serializer_class.new(resource, options.except(:serializer))
13
- end
14
- end
3
+ module ActiveModel
4
+ class Serializer
5
+ class ErrorsSerializer
6
+ include Enumerable
7
+ delegate :each, to: :@serializers
8
+ attr_reader :object, :root
15
9
 
16
- def success?
17
- false
18
- end
10
+ def initialize(resources, options = {})
11
+ @root = options[:root]
12
+ @object = resources
13
+ @serializers = resources.map do |resource|
14
+ serializer_class = options.fetch(:serializer) { ActiveModel::Serializer::ErrorSerializer }
15
+ serializer_class.new(resource, options.except(:serializer))
16
+ end
17
+ end
19
18
 
20
- def json_key
21
- nil
22
- end
19
+ def success?
20
+ false
21
+ end
23
22
 
24
- protected
23
+ def json_key
24
+ nil
25
+ end
25
26
 
26
- attr_reader :serializers
27
+ protected
28
+
29
+ attr_reader :serializers
30
+ end
31
+ end
27
32
  end
@@ -2,9 +2,6 @@ module ActiveModel
2
2
  class Serializer
3
3
  # @api private
4
4
  class HasManyReflection < CollectionReflection
5
- def macro
6
- :has_many
7
- end
8
5
  end
9
6
  end
10
7
  end
@@ -2,9 +2,6 @@ module ActiveModel
2
2
  class Serializer
3
3
  # @api private
4
4
  class HasOneReflection < SingularReflection
5
- def macro
6
- :has_one
7
- end
8
5
  end
9
6
  end
10
7
  end