Skip to content

Commit

Permalink
Cleanup assertions in isolated jsonapi renderer tests a bit
Browse files Browse the repository at this point in the history
  • Loading branch information
bf4 committed Dec 25, 2016
1 parent f246741 commit 11c4efb
Showing 1 changed file with 24 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ class << self

def render_with_jsonapi_renderer
unlocked_params = Rails::VERSION::MAJOR >= 5 ? params.to_unsafe_h : params
attributes = unlocked_params[:data].present? ? unlocked_params[:data][:attributes] : {}
attributes = unlocked_params[:data].present? ? unlocked_params[:data][:attributes].merge(id: unlocked_params[:data][:id]) : {}
author = Author.new(attributes)
render jsonapi: author
end
Expand All @@ -34,6 +34,17 @@ def assert_parses(expected, actual, headers = {})
assert_equal(expected, TestController.last_request_parameters)
end

def define_author_model_and_serializer
TestController.const_set(:Author, Class.new(ActiveModelSerializers::Model) do
attributes :name
end)
TestController.const_set(:AuthorSerializer, Class.new(ActiveModel::Serializer) do
type 'users'
attribute :id
attribute :name
end)
end

class WithoutRenderer < JsonApiRendererTest
setup do
require 'rails'
Expand All @@ -49,6 +60,7 @@ class WithoutRenderer < JsonApiRendererTest
match ':action', to: TestController, via: [:get, :post]
end
end
define_author_model_and_serializer
end

def test_jsonapi_parser_not_registered
Expand All @@ -61,12 +73,12 @@ def test_jsonapi_parser_not_registered
end

def test_jsonapi_renderer_not_registered
payload = '{"data": {"attributes": {"name": "Johnny Rico"}, "type": "authors"}}'
payload = '{"data": {"attributes": {"name": "Johnny Rico"}, "type": "users", "id": "36c9c04e-86b1-4636-a5b0-8616672d1765"}}'
headers = { 'CONTENT_TYPE' => 'application/vnd.api+json' }
post '/render_with_jsonapi_renderer', params: payload, headers: headers
assert_equal 500, response.status
assert_equal '', response.body
assert response.request.env['action_dispatch.exception'].is_a?(ActionView::MissingTemplate) if response.request.present?
assert_equal 500, response.status
assert_equal ActionView::MissingTemplate, request.env['action_dispatch.exception'].class
end

def test_jsonapi_parser
Expand Down Expand Up @@ -94,6 +106,7 @@ class WithRenderer < JsonApiRendererTest
match ':action', to: TestController, via: [:get, :post]
end
end
define_author_model_and_serializer
end

def test_jsonapi_parser_registered
Expand All @@ -109,18 +122,13 @@ def test_jsonapi_parser_registered
def test_jsonapi_renderer_registered
expected = {
'data' => {
'id' => 'author',
'type' => 'authors',
'attributes' => { 'name' => 'Johnny Rico' },
'relationships' => {
'posts' => { 'data' => nil },
'roles' => { 'data' => nil },
'bio' => { 'data' => nil }
}
'id' => '36c9c04e-86b1-4636-a5b0-8616672d1765',
'type' => 'users',
'attributes' => { 'name' => 'Johnny Rico' }
}
}

payload = '{"data": {"attributes": {"name": "Johnny Rico"}, "type": "authors"}}'
payload = '{"data": {"attributes": {"name": "Johnny Rico"}, "type": "users", "id": "36c9c04e-86b1-4636-a5b0-8616672d1765"}}'
headers = { 'CONTENT_TYPE' => 'application/vnd.api+json' }
post '/render_with_jsonapi_renderer', params: payload, headers: headers
assert_equal expected.to_json, response.body
Expand All @@ -133,10 +141,11 @@ def test_jsonapi_parser
'attributes' => {
'name' => 'John Doe'
},
'type' => 'users'
'type' => 'users',
'id' => '36c9c04e-86b1-4636-a5b0-8616672d1765'
}
},
'{"data": {"attributes": {"name": "John Doe"}, "type": "users"}}',
'{"data": {"attributes": {"name": "John Doe"}, "type": "users", "id": "36c9c04e-86b1-4636-a5b0-8616672d1765"}}',
'CONTENT_TYPE' => 'application/vnd.api+json'
)
end
Expand Down

0 comments on commit 11c4efb

Please sign in to comment.