2008-05-17 23:22:34 -05:00
require 'abstract_unit'
2007-12-21 01:48:59 -06:00
require " fixtures/person "
class BaseErrorsTest < Test :: Unit :: TestCase
def setup
ActiveResource :: HttpMock . respond_to do | mock |
2009-11-30 19:38:34 -06:00
mock . post " /people.xml " , { } , %q( <?xml version="1.0" encoding="UTF-8"?><errors><error>Age can't be blank</error><error>Name can't be blank</error><error>Name must start with a letter</error><error>Person quota full for today.</error></errors> ) , 422 , { 'Content-Type' = > 'application/xml; charset=utf-8' }
mock . post " /people.json " , { } , %q( {"errors":["Age can't be blank","Name can't be blank","Name must start with a letter","Person quota full for today."]} ) , 422 , { 'Content-Type' = > 'application/json; charset=utf-8' }
2007-12-21 01:48:59 -06:00
end
@person = Person . new ( :name = > '' , :age = > '' )
assert_equal @person . save , false
end
def test_should_mark_as_invalid
2009-09-05 02:01:46 -05:00
[ :json , :xml ] . each do | format |
invalid_user_using_format ( format ) do
assert ! @person . valid?
end
end
2007-12-21 01:48:59 -06:00
end
def test_should_parse_xml_errors
2009-09-05 02:01:46 -05:00
[ :json , :xml ] . each do | format |
invalid_user_using_format ( format ) do
assert_kind_of ActiveResource :: Errors , @person . errors
assert_equal 4 , @person . errors . size
end
end
2007-12-21 01:48:59 -06:00
end
def test_should_parse_errors_to_individual_attributes
2009-09-05 02:01:46 -05:00
[ :json , :xml ] . each do | format |
invalid_user_using_format ( format ) do
assert @person . errors [ :name ] . any?
assert_equal " can't be blank " , @person . errors [ :age ]
assert_equal [ " can't be blank " , " must start with a letter " ] , @person . errors [ :name ]
assert_equal " Person quota full for today. " , @person . errors [ :base ]
end
end
2007-12-21 01:48:59 -06:00
end
def test_should_iterate_over_errors
2009-09-05 02:01:46 -05:00
[ :json , :xml ] . each do | format |
invalid_user_using_format ( format ) do
errors = [ ]
@person . errors . each { | attribute , message | errors << [ attribute , message ] }
assert errors . include? ( [ 'name' , " can't be blank " ] )
end
end
2007-12-21 01:48:59 -06:00
end
def test_should_iterate_over_full_errors
2009-09-05 02:01:46 -05:00
[ :json , :xml ] . each do | format |
invalid_user_using_format ( format ) do
errors = [ ]
@person . errors . to_a . each { | message | errors << message }
assert errors . include? ( [ " name " , " can't be blank " ] )
end
end
2007-12-21 01:48:59 -06:00
end
def test_should_format_full_errors
2009-09-05 02:01:46 -05:00
[ :json , :xml ] . each do | format |
invalid_user_using_format ( format ) do
full = @person . errors . full_messages
assert full . include? ( " Age can't be blank " )
assert full . include? ( " Name can't be blank " )
assert full . include? ( " Name must start with a letter " )
assert full . include? ( " Person quota full for today. " )
end
end
end
2010-05-25 12:45:45 -05:00
def test_should_mark_as_invalid_when_content_type_is_unavailable_in_response_header
ActiveResource :: HttpMock . respond_to do | mock |
mock . post " /people.xml " , { } , %q( <?xml version="1.0" encoding="UTF-8"?><errors><error>Age can't be blank</error><error>Name can't be blank</error><error>Name must start with a letter</error><error>Person quota full for today.</error></errors> ) , 422 , { }
mock . post " /people.json " , { } , %q( {"errors":["Age can't be blank","Name can't be blank","Name must start with a letter","Person quota full for today."]} ) , 422 , { }
end
[ :json , :xml ] . each do | format |
invalid_user_using_format ( format ) do
assert ! @person . valid?
end
end
end
2009-09-05 02:01:46 -05:00
private
def invalid_user_using_format ( mime_type_reference )
previous_format = Person . format
Person . format = mime_type_reference
@person = Person . new ( :name = > '' , :age = > '' )
assert_equal false , @person . save
yield
ensure
Person . format = previous_format
2007-12-21 01:48:59 -06:00
end
end