Browse Source

Merge pull request #78 from connyay/handle-empty-json-response

Handle empty response (204)
http2
Vsevolod Strukchinsky 10 years ago
parent
commit
2a155a8f4f
  1. 4
      index.js
  2. 12
      test/test-json.js

4
index.js

@ -195,7 +195,9 @@ function got(url, opts, cb) {
readAllStream(res, encoding, function (err, data) { readAllStream(res, encoding, function (err, data) {
if (err) { if (err) {
err = new GotError('Reading ' + url + ' response failed', err); err = new GotError('Reading ' + url + ' response failed', err);
} else if (json) { } else if (json && statusCode !== 204) {
// only parse json if the option is enabled, and the response
// is not a 204 (empty reponse)
try { try {
data = JSON.parse(data); data = JSON.parse(data);
} catch (e) { } catch (e) {

12
test/test-json.js

@ -12,6 +12,11 @@ s.on('/invalid', function (req, res) {
res.end('/'); res.end('/');
}); });
s.on('/204', function (req, res) {
res.statusCode = 204;
res.end();
});
s.on('/non200', function (req, res) { s.on('/non200', function (req, res) {
res.statusCode = 500; res.statusCode = 500;
res.end('{"data":"dog"}'); res.end('{"data":"dog"}');
@ -43,6 +48,13 @@ test('json option should parse response', function (t) {
}); });
}); });
test('json option should not parse responses without a body', function (t) {
got(s.url + '/204', {json: true}, function (err) {
t.error(err);
t.end();
});
});
test('json option wrap parsing errors', function (t) { test('json option wrap parsing errors', function (t) {
got(s.url + '/invalid', {json: true}, function (err) { got(s.url + '/invalid', {json: true}, function (err) {
t.ok(err); t.ok(err);

Loading…
Cancel
Save