mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-23 06:16:50 +00:00
commit
3e87c6414d
@ -263,7 +263,7 @@ module ActiveModel
|
|||||||
end
|
end
|
||||||
|
|
||||||
def attribute(attr, options={})
|
def attribute(attr, options={})
|
||||||
self._attributes = _attributes.merge(attr => options[:key] || attr)
|
self._attributes = _attributes.merge(attr => options[:key] || attr.to_s.gsub(/\?$/, '').to_sym)
|
||||||
|
|
||||||
unless method_defined?(attr)
|
unless method_defined?(attr)
|
||||||
class_eval "def #{attr}() object.read_attribute_for_serialization(:#{attr}) end", __FILE__, __LINE__
|
class_eval "def #{attr}() object.read_attribute_for_serialization(:#{attr}) end", __FILE__, __LINE__
|
||||||
|
|||||||
@ -908,4 +908,48 @@ class SerializerTest < ActiveModel::TestCase
|
|||||||
end
|
end
|
||||||
assert_equal ActiveModel::Serializer, loaded
|
assert_equal ActiveModel::Serializer, loaded
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def tests_query_attributes_strip_question_mark
|
||||||
|
todo = Class.new do
|
||||||
|
def overdue?
|
||||||
|
true
|
||||||
|
end
|
||||||
|
|
||||||
|
def read_attribute_for_serialization(name)
|
||||||
|
send name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
serializer = Class.new(ActiveModel::Serializer) do
|
||||||
|
attribute :overdue?
|
||||||
|
end
|
||||||
|
|
||||||
|
actual = serializer.new(todo.new).as_json
|
||||||
|
|
||||||
|
assert_equal({
|
||||||
|
:overdue => true
|
||||||
|
}, actual)
|
||||||
|
end
|
||||||
|
|
||||||
|
def tests_query_attributes_allow_key_option
|
||||||
|
todo = Class.new do
|
||||||
|
def overdue?
|
||||||
|
true
|
||||||
|
end
|
||||||
|
|
||||||
|
def read_attribute_for_serialization(name)
|
||||||
|
send name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
serializer = Class.new(ActiveModel::Serializer) do
|
||||||
|
attribute :overdue?, :key => :foo
|
||||||
|
end
|
||||||
|
|
||||||
|
actual = serializer.new(todo.new).as_json
|
||||||
|
|
||||||
|
assert_equal({
|
||||||
|
:foo => true
|
||||||
|
}, actual)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user