Skip to content

Commit

Permalink
Adds polymorphic tests and documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
wolovim committed Mar 15, 2016
1 parent 7d4f0c5 commit e4afbdc
Show file tree
Hide file tree
Showing 4 changed files with 113 additions and 0 deletions.
12 changes: 12 additions & 0 deletions docs/general/serializers.md
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,18 @@ def blog
end
```

### Polymorphic Relationships

Polymorphic relationships are serialized by specifying the relationship, like any other association. For example:

```ruby
class PictureSerializer < ActiveModel::Serializer
has_one :imageable
end
```

For more context, see the [tests](../../test/adapter/polymorphic_test.rb) for each adapter.

### Caching

#### ::cache
Expand Down
72 changes: 72 additions & 0 deletions test/adapter/polymorphic_test.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
require 'test_helper'

module ActiveModel
class Serializer
module Adapter
class PolymorphicTest < ActiveSupport::TestCase
setup do
@employee = Employee.new(id: 42, name: 'Zoop Zoopler', email: 'zoop@example.com')
@picture = @employee.pictures.new(id: 1, title: 'headshot-1.jpg')
@picture.imageable = @employee

@attributes_serialization = serializable(@picture, serializer: PolymorphicBelongsToSerializer) # uses default adapter: attributes
@json_serialization = serializable(@picture, adapter: :json, serializer: PolymorphicBelongsToSerializer)
@json_api_serialization = serializable(@picture, adapter: :json_api, serializer: PolymorphicBelongsToSerializer)
end

def test_attributes_serialization
expected =
{
id: 1,
title: 'headshot-1.jpg',
imageable: {
id: 42,
name: 'Zoop Zoopler'
}
}

assert_equal(expected, @attributes_serialization.as_json)
end

def test_json_serializer
expected =
{
picture: {
id: 1,
title: 'headshot-1.jpg',
imageable: {
id: 42,
name: 'Zoop Zoopler'
}
}
}

assert_equal(expected, @json_serialization.as_json)
end

def test_json_api_serializer
expected =
{
data: {
id: '1',
type: 'pictures',
attributes: {
title: 'headshot-1.jpg'
},
relationships: {
imageable: {
data: {
id: '42',
type: 'employees'
}
}
}
}
}

assert_equal(expected, @json_api_serialization.as_json)
end
end
end
end
end
11 changes: 11 additions & 0 deletions test/fixtures/active_record.rb
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,17 @@
t.references :post
t.timestamp null: false
end
create_table :employees, force: true do |t|
t.string :name
t.string :email
t.timestamp null: false
end
create_table :pictures, force: true do |t|
t.string :title
t.string :imageable_type
t.string :imageable_id
t.timestamp null: false
end
end

module ARModels
Expand Down
18 changes: 18 additions & 0 deletions test/fixtures/poro.rb
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,14 @@ def cache_key
end
end

class Employee < ActiveRecord::Base
has_many :pictures, as: :imageable
end

class Picture < ActiveRecord::Base
belongs_to :imageable, polymorphic: true
end

module Spam; end
Spam::UnrelatedLink = Class.new(Model)

Expand Down Expand Up @@ -230,6 +238,16 @@ def maker
end
end

PolymorphicHasManySerializer = Class.new(ActiveModel::Serializer) do
attributes :id, :name
end

PolymorphicBelongsToSerializer = Class.new(ActiveModel::Serializer) do
attributes :id, :title

has_one :imageable, serializer: PolymorphicHasManySerializer
end

Spam::UnrelatedLinkSerializer = Class.new(ActiveModel::Serializer) do
cache only: [:id]
attributes :id
Expand Down

0 comments on commit e4afbdc

Please sign in to comment.