mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-24 14:56:50 +00:00
Move Adapter.adapter_for to Serializer.adapter
This commit is contained in:
parent
a6f9dae560
commit
b1f7a5ccda
@ -12,7 +12,7 @@ module ActionController
|
|||||||
if serializer
|
if serializer
|
||||||
# omg hax
|
# omg hax
|
||||||
object = serializer.new(resource)
|
object = serializer.new(resource)
|
||||||
adapter = ActiveModel::Serializer::Adapter.adapter_for(object)
|
adapter = ActiveModel::Serializer.adapter.new(object)
|
||||||
|
|
||||||
super(adapter, options)
|
super(adapter, options)
|
||||||
else
|
else
|
||||||
|
|||||||
@ -74,6 +74,24 @@ module ActiveModel
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def self.adapter
|
||||||
|
adapter_class = case config.adapter
|
||||||
|
when Symbol
|
||||||
|
class_name = "ActiveModel::Serializer::Adapter::#{config.adapter.to_s.classify}Adapter"
|
||||||
|
if Object.const_defined?(class_name)
|
||||||
|
Object.const_get(class_name)
|
||||||
|
end
|
||||||
|
when Class
|
||||||
|
config.adapter
|
||||||
|
end
|
||||||
|
unless adapter_class
|
||||||
|
valid_adapters = Adapter.constants.map { |klass| ":#{klass.to_s.sub('Adapter', '').downcase}" }
|
||||||
|
raise ArgumentError, "Unknown adapter: #{config.adapter}. Valid adapters are: #{valid_adapters}"
|
||||||
|
end
|
||||||
|
|
||||||
|
adapter_class
|
||||||
|
end
|
||||||
|
|
||||||
attr_accessor :object
|
attr_accessor :object
|
||||||
|
|
||||||
def initialize(object)
|
def initialize(object)
|
||||||
|
|||||||
@ -18,24 +18,6 @@ module ActiveModel
|
|||||||
def to_json(options={})
|
def to_json(options={})
|
||||||
serializable_hash(options).to_json
|
serializable_hash(options).to_json
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.adapter_for(serializer)
|
|
||||||
adapter_class = case serializer.config.adapter
|
|
||||||
when Symbol
|
|
||||||
class_name = "ActiveModel::Serializer::Adapter::#{serializer.config.adapter.to_s.classify}Adapter"
|
|
||||||
if Object.const_defined?(class_name)
|
|
||||||
Object.const_get(class_name)
|
|
||||||
end
|
|
||||||
when Class
|
|
||||||
serializer.config.adapter
|
|
||||||
end
|
|
||||||
unless adapter_class
|
|
||||||
valid_adapters = self.constants.map { |klass| ":#{klass.to_s.sub('Adapter', '').downcase}" }
|
|
||||||
raise ArgumentError, "Unknown adapter: #{serializer.config.adapter}. Valid adapters are: #{valid_adapters}"
|
|
||||||
end
|
|
||||||
|
|
||||||
adapter_class.new(serializer)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -19,54 +19,5 @@ module ActiveModel
|
|||||||
assert_equal @serializer, @adapter.serializer
|
assert_equal @serializer, @adapter.serializer
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class AdapterForTest < Minitest::Test
|
|
||||||
def setup
|
|
||||||
profile = Profile.new
|
|
||||||
@serializer = ProfileSerializer.new(profile)
|
|
||||||
@previous_adapter = ActiveModel::Serializer.config.adapter
|
|
||||||
end
|
|
||||||
|
|
||||||
def teardown
|
|
||||||
ActiveModel::Serializer.config.adapter = @previous_adapter
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_returns_default_adapter
|
|
||||||
adapter = Adapter.adapter_for(@serializer)
|
|
||||||
assert_kind_of ActiveModel::Serializer::Adapter::SimpleAdapter, adapter
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_overwrite_adapter_with_symbol
|
|
||||||
ActiveModel::Serializer.config.adapter = :null
|
|
||||||
|
|
||||||
adapter = Adapter.adapter_for(@serializer)
|
|
||||||
assert_kind_of ActiveModel::Serializer::Adapter::NullAdapter, adapter
|
|
||||||
ensure
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_overwrite_adapter_with_class
|
|
||||||
ActiveModel::Serializer.config.adapter = ActiveModel::Serializer::Adapter::NullAdapter
|
|
||||||
|
|
||||||
adapter = Adapter.adapter_for(@serializer)
|
|
||||||
assert_kind_of ActiveModel::Serializer::Adapter::NullAdapter, adapter
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_raises_exception_if_invalid_symbol_given
|
|
||||||
ActiveModel::Serializer.config.adapter = :unknown
|
|
||||||
|
|
||||||
assert_raises ArgumentError do
|
|
||||||
Adapter.adapter_for(@serializer)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_raises_exception_if_it_does_not_know_hot_to_infer_adapter
|
|
||||||
ActiveModel::Serializer.config.adapter = 42
|
|
||||||
|
|
||||||
assert_raises ArgumentError do
|
|
||||||
Adapter.adapter_for(@serializer)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
50
test/serializers/adapter_for_test.rb
Normal file
50
test/serializers/adapter_for_test.rb
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
module ActiveModel
|
||||||
|
class Serializer
|
||||||
|
class AdapterForTest < Minitest::Test
|
||||||
|
def setup
|
||||||
|
@previous_adapter = ActiveModel::Serializer.config.adapter
|
||||||
|
end
|
||||||
|
|
||||||
|
def teardown
|
||||||
|
ActiveModel::Serializer.config.adapter = @previous_adapter
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_returns_default_adapter
|
||||||
|
adapter = ActiveModel::Serializer.adapter
|
||||||
|
assert_equal ActiveModel::Serializer::Adapter::SimpleAdapter, adapter
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_overwrite_adapter_with_symbol
|
||||||
|
ActiveModel::Serializer.config.adapter = :null
|
||||||
|
|
||||||
|
adapter = ActiveModel::Serializer.adapter
|
||||||
|
assert_equal ActiveModel::Serializer::Adapter::NullAdapter, adapter
|
||||||
|
ensure
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_overwrite_adapter_with_class
|
||||||
|
ActiveModel::Serializer.config.adapter = ActiveModel::Serializer::Adapter::NullAdapter
|
||||||
|
|
||||||
|
adapter = ActiveModel::Serializer.adapter
|
||||||
|
assert_equal ActiveModel::Serializer::Adapter::NullAdapter, adapter
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_raises_exception_if_invalid_symbol_given
|
||||||
|
ActiveModel::Serializer.config.adapter = :unknown
|
||||||
|
|
||||||
|
assert_raises ArgumentError do
|
||||||
|
ActiveModel::Serializer.adapter
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_raises_exception_if_it_does_not_know_hot_to_infer_adapter
|
||||||
|
ActiveModel::Serializer.config.adapter = 42
|
||||||
|
|
||||||
|
assert_raises ArgumentError do
|
||||||
|
ActiveModel::Serializer.adapter
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
Loading…
Reference in New Issue
Block a user