mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-22 22:06:50 +00:00
Close #86
This commit is contained in:
parent
b91e63c4ec
commit
2b9cd97436
@ -257,7 +257,7 @@ module ActiveModel
|
||||
end
|
||||
|
||||
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)
|
||||
class_eval "def #{attr}() object.read_attribute_for_serialization(:#{attr}) end", __FILE__, __LINE__
|
||||
@ -522,4 +522,4 @@ module ActiveModel
|
||||
ActiveSupport::Notifications.instrument("#{name}.serializer", payload, &block)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@ -890,4 +890,48 @@ class SerializerTest < ActiveModel::TestCase
|
||||
end
|
||||
assert_equal ActiveModel::Serializer, loaded
|
||||
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
|
||||
|
||||
Loading…
Reference in New Issue
Block a user