Skip to content

Commit 3925f93

Browse files
committed
Merge pull request #1 from metermd/master
Allow for the implicit use of ArraySerializer when :each_serializer is specified
2 parents c84430c + 58b6c4a commit 3925f93

File tree

3 files changed

+38
-6
lines changed

3 files changed

+38
-6
lines changed

README.md

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -107,7 +107,12 @@ If you wish to use a serializer other than the default, you can explicitly pass
107107
#### 2. For an array resource:
108108

109109
```ruby
110-
render json: @posts, serializer: PaginatedSerializer, each_serializer: PostPreviewSerializer
110+
# Use the default `ArraySerializer`, which will use `each_serializer` to
111+
# serialize each element
112+
render json: @posts, each_serializer: PostPreviewSerializer
113+
114+
# Or, you can explicitly provide the collection serializer as well
115+
render json: @posts, serializer: PaginatedSerializer, each_serializer: PostPreviewSerializer
111116
```
112117

113118
## Installation

lib/action_controller/serialization.rb

Lines changed: 7 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -9,12 +9,14 @@ module Serialization
99
ADAPTER_OPTION_KEYS = [:include, :root]
1010

1111
def get_serializer(resource, options)
12-
@_serializer ||= if (serializer = options.delete :serializer)
13-
options[:serializer] = options.delete :each_serializer
14-
serializer
15-
else
16-
ActiveModel::Serializer.serializer_for(resource)
12+
@_serializer ||= options.delete(:serializer)
13+
@_serializer ||= ActiveModel::Serializer.serializer_for(resource)
14+
15+
if options.key?(:each_serializer)
16+
options[:serializer] = options.delete(:each_serializer)
1717
end
18+
19+
@_serializer
1820
end
1921

2022
[:_render_option_json, :_render_with_renderer_json].each do |renderer_method|

test/action_controller/explicit_serializer_test.rb

Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,19 @@ def render_array_using_explicit_serializer
2424
serializer: PaginatedSerializer,
2525
each_serializer: ProfilePreviewSerializer
2626
end
27+
28+
def render_array_using_implicit_serializer
29+
array = [
30+
Profile.new(name: 'Name 1',
31+
description: 'Description 1',
32+
comments: 'Comments 1'),
33+
Profile.new(name: 'Name 2',
34+
description: 'Description 2',
35+
comments: 'Comments 2')
36+
]
37+
render json: array,
38+
each_serializer: ProfilePreviewSerializer
39+
end
2740
end
2841

2942
tests MyController
@@ -48,6 +61,18 @@ def test_render_array_using_explicit_serializer
4861

4962
assert_equal expected.to_json, @response.body
5063
end
64+
65+
def test_render_array_using_explicit_serializer
66+
get :render_array_using_implicit_serializer
67+
assert_equal 'application/json', @response.content_type
68+
69+
expected = [
70+
{ 'name' => 'Name 1' },
71+
{ 'name' => 'Name 2' }
72+
]
73+
assert_equal expected.to_json, @response.body
74+
end
75+
5176
end
5277
end
5378
end

0 commit comments

Comments
 (0)