mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-24 14:56:50 +00:00
Implement meta and meta_key for AM::Serializer
This commit is contained in:
parent
af357619c1
commit
93baaa96b1
@ -28,12 +28,14 @@ module ActiveModel
|
|||||||
end
|
end
|
||||||
|
|
||||||
def initialize(object, options={})
|
def initialize(object, options={})
|
||||||
@object = object
|
@object = object
|
||||||
@root = options[:root] || self.class._root
|
@root = options[:root] || self.class._root
|
||||||
@root = self.class.root_name if @root == true
|
@root = self.class.root_name if @root == true
|
||||||
@scope = options[:scope]
|
@scope = options[:scope]
|
||||||
|
@meta_key = options[:meta_key] || :meta
|
||||||
|
@meta = options[@meta_key]
|
||||||
end
|
end
|
||||||
attr_accessor :object, :root, :scope
|
attr_accessor :object, :root, :scope, :meta_key, :meta
|
||||||
|
|
||||||
alias read_attribute_for_serialization send
|
alias read_attribute_for_serialization send
|
||||||
|
|
||||||
@ -50,7 +52,9 @@ module ActiveModel
|
|||||||
|
|
||||||
def as_json(options={})
|
def as_json(options={})
|
||||||
if root = options[:root] || self.root
|
if root = options[:root] || self.root
|
||||||
{ root.to_s => serializable_hash }
|
hash = { root.to_s => serializable_hash }
|
||||||
|
hash[meta_key.to_s] = meta if meta
|
||||||
|
hash
|
||||||
else
|
else
|
||||||
serializable_hash
|
serializable_hash
|
||||||
end
|
end
|
||||||
|
|||||||
41
test/unit/active_model/serializer/meta_test.rb
Normal file
41
test/unit/active_model/serializer/meta_test.rb
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
require 'newbase/test_helper'
|
||||||
|
require 'newbase/active_model/serializer'
|
||||||
|
|
||||||
|
|
||||||
|
module ActiveModel
|
||||||
|
class Serializer
|
||||||
|
class MetaTest < ActiveModel::TestCase
|
||||||
|
def setup
|
||||||
|
@model = Model.new({ :attr1 => 'value1', :attr2 => 'value2', :attr3 => 'value3' })
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_meta
|
||||||
|
model_serializer = ModelSerializer.new(@model, root: 'model', meta: { 'total' => 10 })
|
||||||
|
|
||||||
|
assert_equal({
|
||||||
|
'model' => {
|
||||||
|
'attr1' => 'value1',
|
||||||
|
'attr2' => 'value2'
|
||||||
|
},
|
||||||
|
'meta' => {
|
||||||
|
'total' => 10
|
||||||
|
}
|
||||||
|
}, model_serializer.as_json)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_meta_using_meta_key
|
||||||
|
model_serializer = ModelSerializer.new(@model, root: 'model', meta_key: :my_meta, my_meta: { 'total' => 10 })
|
||||||
|
|
||||||
|
assert_equal({
|
||||||
|
'model' => {
|
||||||
|
'attr1' => 'value1',
|
||||||
|
'attr2' => 'value2'
|
||||||
|
},
|
||||||
|
'my_meta' => {
|
||||||
|
'total' => 10
|
||||||
|
}
|
||||||
|
}, model_serializer.as_json)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
Loading…
Reference in New Issue
Block a user