Fixed #27516 -- Made test client's response.json() cache the parsed JSON.
This commit is contained in:
parent
0783aa7deb
commit
19e2114634
|
@ -683,12 +683,14 @@ class Client(RequestFactory):
|
||||||
self.cookies = SimpleCookie()
|
self.cookies = SimpleCookie()
|
||||||
|
|
||||||
def _parse_json(self, response, **extra):
|
def _parse_json(self, response, **extra):
|
||||||
if 'application/json' not in response.get('Content-Type'):
|
if not hasattr(response, '_json'):
|
||||||
raise ValueError(
|
if 'application/json' not in response.get('Content-Type'):
|
||||||
'Content-Type header is "{0}", not "application/json"'
|
raise ValueError(
|
||||||
.format(response.get('Content-Type'))
|
'Content-Type header is "{0}", not "application/json"'
|
||||||
)
|
.format(response.get('Content-Type'))
|
||||||
return json.loads(response.content.decode(), **extra)
|
)
|
||||||
|
response._json = json.loads(response.content.decode(), **extra)
|
||||||
|
return response._json
|
||||||
|
|
||||||
def _handle_redirects(self, response, **extra):
|
def _handle_redirects(self, response, **extra):
|
||||||
"Follows any redirects by requesting responses from the server using GET."
|
"Follows any redirects by requesting responses from the server using GET."
|
||||||
|
|
|
@ -1209,6 +1209,10 @@ class RequestMethodStringDataTests(SimpleTestCase):
|
||||||
response = self.client.get('/json_response/')
|
response = self.client.get('/json_response/')
|
||||||
self.assertEqual(response.json(), {'key': 'value'})
|
self.assertEqual(response.json(), {'key': 'value'})
|
||||||
|
|
||||||
|
def test_json_multiple_access(self):
|
||||||
|
response = self.client.get('/json_response/')
|
||||||
|
self.assertIs(response.json(), response.json())
|
||||||
|
|
||||||
def test_json_wrong_header(self):
|
def test_json_wrong_header(self):
|
||||||
response = self.client.get('/body/')
|
response = self.client.get('/body/')
|
||||||
msg = 'Content-Type header is "text/html; charset=utf-8", not "application/json"'
|
msg = 'Content-Type header is "text/html; charset=utf-8", not "application/json"'
|
||||||
|
|
Loading…
Reference in New Issue