aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/test/assertions
diff options
context:
space:
mode:
authorRafael França <rafaelmfranca@gmail.com>2016-09-14 16:00:22 -0300
committerGitHub <noreply@github.com>2016-09-14 16:00:22 -0300
commit0ad38412f4278223dbdf46c8c1fd6233e4d54db2 (patch)
tree1dcd89394dcac5ead83fdd0991f300c28ced5445 /actionpack/test/assertions
parent1d7b00d6072e4749e90fb4bc8307dc06b052848d (diff)
parentbc3b0e729282b6474f217806c14f293584dd8c97 (diff)
downloadrails-0ad38412f4278223dbdf46c8c1fd6233e4d54db2.tar.gz
rails-0ad38412f4278223dbdf46c8c1fd6233e4d54db2.tar.bz2
rails-0ad38412f4278223dbdf46c8c1fd6233e4d54db2.zip
Merge pull request #26477 from kirs/action_dispatch-assert_response
Improve assert_response helper
Diffstat (limited to 'actionpack/test/assertions')
-rw-r--r--actionpack/test/assertions/response_assertions_test.rb24
1 files changed, 23 insertions, 1 deletions
diff --git a/actionpack/test/assertions/response_assertions_test.rb b/actionpack/test/assertions/response_assertions_test.rb
index 17517f8965..14a04ccdb1 100644
--- a/actionpack/test/assertions/response_assertions_test.rb
+++ b/actionpack/test/assertions/response_assertions_test.rb
@@ -6,10 +6,11 @@ module ActionDispatch
class ResponseAssertionsTest < ActiveSupport::TestCase
include ResponseAssertions
- FakeResponse = Struct.new(:response_code, :location) do
+ FakeResponse = Struct.new(:response_code, :location, :body) do
def initialize(*)
super
self.location ||= "http://test.example.com/posts"
+ self.body ||= ""
end
[:successful, :not_found, :redirection, :server_error].each do |sym|
@@ -112,6 +113,27 @@ module ActionDispatch
" redirect to <http://test.host/posts/redirect/2>"
assert_match expected, error.message
end
+
+ def test_error_message_shows_short_response_body
+ @response = ActionDispatch::Response.new
+ @response.status = 400
+ @response.body = "not too long"
+ error = assert_raises(Minitest::Assertion) { assert_response 200 }
+ expected = "Expected response to be a <200: OK>,"\
+ " but was a <400: Bad Request>" \
+ "\nResponse body: not too long"
+ assert_match expected, error.message
+ end
+
+ def test_error_message_does_not_show_long_response_body
+ @response = ActionDispatch::Response.new
+ @response.status = 400
+ @response.body = "not too long" * 50
+ error = assert_raises(Minitest::Assertion) { assert_response 200 }
+ expected = "Expected response to be a <200: OK>,"\
+ " but was a <400: Bad Request>"
+ assert_match expected, error.message
+ end
end
end
end