active_model_serializers 0.10.3 → 0.10.12
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/CHANGELOG.md +154 -2
- data/README.md +153 -15
- data/lib/action_controller/serialization.rb +11 -1
- data/lib/active_model/serializable_resource.rb +2 -0
- data/lib/active_model/serializer.rb +275 -81
- data/lib/active_model/serializer/adapter.rb +2 -0
- data/lib/active_model/serializer/adapter/attributes.rb +2 -0
- data/lib/active_model/serializer/adapter/base.rb +2 -0
- data/lib/active_model/serializer/adapter/json.rb +2 -0
- data/lib/active_model/serializer/adapter/json_api.rb +2 -0
- data/lib/active_model/serializer/adapter/null.rb +2 -0
- data/lib/active_model/serializer/array_serializer.rb +2 -0
- data/lib/active_model/serializer/association.rb +53 -14
- data/lib/active_model/serializer/attribute.rb +2 -0
- data/lib/active_model/serializer/belongs_to_reflection.rb +7 -1
- data/lib/active_model/serializer/collection_serializer.rb +8 -5
- data/lib/active_model/serializer/concerns/caching.rb +36 -23
- data/lib/active_model/serializer/error_serializer.rb +2 -0
- data/lib/active_model/serializer/errors_serializer.rb +2 -0
- data/lib/active_model/serializer/field.rb +2 -0
- data/lib/active_model/serializer/fieldset.rb +3 -1
- data/lib/active_model/serializer/has_many_reflection.rb +6 -1
- data/lib/active_model/serializer/has_one_reflection.rb +3 -1
- data/lib/active_model/serializer/lazy_association.rb +99 -0
- data/lib/active_model/serializer/link.rb +23 -0
- data/lib/active_model/serializer/lint.rb +2 -0
- data/lib/active_model/serializer/null.rb +2 -0
- data/lib/active_model/serializer/reflection.rb +122 -73
- data/lib/active_model/serializer/version.rb +3 -1
- data/lib/active_model_serializers.rb +29 -11
- data/lib/active_model_serializers/adapter.rb +3 -1
- data/lib/active_model_serializers/adapter/attributes.rb +23 -0
- data/lib/active_model_serializers/adapter/base.rb +4 -2
- data/lib/active_model_serializers/adapter/json.rb +2 -0
- data/lib/active_model_serializers/adapter/json_api.rb +44 -26
- data/lib/active_model_serializers/adapter/json_api/deserialization.rb +4 -2
- data/lib/active_model_serializers/adapter/json_api/error.rb +2 -0
- data/lib/active_model_serializers/adapter/json_api/jsonapi.rb +2 -0
- data/lib/active_model_serializers/adapter/json_api/link.rb +2 -0
- data/lib/active_model_serializers/adapter/json_api/meta.rb +2 -0
- data/lib/active_model_serializers/adapter/json_api/pagination_links.rb +42 -21
- data/lib/active_model_serializers/adapter/json_api/relationship.rb +52 -9
- data/lib/active_model_serializers/adapter/json_api/resource_identifier.rb +35 -18
- data/lib/active_model_serializers/adapter/null.rb +2 -0
- data/lib/active_model_serializers/callbacks.rb +2 -0
- data/lib/active_model_serializers/deprecate.rb +2 -0
- data/lib/active_model_serializers/deserialization.rb +2 -0
- data/lib/active_model_serializers/json_pointer.rb +2 -0
- data/lib/active_model_serializers/logging.rb +2 -0
- data/lib/active_model_serializers/lookup_chain.rb +2 -0
- data/lib/active_model_serializers/model.rb +111 -30
- data/lib/active_model_serializers/model/caching.rb +25 -0
- data/lib/active_model_serializers/railtie.rb +4 -0
- data/lib/active_model_serializers/register_jsonapi_renderer.rb +2 -0
- data/lib/active_model_serializers/serializable_resource.rb +4 -2
- data/lib/active_model_serializers/serialization_context.rb +2 -0
- data/lib/active_model_serializers/test.rb +2 -0
- data/lib/active_model_serializers/test/schema.rb +4 -2
- data/lib/active_model_serializers/test/serializer.rb +2 -0
- data/lib/generators/rails/resource_override.rb +3 -1
- data/lib/generators/rails/serializer_generator.rb +2 -0
- data/lib/grape/active_model_serializers.rb +2 -0
- data/lib/grape/formatters/active_model_serializers.rb +2 -0
- data/lib/grape/helpers/active_model_serializers.rb +2 -0
- data/lib/tasks/rubocop.rake +55 -0
- metadata +74 -291
- data/.github/ISSUE_TEMPLATE.md +0 -29
- data/.github/PULL_REQUEST_TEMPLATE.md +0 -15
- data/.gitignore +0 -35
- data/.rubocop.yml +0 -102
- data/.simplecov +0 -110
- data/.travis.yml +0 -51
- data/CODE_OF_CONDUCT.md +0 -74
- data/CONTRIBUTING.md +0 -105
- data/Gemfile +0 -56
- data/Rakefile +0 -103
- data/active_model_serializers.gemspec +0 -62
- data/appveyor.yml +0 -24
- data/bin/bench +0 -171
- data/bin/bench_regression +0 -316
- data/bin/serve_benchmark +0 -39
- data/docs/ARCHITECTURE.md +0 -125
- data/docs/README.md +0 -42
- data/docs/STYLE.md +0 -58
- data/docs/general/adapters.md +0 -247
- data/docs/general/caching.md +0 -58
- data/docs/general/configuration_options.md +0 -169
- data/docs/general/deserialization.md +0 -100
- data/docs/general/fields.md +0 -31
- data/docs/general/getting_started.md +0 -133
- data/docs/general/instrumentation.md +0 -40
- data/docs/general/key_transforms.md +0 -40
- data/docs/general/logging.md +0 -14
- data/docs/general/rendering.md +0 -294
- data/docs/general/serializers.md +0 -461
- data/docs/how-open-source-maintained.jpg +0 -0
- data/docs/howto/add_pagination_links.md +0 -138
- data/docs/howto/add_relationship_links.md +0 -137
- data/docs/howto/add_root_key.md +0 -55
- data/docs/howto/grape_integration.md +0 -42
- data/docs/howto/outside_controller_use.md +0 -65
- data/docs/howto/passing_arbitrary_options.md +0 -27
- data/docs/howto/serialize_poro.md +0 -32
- data/docs/howto/test.md +0 -154
- data/docs/howto/upgrade_from_0_8_to_0_10.md +0 -265
- data/docs/integrations/ember-and-json-api.md +0 -144
- data/docs/integrations/grape.md +0 -19
- data/docs/jsonapi/errors.md +0 -56
- data/docs/jsonapi/schema.md +0 -151
- data/docs/jsonapi/schema/schema.json +0 -366
- data/docs/rfcs/0000-namespace.md +0 -106
- data/docs/rfcs/template.md +0 -15
- data/lib/active_model/serializer/collection_reflection.rb +0 -7
- data/lib/active_model/serializer/concerns/associations.rb +0 -102
- data/lib/active_model/serializer/concerns/attributes.rb +0 -82
- data/lib/active_model/serializer/concerns/configuration.rb +0 -59
- data/lib/active_model/serializer/concerns/links.rb +0 -35
- data/lib/active_model/serializer/concerns/meta.rb +0 -29
- data/lib/active_model/serializer/concerns/type.rb +0 -25
- data/lib/active_model/serializer/singular_reflection.rb +0 -7
- data/lib/active_model_serializers/key_transform.rb +0 -74
- data/test/action_controller/adapter_selector_test.rb +0 -53
- data/test/action_controller/explicit_serializer_test.rb +0 -135
- data/test/action_controller/json/include_test.rb +0 -246
- data/test/action_controller/json_api/deserialization_test.rb +0 -112
- data/test/action_controller/json_api/errors_test.rb +0 -40
- data/test/action_controller/json_api/fields_test.rb +0 -57
- data/test/action_controller/json_api/linked_test.rb +0 -202
- data/test/action_controller/json_api/pagination_test.rb +0 -116
- data/test/action_controller/json_api/transform_test.rb +0 -181
- data/test/action_controller/lookup_proc_test.rb +0 -49
- data/test/action_controller/namespace_lookup_test.rb +0 -226
- data/test/action_controller/serialization_scope_name_test.rb +0 -229
- data/test/action_controller/serialization_test.rb +0 -472
- data/test/active_model_serializers/adapter_for_test.rb +0 -208
- data/test/active_model_serializers/json_pointer_test.rb +0 -22
- data/test/active_model_serializers/key_transform_test.rb +0 -297
- data/test/active_model_serializers/logging_test.rb +0 -77
- data/test/active_model_serializers/model_test.rb +0 -22
- data/test/active_model_serializers/railtie_test_isolated.rb +0 -63
- data/test/active_model_serializers/register_jsonapi_renderer_test_isolated.rb +0 -143
- data/test/active_model_serializers/serialization_context_test_isolated.rb +0 -71
- data/test/active_model_serializers/test/schema_test.rb +0 -130
- data/test/active_model_serializers/test/serializer_test.rb +0 -62
- data/test/active_record_test.rb +0 -9
- data/test/adapter/attributes_test.rb +0 -43
- data/test/adapter/deprecation_test.rb +0 -100
- data/test/adapter/json/belongs_to_test.rb +0 -45
- data/test/adapter/json/collection_test.rb +0 -104
- data/test/adapter/json/has_many_test.rb +0 -45
- data/test/adapter/json/transform_test.rb +0 -93
- data/test/adapter/json_api/belongs_to_test.rb +0 -155
- data/test/adapter/json_api/collection_test.rb +0 -96
- data/test/adapter/json_api/errors_test.rb +0 -76
- data/test/adapter/json_api/fields_test.rb +0 -88
- data/test/adapter/json_api/has_many_embed_ids_test.rb +0 -43
- data/test/adapter/json_api/has_many_explicit_serializer_test.rb +0 -96
- data/test/adapter/json_api/has_many_test.rb +0 -165
- data/test/adapter/json_api/has_one_test.rb +0 -80
- data/test/adapter/json_api/include_data_if_sideloaded_test.rb +0 -166
- data/test/adapter/json_api/json_api_test.rb +0 -33
- data/test/adapter/json_api/linked_test.rb +0 -413
- data/test/adapter/json_api/links_test.rb +0 -95
- data/test/adapter/json_api/pagination_links_test.rb +0 -193
- data/test/adapter/json_api/parse_test.rb +0 -137
- data/test/adapter/json_api/relationship_test.rb +0 -397
- data/test/adapter/json_api/resource_identifier_test.rb +0 -110
- data/test/adapter/json_api/resource_meta_test.rb +0 -100
- data/test/adapter/json_api/toplevel_jsonapi_test.rb +0 -82
- data/test/adapter/json_api/transform_test.rb +0 -504
- data/test/adapter/json_api/type_test.rb +0 -61
- data/test/adapter/json_test.rb +0 -46
- data/test/adapter/null_test.rb +0 -22
- data/test/adapter/polymorphic_test.rb +0 -171
- data/test/adapter_test.rb +0 -67
- data/test/array_serializer_test.rb +0 -22
- data/test/benchmark/app.rb +0 -65
- data/test/benchmark/benchmarking_support.rb +0 -67
- data/test/benchmark/bm_active_record.rb +0 -81
- data/test/benchmark/bm_adapter.rb +0 -38
- data/test/benchmark/bm_caching.rb +0 -119
- data/test/benchmark/bm_lookup_chain.rb +0 -83
- data/test/benchmark/bm_transform.rb +0 -45
- data/test/benchmark/config.ru +0 -3
- data/test/benchmark/controllers.rb +0 -83
- data/test/benchmark/fixtures.rb +0 -219
- data/test/cache_test.rb +0 -579
- data/test/collection_serializer_test.rb +0 -110
- data/test/fixtures/active_record.rb +0 -78
- data/test/fixtures/poro.rb +0 -286
- data/test/generators/scaffold_controller_generator_test.rb +0 -24
- data/test/generators/serializer_generator_test.rb +0 -74
- data/test/grape_test.rb +0 -178
- data/test/lint_test.rb +0 -49
- data/test/logger_test.rb +0 -20
- data/test/poro_test.rb +0 -9
- data/test/serializable_resource_test.rb +0 -79
- data/test/serializers/association_macros_test.rb +0 -37
- data/test/serializers/associations_test.rb +0 -370
- data/test/serializers/attribute_test.rb +0 -151
- data/test/serializers/attributes_test.rb +0 -52
- data/test/serializers/caching_configuration_test_isolated.rb +0 -170
- data/test/serializers/configuration_test.rb +0 -32
- data/test/serializers/fieldset_test.rb +0 -14
- data/test/serializers/meta_test.rb +0 -202
- data/test/serializers/options_test.rb +0 -21
- data/test/serializers/read_attribute_for_serialization_test.rb +0 -79
- data/test/serializers/root_test.rb +0 -21
- data/test/serializers/serialization_test.rb +0 -55
- data/test/serializers/serializer_for_test.rb +0 -136
- data/test/serializers/serializer_for_with_namespace_test.rb +0 -87
- data/test/support/custom_schemas/active_model_serializers/test/schema_test/my/index.json +0 -6
- data/test/support/isolated_unit.rb +0 -82
- data/test/support/rails5_shims.rb +0 -53
- data/test/support/rails_app.rb +0 -36
- data/test/support/schemas/active_model_serializers/test/schema_test/my/index.json +0 -6
- data/test/support/schemas/active_model_serializers/test/schema_test/my/show.json +0 -6
- data/test/support/schemas/custom/show.json +0 -7
- data/test/support/schemas/hyper_schema.json +0 -93
- data/test/support/schemas/render_using_json_api.json +0 -43
- data/test/support/schemas/simple_json_pointers.json +0 -10
- data/test/support/serialization_testing.rb +0 -71
- data/test/test_helper.rb +0 -58
@@ -1,52 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
module ActiveModel
|
4
|
-
class Serializer
|
5
|
-
class AttributesTest < ActiveSupport::TestCase
|
6
|
-
def setup
|
7
|
-
@profile = Profile.new(name: 'Name 1', description: 'Description 1', comments: 'Comments 1')
|
8
|
-
@profile_serializer = ProfileSerializer.new(@profile)
|
9
|
-
@comment = Comment.new(id: 1, body: 'ZOMG!!', date: '2015')
|
10
|
-
@serializer_klass = Class.new(CommentSerializer)
|
11
|
-
@serializer_klass_with_new_attributes = Class.new(CommentSerializer) do
|
12
|
-
attributes :date, :likes
|
13
|
-
end
|
14
|
-
end
|
15
|
-
|
16
|
-
def test_attributes_definition
|
17
|
-
assert_equal([:name, :description],
|
18
|
-
@profile_serializer.class._attributes)
|
19
|
-
end
|
20
|
-
|
21
|
-
def test_attributes_inheritance_definition
|
22
|
-
assert_equal([:id, :body], @serializer_klass._attributes)
|
23
|
-
end
|
24
|
-
|
25
|
-
def test_attributes_inheritance
|
26
|
-
serializer = @serializer_klass.new(@comment)
|
27
|
-
assert_equal({ id: 1, body: 'ZOMG!!' },
|
28
|
-
serializer.attributes)
|
29
|
-
end
|
30
|
-
|
31
|
-
def test_attribute_inheritance_with_new_attribute_definition
|
32
|
-
assert_equal([:id, :body, :date, :likes], @serializer_klass_with_new_attributes._attributes)
|
33
|
-
assert_equal([:id, :body], CommentSerializer._attributes)
|
34
|
-
end
|
35
|
-
|
36
|
-
def test_attribute_inheritance_with_new_attribute
|
37
|
-
serializer = @serializer_klass_with_new_attributes.new(@comment)
|
38
|
-
assert_equal({ id: 1, body: 'ZOMG!!', date: '2015', likes: nil },
|
39
|
-
serializer.attributes)
|
40
|
-
end
|
41
|
-
|
42
|
-
def test_multiple_calls_with_the_same_attribute
|
43
|
-
serializer_class = Class.new(ActiveModel::Serializer) do
|
44
|
-
attributes :id, :title
|
45
|
-
attributes :id, :title, :title, :body
|
46
|
-
end
|
47
|
-
|
48
|
-
assert_equal([:id, :title, :body], serializer_class._attributes)
|
49
|
-
end
|
50
|
-
end
|
51
|
-
end
|
52
|
-
end
|
@@ -1,170 +0,0 @@
|
|
1
|
-
# Execute this test in isolation
|
2
|
-
require 'support/isolated_unit'
|
3
|
-
|
4
|
-
class CachingConfigurationTest < ActiveSupport::TestCase
|
5
|
-
include ActiveSupport::Testing::Isolation
|
6
|
-
|
7
|
-
setup do
|
8
|
-
require 'rails'
|
9
|
-
# AMS needs to be required before Rails.application is initialized for
|
10
|
-
# Railtie's to fire in Rails.application.initialize!
|
11
|
-
# (and make_basic_app initializes the app)
|
12
|
-
require 'active_model_serializers'
|
13
|
-
# Create serializers before Rails.application.initialize!
|
14
|
-
# To ensure we're testing that the cache settings depend on
|
15
|
-
# the Railtie firing, not on the ActionController being loaded.
|
16
|
-
create_serializers
|
17
|
-
end
|
18
|
-
|
19
|
-
def create_serializers
|
20
|
-
@cached_serializer = Class.new(ActiveModel::Serializer) do
|
21
|
-
cache skip_digest: true
|
22
|
-
attributes :id, :name, :title
|
23
|
-
end
|
24
|
-
@fragment_cached_serializer = Class.new(ActiveModel::Serializer) do
|
25
|
-
cache only: :id
|
26
|
-
attributes :id, :name, :title
|
27
|
-
end
|
28
|
-
@non_cached_serializer = Class.new(ActiveModel::Serializer) do
|
29
|
-
attributes :id, :name, :title
|
30
|
-
end
|
31
|
-
end
|
32
|
-
|
33
|
-
class PerformCachingTrue < CachingConfigurationTest
|
34
|
-
setup do
|
35
|
-
# Let's make that Rails app and initialize it!
|
36
|
-
make_basic_app do |app|
|
37
|
-
app.config.action_controller.perform_caching = true
|
38
|
-
app.config.action_controller.cache_store = ActiveSupport::Cache.lookup_store(:memory_store)
|
39
|
-
end
|
40
|
-
controller_cache_store # Force ActiveSupport.on_load(:action_controller) to run
|
41
|
-
end
|
42
|
-
|
43
|
-
test 'it sets perform_caching to true on AMS.config and serializers' do
|
44
|
-
assert Rails.configuration.action_controller.perform_caching
|
45
|
-
assert ActiveModelSerializers.config.perform_caching
|
46
|
-
assert ActiveModel::Serializer.perform_caching?
|
47
|
-
assert @cached_serializer.perform_caching?
|
48
|
-
assert @non_cached_serializer.perform_caching?
|
49
|
-
assert @fragment_cached_serializer.perform_caching?
|
50
|
-
end
|
51
|
-
|
52
|
-
test 'it sets the AMS.config.cache_store to the controller cache_store' do
|
53
|
-
assert_equal controller_cache_store, ActiveSupport::Cache::MemoryStore
|
54
|
-
assert_equal controller_cache_store, ActiveModelSerializers.config.cache_store.class
|
55
|
-
end
|
56
|
-
|
57
|
-
test 'it sets the cached serializer cache_store to the ActionController::Base.cache_store' do
|
58
|
-
assert_equal ActiveSupport::Cache::NullStore, @cached_serializer._cache.class
|
59
|
-
assert_equal controller_cache_store, @cached_serializer.cache_store.class
|
60
|
-
assert_equal ActiveSupport::Cache::MemoryStore, @cached_serializer._cache.class
|
61
|
-
end
|
62
|
-
|
63
|
-
test 'the cached serializer has cache_enabled?' do
|
64
|
-
assert @cached_serializer.cache_enabled?
|
65
|
-
end
|
66
|
-
|
67
|
-
test 'the cached serializer does not have fragment_cache_enabled?' do
|
68
|
-
refute @cached_serializer.fragment_cache_enabled?
|
69
|
-
end
|
70
|
-
|
71
|
-
test 'the non-cached serializer cache_store is nil' do
|
72
|
-
assert_equal nil, @non_cached_serializer._cache
|
73
|
-
assert_equal nil, @non_cached_serializer.cache_store
|
74
|
-
assert_equal nil, @non_cached_serializer._cache
|
75
|
-
end
|
76
|
-
|
77
|
-
test 'the non-cached serializer does not have cache_enabled?' do
|
78
|
-
refute @non_cached_serializer.cache_enabled?
|
79
|
-
end
|
80
|
-
|
81
|
-
test 'the non-cached serializer does not have fragment_cache_enabled?' do
|
82
|
-
refute @non_cached_serializer.fragment_cache_enabled?
|
83
|
-
end
|
84
|
-
|
85
|
-
test 'it sets the fragment cached serializer cache_store to the ActionController::Base.cache_store' do
|
86
|
-
assert_equal ActiveSupport::Cache::NullStore, @fragment_cached_serializer._cache.class
|
87
|
-
assert_equal controller_cache_store, @fragment_cached_serializer.cache_store.class
|
88
|
-
assert_equal ActiveSupport::Cache::MemoryStore, @fragment_cached_serializer._cache.class
|
89
|
-
end
|
90
|
-
|
91
|
-
test 'the fragment cached serializer does not have cache_enabled?' do
|
92
|
-
refute @fragment_cached_serializer.cache_enabled?
|
93
|
-
end
|
94
|
-
|
95
|
-
test 'the fragment cached serializer has fragment_cache_enabled?' do
|
96
|
-
assert @fragment_cached_serializer.fragment_cache_enabled?
|
97
|
-
end
|
98
|
-
end
|
99
|
-
|
100
|
-
class PerformCachingFalse < CachingConfigurationTest
|
101
|
-
setup do
|
102
|
-
# Let's make that Rails app and initialize it!
|
103
|
-
make_basic_app do |app|
|
104
|
-
app.config.action_controller.perform_caching = false
|
105
|
-
app.config.action_controller.cache_store = ActiveSupport::Cache.lookup_store(:memory_store)
|
106
|
-
end
|
107
|
-
controller_cache_store # Force ActiveSupport.on_load(:action_controller) to run
|
108
|
-
end
|
109
|
-
|
110
|
-
test 'it sets perform_caching to false on AMS.config and serializers' do
|
111
|
-
refute Rails.configuration.action_controller.perform_caching
|
112
|
-
refute ActiveModelSerializers.config.perform_caching
|
113
|
-
refute ActiveModel::Serializer.perform_caching?
|
114
|
-
refute @cached_serializer.perform_caching?
|
115
|
-
refute @non_cached_serializer.perform_caching?
|
116
|
-
refute @fragment_cached_serializer.perform_caching?
|
117
|
-
end
|
118
|
-
|
119
|
-
test 'it sets the AMS.config.cache_store to the controller cache_store' do
|
120
|
-
assert_equal controller_cache_store, ActiveSupport::Cache::MemoryStore
|
121
|
-
assert_equal controller_cache_store, ActiveModelSerializers.config.cache_store.class
|
122
|
-
end
|
123
|
-
|
124
|
-
test 'it sets the cached serializer cache_store to the ActionController::Base.cache_store' do
|
125
|
-
assert_equal ActiveSupport::Cache::NullStore, @cached_serializer._cache.class
|
126
|
-
assert_equal controller_cache_store, @cached_serializer.cache_store.class
|
127
|
-
assert_equal ActiveSupport::Cache::MemoryStore, @cached_serializer._cache.class
|
128
|
-
end
|
129
|
-
|
130
|
-
test 'the cached serializer does not have cache_enabled?' do
|
131
|
-
refute @cached_serializer.cache_enabled?
|
132
|
-
end
|
133
|
-
|
134
|
-
test 'the cached serializer does not have fragment_cache_enabled?' do
|
135
|
-
refute @cached_serializer.fragment_cache_enabled?
|
136
|
-
end
|
137
|
-
|
138
|
-
test 'the non-cached serializer cache_store is nil' do
|
139
|
-
assert_equal nil, @non_cached_serializer._cache
|
140
|
-
assert_equal nil, @non_cached_serializer.cache_store
|
141
|
-
assert_equal nil, @non_cached_serializer._cache
|
142
|
-
end
|
143
|
-
|
144
|
-
test 'the non-cached serializer does not have cache_enabled?' do
|
145
|
-
refute @non_cached_serializer.cache_enabled?
|
146
|
-
end
|
147
|
-
|
148
|
-
test 'the non-cached serializer does not have fragment_cache_enabled?' do
|
149
|
-
refute @non_cached_serializer.fragment_cache_enabled?
|
150
|
-
end
|
151
|
-
|
152
|
-
test 'it sets the fragment cached serializer cache_store to the ActionController::Base.cache_store' do
|
153
|
-
assert_equal ActiveSupport::Cache::NullStore, @fragment_cached_serializer._cache.class
|
154
|
-
assert_equal controller_cache_store, @fragment_cached_serializer.cache_store.class
|
155
|
-
assert_equal ActiveSupport::Cache::MemoryStore, @fragment_cached_serializer._cache.class
|
156
|
-
end
|
157
|
-
|
158
|
-
test 'the fragment cached serializer does not have cache_enabled?' do
|
159
|
-
refute @fragment_cached_serializer.cache_enabled?
|
160
|
-
end
|
161
|
-
|
162
|
-
test 'the fragment cached serializer does not have fragment_cache_enabled?' do
|
163
|
-
refute @fragment_cached_serializer.fragment_cache_enabled?
|
164
|
-
end
|
165
|
-
end
|
166
|
-
|
167
|
-
def controller_cache_store
|
168
|
-
ActionController::Base.cache_store.class
|
169
|
-
end
|
170
|
-
end
|
@@ -1,32 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
module ActiveModel
|
4
|
-
class Serializer
|
5
|
-
class ConfigurationTest < ActiveSupport::TestCase
|
6
|
-
def test_collection_serializer
|
7
|
-
assert_equal ActiveModel::Serializer::CollectionSerializer, ActiveModelSerializers.config.collection_serializer
|
8
|
-
end
|
9
|
-
|
10
|
-
def test_array_serializer
|
11
|
-
assert_equal ActiveModel::Serializer::CollectionSerializer, ActiveModelSerializers.config.array_serializer
|
12
|
-
end
|
13
|
-
|
14
|
-
def test_setting_array_serializer_sets_collection_serializer
|
15
|
-
config = ActiveModelSerializers.config
|
16
|
-
old_config = config.dup
|
17
|
-
begin
|
18
|
-
assert_equal ActiveModel::Serializer::CollectionSerializer, config.collection_serializer
|
19
|
-
config.array_serializer = :foo
|
20
|
-
assert_equal config.array_serializer, :foo
|
21
|
-
assert_equal config.collection_serializer, :foo
|
22
|
-
ensure
|
23
|
-
ActiveModelSerializers.config.replace(old_config)
|
24
|
-
end
|
25
|
-
end
|
26
|
-
|
27
|
-
def test_default_adapter
|
28
|
-
assert_equal :attributes, ActiveModelSerializers.config.adapter
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
32
|
-
end
|
@@ -1,14 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
module ActiveModel
|
4
|
-
class Serializer
|
5
|
-
class FieldsetTest < ActiveSupport::TestCase
|
6
|
-
def test_fieldset_with_hash
|
7
|
-
fieldset = ActiveModel::Serializer::Fieldset.new('post' => %w(id title), 'comment' => ['body'])
|
8
|
-
expected = { post: [:id, :title], comment: [:body] }
|
9
|
-
|
10
|
-
assert_equal(expected, fieldset.fields)
|
11
|
-
end
|
12
|
-
end
|
13
|
-
end
|
14
|
-
end
|
@@ -1,202 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
module ActiveModel
|
4
|
-
class Serializer
|
5
|
-
class MetaTest < ActiveSupport::TestCase
|
6
|
-
def setup
|
7
|
-
@blog = Blog.new(id: 1,
|
8
|
-
name: 'AMS Hints',
|
9
|
-
writer: Author.new(id: 2, name: 'Steve'),
|
10
|
-
articles: [Post.new(id: 3, title: 'AMS')])
|
11
|
-
end
|
12
|
-
|
13
|
-
def test_meta_is_present_with_root
|
14
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
15
|
-
@blog,
|
16
|
-
adapter: :json,
|
17
|
-
serializer: AlternateBlogSerializer,
|
18
|
-
meta: { total: 10 }
|
19
|
-
).as_json
|
20
|
-
expected = {
|
21
|
-
blog: {
|
22
|
-
id: 1,
|
23
|
-
title: 'AMS Hints'
|
24
|
-
},
|
25
|
-
'meta' => {
|
26
|
-
total: 10
|
27
|
-
}
|
28
|
-
}
|
29
|
-
assert_equal(expected, actual)
|
30
|
-
end
|
31
|
-
|
32
|
-
def test_meta_is_not_included_when_blank
|
33
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
34
|
-
@blog,
|
35
|
-
adapter: :json,
|
36
|
-
serializer: AlternateBlogSerializer,
|
37
|
-
meta: {}
|
38
|
-
).as_json
|
39
|
-
expected = {
|
40
|
-
blog: {
|
41
|
-
id: 1,
|
42
|
-
title: 'AMS Hints'
|
43
|
-
}
|
44
|
-
}
|
45
|
-
assert_equal(expected, actual)
|
46
|
-
end
|
47
|
-
|
48
|
-
def test_meta_is_not_included_when_empty_string
|
49
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
50
|
-
@blog,
|
51
|
-
adapter: :json,
|
52
|
-
serializer: AlternateBlogSerializer,
|
53
|
-
meta: ''
|
54
|
-
).as_json
|
55
|
-
expected = {
|
56
|
-
blog: {
|
57
|
-
id: 1,
|
58
|
-
title: 'AMS Hints'
|
59
|
-
}
|
60
|
-
}
|
61
|
-
assert_equal(expected, actual)
|
62
|
-
end
|
63
|
-
|
64
|
-
def test_meta_is_not_included_when_root_is_missing
|
65
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
66
|
-
@blog,
|
67
|
-
adapter: :attributes,
|
68
|
-
serializer: AlternateBlogSerializer,
|
69
|
-
meta: { total: 10 }
|
70
|
-
).as_json
|
71
|
-
expected = {
|
72
|
-
id: 1,
|
73
|
-
title: 'AMS Hints'
|
74
|
-
}
|
75
|
-
assert_equal(expected, actual)
|
76
|
-
end
|
77
|
-
|
78
|
-
def test_meta_key_is_used
|
79
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
80
|
-
@blog,
|
81
|
-
adapter: :json,
|
82
|
-
serializer: AlternateBlogSerializer,
|
83
|
-
meta: { total: 10 },
|
84
|
-
meta_key: 'haha_meta'
|
85
|
-
).as_json
|
86
|
-
expected = {
|
87
|
-
blog: {
|
88
|
-
id: 1,
|
89
|
-
title: 'AMS Hints'
|
90
|
-
},
|
91
|
-
'haha_meta' => {
|
92
|
-
total: 10
|
93
|
-
}
|
94
|
-
}
|
95
|
-
assert_equal(expected, actual)
|
96
|
-
end
|
97
|
-
|
98
|
-
def test_meta_key_is_not_used_with_json_api
|
99
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
100
|
-
@blog,
|
101
|
-
adapter: :json_api,
|
102
|
-
serializer: AlternateBlogSerializer,
|
103
|
-
meta: { total: 10 },
|
104
|
-
meta_key: 'haha_meta'
|
105
|
-
).as_json
|
106
|
-
expected = {
|
107
|
-
data: {
|
108
|
-
id: '1',
|
109
|
-
type: 'blogs',
|
110
|
-
attributes: { title: 'AMS Hints' }
|
111
|
-
},
|
112
|
-
meta: { total: 10 }
|
113
|
-
}
|
114
|
-
assert_equal(expected, actual)
|
115
|
-
end
|
116
|
-
|
117
|
-
def test_meta_key_is_not_present_when_empty_hash_with_json_api
|
118
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
119
|
-
@blog,
|
120
|
-
adapter: :json_api,
|
121
|
-
serializer: AlternateBlogSerializer,
|
122
|
-
meta: {}
|
123
|
-
).as_json
|
124
|
-
expected = {
|
125
|
-
data: {
|
126
|
-
id: '1',
|
127
|
-
type: 'blogs',
|
128
|
-
attributes: { title: 'AMS Hints' }
|
129
|
-
}
|
130
|
-
}
|
131
|
-
assert_equal(expected, actual)
|
132
|
-
end
|
133
|
-
|
134
|
-
def test_meta_key_is_not_present_when_empty_string_with_json_api
|
135
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
136
|
-
@blog,
|
137
|
-
adapter: :json_api,
|
138
|
-
serializer: AlternateBlogSerializer,
|
139
|
-
meta: ''
|
140
|
-
).as_json
|
141
|
-
expected = {
|
142
|
-
data: {
|
143
|
-
id: '1',
|
144
|
-
type: 'blogs',
|
145
|
-
attributes: { title: 'AMS Hints' }
|
146
|
-
}
|
147
|
-
}
|
148
|
-
assert_equal(expected, actual)
|
149
|
-
end
|
150
|
-
|
151
|
-
def test_meta_is_not_present_on_arrays_without_root
|
152
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
153
|
-
[@blog],
|
154
|
-
adapter: :attributes,
|
155
|
-
meta: { total: 10 }
|
156
|
-
).as_json
|
157
|
-
expected = [{
|
158
|
-
id: 1,
|
159
|
-
name: 'AMS Hints',
|
160
|
-
writer: {
|
161
|
-
id: 2,
|
162
|
-
name: 'Steve'
|
163
|
-
},
|
164
|
-
articles: [{
|
165
|
-
id: 3,
|
166
|
-
title: 'AMS',
|
167
|
-
body: nil
|
168
|
-
}]
|
169
|
-
}]
|
170
|
-
assert_equal(expected, actual)
|
171
|
-
end
|
172
|
-
|
173
|
-
def test_meta_is_present_on_arrays_with_root
|
174
|
-
actual = ActiveModelSerializers::SerializableResource.new(
|
175
|
-
[@blog],
|
176
|
-
adapter: :json,
|
177
|
-
meta: { total: 10 },
|
178
|
-
meta_key: 'haha_meta'
|
179
|
-
).as_json
|
180
|
-
expected = {
|
181
|
-
blogs: [{
|
182
|
-
id: 1,
|
183
|
-
name: 'AMS Hints',
|
184
|
-
writer: {
|
185
|
-
id: 2,
|
186
|
-
name: 'Steve'
|
187
|
-
},
|
188
|
-
articles: [{
|
189
|
-
id: 3,
|
190
|
-
title: 'AMS',
|
191
|
-
body: nil
|
192
|
-
}]
|
193
|
-
}],
|
194
|
-
'haha_meta' => {
|
195
|
-
total: 10
|
196
|
-
}
|
197
|
-
}
|
198
|
-
assert_equal(expected, actual)
|
199
|
-
end
|
200
|
-
end
|
201
|
-
end
|
202
|
-
end
|