blob: e4d2f094842373a32502ccdaf30079ae1d1d6504 [file] [log] [blame]
Craig Citro15744b12015-03-02 13:34:32 -08001#!/usr/bin/env python
Ali Afshar2dcc6522010-12-16 10:11:53 +01002#
Craig Citro751b7fb2014-09-23 11:20:38 -07003# Copyright 2014 Google Inc. All Rights Reserved.
Ali Afshar2dcc6522010-12-16 10:11:53 +01004#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16
17"""Tests for errors handling
18"""
INADA Naokid898a372015-03-04 03:52:46 +090019from __future__ import absolute_import
Ali Afshar2dcc6522010-12-16 10:11:53 +010020
21__author__ = 'afshar@google.com (Ali Afshar)'
22
23
Pat Ferate497a90f2015-03-09 09:52:54 -070024import unittest2 as unittest
Ali Afshar2dcc6522010-12-16 10:11:53 +010025import httplib2
26
27
John Asmuth864311d2014-04-24 15:46:08 -040028from googleapiclient.errors import HttpError
Ali Afshar2dcc6522010-12-16 10:11:53 +010029
30
INADA Naoki09157612015-03-25 01:51:03 +090031JSON_ERROR_CONTENT = b"""
Ali Afshar2dcc6522010-12-16 10:11:53 +010032{
33 "error": {
34 "errors": [
35 {
36 "domain": "global",
37 "reason": "required",
38 "message": "country is required",
39 "locationType": "parameter",
40 "location": "country"
41 }
42 ],
43 "code": 400,
Son CHUf6e26612017-07-17 18:02:18 +020044 "message": "country is required",
45 "details": "error details"
Ali Afshar2dcc6522010-12-16 10:11:53 +010046 }
47}
48"""
49
Joe Gregorio20b54fb2012-07-26 09:59:35 -040050def fake_response(data, headers, reason='Ok'):
51 response = httplib2.Response(headers)
52 response.reason = reason
53 return response, data
Joe Gregorio49396552011-03-08 10:39:00 -050054
55
56class Error(unittest.TestCase):
57 """Test handling of error bodies."""
58
59 def test_json_body(self):
60 """Test a nicely formed, expected error response."""
61 resp, content = fake_response(JSON_ERROR_CONTENT,
Joe Gregorio20b54fb2012-07-26 09:59:35 -040062 {'status':'400', 'content-type': 'application/json'},
63 reason='Failed')
Joe Gregorio68a8cfe2012-08-03 16:17:40 -040064 error = HttpError(resp, content, uri='http://example.org')
Son CHUf6e26612017-07-17 18:02:18 +020065 self.assertEqual(str(error), '<HttpError 400 when requesting http://example.org returned "country is required". Details: "error details">')
Joe Gregorio49396552011-03-08 10:39:00 -050066
67 def test_bad_json_body(self):
68 """Test handling of bodies with invalid json."""
INADA Naoki09157612015-03-25 01:51:03 +090069 resp, content = fake_response(b'{',
Joe Gregorio20b54fb2012-07-26 09:59:35 -040070 { 'status':'400', 'content-type': 'application/json'},
71 reason='Failed')
Joe Gregorio49396552011-03-08 10:39:00 -050072 error = HttpError(resp, content)
Joe Gregorio20b54fb2012-07-26 09:59:35 -040073 self.assertEqual(str(error), '<HttpError 400 "Failed">')
Joe Gregorio49396552011-03-08 10:39:00 -050074
75 def test_with_uri(self):
76 """Test handling of passing in the request uri."""
INADA Naoki09157612015-03-25 01:51:03 +090077 resp, content = fake_response(b'{',
Joe Gregorio20b54fb2012-07-26 09:59:35 -040078 {'status':'400', 'content-type': 'application/json'},
79 reason='Failure')
Joe Gregorio68a8cfe2012-08-03 16:17:40 -040080 error = HttpError(resp, content, uri='http://example.org')
Joe Gregorio20b54fb2012-07-26 09:59:35 -040081 self.assertEqual(str(error), '<HttpError 400 when requesting http://example.org returned "Failure">')
Joe Gregorio49396552011-03-08 10:39:00 -050082
83 def test_missing_message_json_body(self):
84 """Test handling of bodies with missing expected 'message' element."""
INADA Naoki09157612015-03-25 01:51:03 +090085 resp, content = fake_response(b'{}',
Joe Gregorio20b54fb2012-07-26 09:59:35 -040086 {'status':'400', 'content-type': 'application/json'},
87 reason='Failed')
Joe Gregorio49396552011-03-08 10:39:00 -050088 error = HttpError(resp, content)
Joe Gregorio20b54fb2012-07-26 09:59:35 -040089 self.assertEqual(str(error), '<HttpError 400 "Failed">')
Joe Gregorio49396552011-03-08 10:39:00 -050090
91 def test_non_json(self):
92 """Test handling of non-JSON bodies"""
INADA Naoki09157612015-03-25 01:51:03 +090093 resp, content = fake_response(b'}NOT OK', {'status':'400'})
Joe Gregorio49396552011-03-08 10:39:00 -050094 error = HttpError(resp, content)
95 self.assertEqual(str(error), '<HttpError 400 "Ok">')
Joe Gregorioe7bbbb92013-02-20 15:37:24 -050096
97 def test_missing_reason(self):
98 """Test an empty dict with a missing resp.reason."""
INADA Naoki09157612015-03-25 01:51:03 +090099 resp, content = fake_response(b'}NOT OK', {'status': '400'}, reason=None)
Joe Gregorioe7bbbb92013-02-20 15:37:24 -0500100 error = HttpError(resp, content)
101 self.assertEqual(str(error), '<HttpError 400 "">')