doipjs/node_modules/superagent/docs/test.html
Yarmo Mackenbach e996bc8023 Initial commit
2020-10-23 22:35:53 +02:00

4610 lines
146 KiB
HTML

<!DOCTYPE html>
<html>
<head>
<meta charset="utf8">
<title>SuperAgent — elegant API for AJAX in Node and browsers</title>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/tocbot/3.0.0/tocbot.css">
<link rel="stylesheet" href="docs/style.css">
</head>
<body>
<ul id="menu"></ul>
<div id="content">
<section class="suite">
<h1>Agent</h1>
<dl>
<dt>should remember defaults</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return;
}
let called = 0;
let event_called = 0;
const agent = request
.agent()
.accept(&#x27;json&#x27;)
.use(() =&#x3E; {
called++;
})
.once(&#x27;request&#x27;, () =&#x3E; {
event_called++;
})
.query({ hello: &#x27;world&#x27; })
.set(&#x27;X-test&#x27;, &#x27;testing&#x27;);
assert.equal(0, called);
assert.equal(0, event_called);
return agent
.get(&#x60;${base}/echo&#x60;)
.then((res) =&#x3E; {
assert.equal(1, called);
assert.equal(1, event_called);
assert.equal(&#x27;application/json&#x27;, res.headers.accept);
assert.equal(&#x27;testing&#x27;, res.headers[&#x27;x-test&#x27;]);
return agent.get(&#x60;${base}/querystring&#x60;);
})
.then((res) =&#x3E; {
assert.equal(2, called);
assert.equal(2, event_called);
assert.deepEqual({ hello: &#x27;world&#x27; }, res.body);
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>request</h1>
<dl>
<section class="suite">
<h1>res.statusCode</h1>
<dl>
<dt>should set statusCode</dt>
<dd><pre><code>request.get(&#x60;${uri}/login&#x60;, (err, res) =&#x3E; {
try {
assert.strictEqual(res.statusCode, 200);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>should allow the send shorthand</h1>
<dl>
<dt>with callback in the method call</dt>
<dd><pre><code>request.get(&#x60;${uri}/login&#x60;, (err, res) =&#x3E; {
assert.equal(res.status, 200);
done();
});</code></pre></dd>
<dt>with data in the method call</dt>
<dd><pre><code>request.post(&#x60;${uri}/echo&#x60;, { foo: &#x27;bar&#x27; }).end((err, res) =&#x3E; {
assert.equal(&#x27;{&#x22;foo&#x22;:&#x22;bar&#x22;}&#x27;, res.text);
done();
});</code></pre></dd>
<dt>with callback and data in the method call</dt>
<dd><pre><code>request.post(&#x60;${uri}/echo&#x60;, { foo: &#x27;bar&#x27; }, (err, res) =&#x3E; {
assert.equal(&#x27;{&#x22;foo&#x22;:&#x22;bar&#x22;}&#x27;, res.text);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with a callback</h1>
<dl>
<dt>should invoke .end()</dt>
<dd><pre><code>request.get(&#x60;${uri}/login&#x60;, (err, res) =&#x3E; {
try {
assert.equal(res.status, 200);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.end()</h1>
<dl>
<dt>should issue a request</dt>
<dd><pre><code>request.get(&#x60;${uri}/login&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(res.status, 200);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>is optional with a promise</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return;
}
return request
.get(&#x60;${uri}/login&#x60;)
.then((res) =&#x3E; res.status)
.then()
.then((status) =&#x3E; {
assert.equal(200, status, &#x27;Real promises pass results through&#x27;);
});</code></pre></dd>
<dt>called only once with a promise</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return;
}
const req = request.get(&#x60;${uri}/unique&#x60;);
return Promise.all([req, req, req]).then((results) =&#x3E; {
results.forEach((item) =&#x3E; {
assert.equal(
item.body,
results[0].body,
&#x27;It should keep returning the same result after being called once&#x27;
);
});
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.error</h1>
<dl>
<dt>ok</dt>
<dd><pre><code>let calledErrorEvent = false;
let calledOKHandler = false;
request
.get(&#x60;${uri}/error&#x60;)
.ok((res) =&#x3E; {
assert.strictEqual(500, res.status);
calledOKHandler = true;
return true;
})
.on(&#x27;error&#x27;, (err) =&#x3E; {
calledErrorEvent = true;
})
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert.strictEqual(res.status, 500);
assert(!calledErrorEvent);
assert(calledOKHandler);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should be an Error object</dt>
<dd><pre><code>let calledErrorEvent = false;
request
.get(&#x60;${uri}/error&#x60;)
.on(&#x27;error&#x27;, (err) =&#x3E; {
assert.strictEqual(err.status, 500);
calledErrorEvent = true;
})
.end((err, res) =&#x3E; {
try {
if (NODE) {
res.error.message.should.equal(&#x27;cannot GET /error (500)&#x27;);
} else {
res.error.message.should.equal(&#x60;cannot GET ${uri}/error (500)&#x60;);
}
assert.strictEqual(res.error.status, 500);
assert(err, &#x27;should have an error for 500&#x27;);
assert.equal(err.message, &#x27;Internal Server Error&#x27;);
assert(calledErrorEvent);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>with .then() promise</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return;
}
return request.get(&#x60;${uri}/error&#x60;).then(
() =&#x3E; {
assert.fail();
},
(err) =&#x3E; {
assert.equal(err.message, &#x27;Internal Server Error&#x27;);
}
);</code></pre></dd>
<dt>with .ok() returning false</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return;
}
return request
.get(&#x60;${uri}/echo&#x60;)
.ok(() =&#x3E; false)
.then(
() =&#x3E; {
assert.fail();
},
(err) =&#x3E; {
assert.equal(200, err.response.status);
assert.equal(err.message, &#x27;OK&#x27;);
}
);</code></pre></dd>
<dt>with .ok() throwing an Error</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return;
}
return request
.get(&#x60;${uri}/echo&#x60;)
.ok(() =&#x3E; {
throw new Error(&#x27;boom&#x27;);
})
.then(
() =&#x3E; {
assert.fail();
},
(err) =&#x3E; {
assert.equal(200, err.response.status);
assert.equal(err.message, &#x27;boom&#x27;);
}
);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.header</h1>
<dl>
<dt>should be an object</dt>
<dd><pre><code>request.get(&#x60;${uri}/login&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;Express&#x27;, res.header[&#x27;x-powered-by&#x27;]);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>set headers</h1>
<dl>
<dt>should only set headers for ownProperties of header</dt>
<dd><pre><code>try {
request
.get(&#x60;${uri}/echo-headers&#x60;)
.set(&#x27;valid&#x27;, &#x27;ok&#x27;)
.end((err, res) =&#x3E; {
if (
!err &#x26;&#x26;
res.body &#x26;&#x26;
res.body.valid &#x26;&#x26;
!res.body.hasOwnProperty(&#x27;invalid&#x27;)
) {
return done();
}
done(err || new Error(&#x27;fail&#x27;));
});
} catch (err) {
done(err);
}</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.charset</h1>
<dl>
<dt>should be set when present</dt>
<dd><pre><code>request.get(&#x60;${uri}/login&#x60;).end((err, res) =&#x3E; {
try {
res.charset.should.equal(&#x27;utf-8&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.statusType</h1>
<dl>
<dt>should provide the first digit</dt>
<dd><pre><code>request.get(&#x60;${uri}/login&#x60;).end((err, res) =&#x3E; {
try {
assert(!err, &#x27;should not have an error for success responses&#x27;);
assert.equal(200, res.status);
assert.equal(2, res.statusType);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.type</h1>
<dl>
<dt>should provide the mime-type void of params</dt>
<dd><pre><code>request.get(&#x60;${uri}/login&#x60;).end((err, res) =&#x3E; {
try {
res.type.should.equal(&#x27;text/html&#x27;);
res.charset.should.equal(&#x27;utf-8&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.set(field, val)</h1>
<dl>
<dt>should set the header field</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.set(&#x27;X-Foo&#x27;, &#x27;bar&#x27;)
.set(&#x27;X-Bar&#x27;, &#x27;baz&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;bar&#x27;, res.header[&#x27;x-foo&#x27;]);
assert.equal(&#x27;baz&#x27;, res.header[&#x27;x-bar&#x27;]);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.set(obj)</h1>
<dl>
<dt>should set the header fields</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.set({ &#x27;X-Foo&#x27;: &#x27;bar&#x27;, &#x27;X-Bar&#x27;: &#x27;baz&#x27; })
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;bar&#x27;, res.header[&#x27;x-foo&#x27;]);
assert.equal(&#x27;baz&#x27;, res.header[&#x27;x-bar&#x27;]);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.type(str)</h1>
<dl>
<dt>should set the Content-Type</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.type(&#x27;text/x-foo&#x27;)
.end((err, res) =&#x3E; {
try {
res.header[&#x27;content-type&#x27;].should.equal(&#x27;text/x-foo&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should map &#x22;json&#x22;</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.type(&#x27;json&#x27;)
.send(&#x27;{&#x22;a&#x22;: 1}&#x27;)
.end((err, res) =&#x3E; {
try {
res.should.be.json();
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should map &#x22;html&#x22;</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.type(&#x27;html&#x27;)
.end((err, res) =&#x3E; {
try {
res.header[&#x27;content-type&#x27;].should.equal(&#x27;text/html&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.accept(str)</h1>
<dl>
<dt>should set Accept</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo&#x60;)
.accept(&#x27;text/x-foo&#x27;)
.end((err, res) =&#x3E; {
try {
res.header.accept.should.equal(&#x27;text/x-foo&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should map &#x22;json&#x22;</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo&#x60;)
.accept(&#x27;json&#x27;)
.end((err, res) =&#x3E; {
try {
res.header.accept.should.equal(&#x27;application/json&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should map &#x22;xml&#x22;</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo&#x60;)
.accept(&#x27;xml&#x27;)
.end((err, res) =&#x3E; {
try {
// Mime module keeps changing this :(
assert(
res.header.accept == &#x27;application/xml&#x27; ||
res.header.accept == &#x27;text/xml&#x27;
);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should map &#x22;html&#x22;</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo&#x60;)
.accept(&#x27;html&#x27;)
.end((err, res) =&#x3E; {
try {
res.header.accept.should.equal(&#x27;text/html&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.send(str)</h1>
<dl>
<dt>should write the string</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.type(&#x27;json&#x27;)
.send(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;)
.end((err, res) =&#x3E; {
try {
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.send(Object)</h1>
<dl>
<dt>should default to json</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send({ name: &#x27;tobi&#x27; })
.end((err, res) =&#x3E; {
try {
res.should.be.json();
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<section class="suite">
<h1>when called several times</h1>
<dl>
<dt>should merge the objects</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send({ name: &#x27;tobi&#x27; })
.send({ age: 1 })
.end((err, res) =&#x3E; {
try {
res.should.be.json();
if (NODE) {
res.buffered.should.be.true();
}
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;,&#x22;age&#x22;:1}&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>.end(fn)</h1>
<dl>
<dt>should check arity</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send({ name: &#x27;tobi&#x27; })
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should emit request</dt>
<dd><pre><code>const req = request.post(&#x60;${uri}/echo&#x60;);
req.on(&#x27;request&#x27;, (request) =&#x3E; {
assert.equal(req, request);
done();
});
req.end();</code></pre></dd>
<dt>should emit response</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send({ name: &#x27;tobi&#x27; })
.on(&#x27;response&#x27;, (res) =&#x3E; {
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
done();
})
.end();</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.then(fulfill, reject)</h1>
<dl>
<dt>should support successful fulfills with .then(fulfill)</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return done();
}
request
.post(&#x60;${uri}/echo&#x60;)
.send({ name: &#x27;tobi&#x27; })
.then((res) =&#x3E; {
res.type.should.equal(&#x27;application/json&#x27;);
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
done();
});</code></pre></dd>
<dt>should reject an error with .then(null, reject)</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return done();
}
request.get(&#x60;${uri}/error&#x60;).then(null, (err) =&#x3E; {
assert.equal(err.status, 500);
assert.equal(err.response.text, &#x27;boom&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.catch(reject)</h1>
<dl>
<dt>should reject an error with .catch(reject)</dt>
<dd><pre><code>if (typeof Promise === &#x27;undefined&#x27;) {
return done();
}
request.get(&#x60;${uri}/error&#x60;).catch((err) =&#x3E; {
assert.equal(err.status, 500);
assert.equal(err.response.text, &#x27;boom&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.abort()</h1>
<dl>
<dt>should abort the request</dt>
<dd><pre><code>const req = request.get(&#x60;${uri}/delay/3000&#x60;);
req.end((err, res) =&#x3E; {
try {
assert(false, &#x27;should not complete the request&#x27;);
} catch (err_) {
done(err_);
}
});
req.on(&#x27;error&#x27;, (error) =&#x3E; {
done(error);
});
req.on(&#x27;abort&#x27;, done);
setTimeout(() =&#x3E; {
req.abort();
}, 500);</code></pre></dd>
<dt>should abort the promise</dt>
<dd><pre><code>const req = request.get(&#x60;${uri}/delay/3000&#x60;);
setTimeout(() =&#x3E; {
req.abort();
}, 10);
return req.then(
() =&#x3E; {
assert.fail(&#x27;should not complete the request&#x27;);
},
(err) =&#x3E; {
assert.equal(&#x27;ABORTED&#x27;, err.code);
}
);</code></pre></dd>
<dt>should allow chaining .abort() several times</dt>
<dd><pre><code>const req = request.get(&#x60;${uri}/delay/3000&#x60;);
req.end((err, res) =&#x3E; {
try {
assert(false, &#x27;should not complete the request&#x27;);
} catch (err_) {
done(err_);
}
});
// This also verifies only a single &#x27;done&#x27; event is emitted
req.on(&#x27;abort&#x27;, done);
setTimeout(() =&#x3E; {
req.abort().abort().abort();
}, 1000);</code></pre></dd>
<dt>should not allow abort then end</dt>
<dd><pre><code>request
.get(&#x60;${uri}/delay/3000&#x60;)
.abort()
.end((err, res) =&#x3E; {
done(err ? undefined : new Error(&#x27;Expected abort error&#x27;));
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.toJSON()</h1>
<dl>
<dt>should describe the request</dt>
<dd><pre><code>const req = request.post(&#x60;${uri}/echo&#x60;).send({ foo: &#x27;baz&#x27; });
req.end((err, res) =&#x3E; {
try {
const json = req.toJSON();
assert.equal(&#x27;POST&#x27;, json.method);
assert(/\/echo$/.test(json.url));
assert.equal(&#x27;baz&#x27;, json.data.foo);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.options()</h1>
<dl>
<dt>should allow request body</dt>
<dd><pre><code>request
.options(&#x60;${uri}/options/echo/body&#x60;)
.send({ foo: &#x27;baz&#x27; })
.end((err, res) =&#x3E; {
try {
assert.equal(err, null);
assert.strictEqual(res.body.foo, &#x27;baz&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.sortQuery()</h1>
<dl>
<dt>nop with no querystring</dt>
<dd><pre><code>request
.get(&#x60;${uri}/url&#x60;)
.sortQuery()
.end((err, res) =&#x3E; {
try {
assert.equal(res.text, &#x27;/url&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should sort the request querystring</dt>
<dd><pre><code>request
.get(&#x60;${uri}/url&#x60;)
.query(&#x27;search=Manny&#x27;)
.query(&#x27;order=desc&#x27;)
.sortQuery()
.end((err, res) =&#x3E; {
try {
assert.equal(res.text, &#x27;/url?order=desc&#x26;search=Manny&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should allow disabling sorting</dt>
<dd><pre><code>request
.get(&#x60;${uri}/url&#x60;)
.query(&#x27;search=Manny&#x27;)
.query(&#x27;order=desc&#x27;)
.sortQuery() // take default of true
.sortQuery(false) // override it in later call
.end((err, res) =&#x3E; {
try {
assert.equal(res.text, &#x27;/url?search=Manny&#x26;order=desc&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should sort the request querystring using customized function</dt>
<dd><pre><code>request
.get(&#x60;${uri}/url&#x60;)
.query(&#x27;name=Nick&#x27;)
.query(&#x27;search=Manny&#x27;)
.query(&#x27;order=desc&#x27;)
.sortQuery((a, b) =&#x3E; a.length - b.length)
.end((err, res) =&#x3E; {
try {
assert.equal(res.text, &#x27;/url?name=Nick&#x26;order=desc&#x26;search=Manny&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>req.set(&#x22;Content-Type&#x22;, contentType)</h1>
<dl>
<dt>should work with just the contentType component</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;application/json&#x27;)
.send({ name: &#x27;tobi&#x27; })
.end((err, res) =&#x3E; {
assert(!err);
done();
});</code></pre></dd>
<dt>should work with the charset component</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;application/json; charset=utf-8&#x27;)
.send({ name: &#x27;tobi&#x27; })
.end((err, res) =&#x3E; {
assert(!err);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.send(Object) as &#x22;form&#x22;</h1>
<dl>
<section class="suite">
<h1>with req.type() set to form</h1>
<dl>
<dt>should send x-www-form-urlencoded data</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.type(&#x27;form&#x27;)
.send({ name: &#x27;tobi&#x27; })
.end((err, res) =&#x3E; {
res.header[&#x27;content-type&#x27;].should.equal(
&#x27;application/x-www-form-urlencoded&#x27;
);
res.text.should.equal(&#x27;name=tobi&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>when called several times</h1>
<dl>
<dt>should merge the objects</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.type(&#x27;form&#x27;)
.send({ name: { first: &#x27;tobi&#x27;, last: &#x27;holowaychuk&#x27; } })
.send({ age: &#x27;1&#x27; })
.end((err, res) =&#x3E; {
res.header[&#x27;content-type&#x27;].should.equal(
&#x27;application/x-www-form-urlencoded&#x27;
);
res.text.should.equal(
&#x27;name%5Bfirst%5D=tobi&#x26;name%5Blast%5D=holowaychuk&#x26;age=1&#x27;
);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>req.attach</h1>
<dl>
<dt>ignores null file</dt>
<dd><pre><code>request
.post(&#x27;/echo&#x27;)
.attach(&#x27;image&#x27;, null)
.end((err, res) =&#x3E; {
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.field</h1>
<dl>
<dt>allow bools</dt>
<dd><pre><code>if (!formDataSupported) {
return done();
}
request
.post(&#x60;${base}/formecho&#x60;)
.field(&#x27;bools&#x27;, true)
.field(&#x27;strings&#x27;, &#x27;true&#x27;)
.end((err, res) =&#x3E; {
assert.ifError(err);
assert.deepStrictEqual(res.body, { bools: &#x27;true&#x27;, strings: &#x27;true&#x27; });
done();
});</code></pre></dd>
<dt>allow objects</dt>
<dd><pre><code>if (!formDataSupported) {
return done();
}
request
.post(&#x60;${base}/formecho&#x60;)
.field({ bools: true, strings: &#x27;true&#x27; })
.end((err, res) =&#x3E; {
assert.ifError(err);
assert.deepStrictEqual(res.body, { bools: &#x27;true&#x27;, strings: &#x27;true&#x27; });
done();
});</code></pre></dd>
<dt>works with arrays in objects</dt>
<dd><pre><code>if (!formDataSupported) {
return done();
}
request
.post(&#x60;${base}/formecho&#x60;)
.field({ numbers: [1, 2, 3] })
.end((err, res) =&#x3E; {
assert.ifError(err);
assert.deepStrictEqual(res.body, { numbers: [&#x27;1&#x27;, &#x27;2&#x27;, &#x27;3&#x27;] });
done();
});</code></pre></dd>
<dt>works with arrays</dt>
<dd><pre><code>if (!formDataSupported) {
return done();
}
request
.post(&#x60;${base}/formecho&#x60;)
.field(&#x27;letters&#x27;, [&#x27;a&#x27;, &#x27;b&#x27;, &#x27;c&#x27;])
.end((err, res) =&#x3E; {
assert.ifError(err);
assert.deepStrictEqual(res.body, { letters: [&#x27;a&#x27;, &#x27;b&#x27;, &#x27;c&#x27;] });
done();
});</code></pre></dd>
<dt>throw when empty</dt>
<dd><pre><code>should.throws(() =&#x3E; {
request.post(&#x60;${base}/echo&#x60;).field();
}, /name/);
should.throws(() =&#x3E; {
request.post(&#x60;${base}/echo&#x60;).field(&#x27;name&#x27;);
}, /val/);</code></pre></dd>
<dt>cannot be mixed with send()</dt>
<dd><pre><code>assert.throws(() =&#x3E; {
request.post(&#x27;/echo&#x27;).field(&#x27;form&#x27;, &#x27;data&#x27;).send(&#x27;hi&#x27;);
});
assert.throws(() =&#x3E; {
request.post(&#x27;/echo&#x27;).send(&#x27;hi&#x27;).field(&#x27;form&#x27;, &#x27;data&#x27;);
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.send(Object) as &#x22;json&#x22;</h1>
<dl>
<dt>should default to json</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send({ name: &#x27;tobi&#x27; })
.end((err, res) =&#x3E; {
res.should.be.json();
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
done();
});</code></pre></dd>
<dt>should work with arrays</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send([1, 2, 3])
.end((err, res) =&#x3E; {
res.should.be.json();
res.text.should.equal(&#x27;[1,2,3]&#x27;);
done();
});</code></pre></dd>
<dt>should work with value null</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.type(&#x27;json&#x27;)
.send(&#x27;null&#x27;)
.end((err, res) =&#x3E; {
res.should.be.json();
assert.strictEqual(res.body, null);
done();
});</code></pre></dd>
<dt>should work with value false</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.type(&#x27;json&#x27;)
.send(&#x27;false&#x27;)
.end((err, res) =&#x3E; {
res.should.be.json();
res.body.should.equal(false);
done();
});</code></pre></dd>
<dt>should work with value 0</dt>
<dd><pre><code>// fails in IE9
request
.post(&#x60;${uri}/echo&#x60;)
.type(&#x27;json&#x27;)
.send(&#x27;0&#x27;)
.end((err, res) =&#x3E; {
res.should.be.json();
res.body.should.equal(0);
done();
});</code></pre></dd>
<dt>should work with empty string value</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.type(&#x27;json&#x27;)
.send(&#x27;&#x22;&#x22;&#x27;)
.end((err, res) =&#x3E; {
res.should.be.json();
res.body.should.equal(&#x27;&#x27;);
done();
});</code></pre></dd>
<dt>should work with GET</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo&#x60;)
.send({ tobi: &#x27;ferret&#x27; })
.end((err, res) =&#x3E; {
try {
res.should.be.json();
res.text.should.equal(&#x27;{&#x22;tobi&#x22;:&#x22;ferret&#x22;}&#x27;);
({ tobi: &#x27;ferret&#x27; }.should.eql(res.body));
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should work with vendor MIME type</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;application/vnd.example+json&#x27;)
.send({ name: &#x27;vendor&#x27; })
.end((err, res) =&#x3E; {
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;vendor&#x22;}&#x27;);
({ name: &#x27;vendor&#x27; }.should.eql(res.body));
done();
});</code></pre></dd>
<section class="suite">
<h1>when called several times</h1>
<dl>
<dt>should merge the objects</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send({ name: &#x27;tobi&#x27; })
.send({ age: 1 })
.end((err, res) =&#x3E; {
res.should.be.json();
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;,&#x22;age&#x22;:1}&#x27;);
({ name: &#x27;tobi&#x27;, age: 1 }.should.eql(res.body));
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>res.body</h1>
<dl>
<section class="suite">
<h1>application/json</h1>
<dl>
<dt>should parse the body</dt>
<dd><pre><code>request.get(&#x60;${uri}/json&#x60;).end((err, res) =&#x3E; {
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;manny&#x22;}&#x27;);
res.body.should.eql({ name: &#x27;manny&#x27; });
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>HEAD requests</h1>
<dl>
<dt>should not throw a parse error</dt>
<dd><pre><code>request.head(&#x60;${uri}/json&#x60;).end((err, res) =&#x3E; {
try {
assert.strictEqual(err, null);
assert.strictEqual(res.text, undefined);
assert.strictEqual(Object.keys(res.body).length, 0);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>Invalid JSON response</h1>
<dl>
<dt>should return the raw response</dt>
<dd><pre><code>request.get(&#x60;${uri}/invalid-json&#x60;).end((err, res) =&#x3E; {
assert.deepEqual(
err.rawResponse,
&#x22;)]}&#x27;, {&#x27;header&#x27;:{&#x27;code&#x27;:200,&#x27;text&#x27;:&#x27;OK&#x27;,&#x27;version&#x27;:&#x27;1.0&#x27;},&#x27;data&#x27;:&#x27;some data&#x27;}&#x22;
);
done();
});</code></pre></dd>
<dt>should return the http status code</dt>
<dd><pre><code>request.get(&#x60;${uri}/invalid-json-forbidden&#x60;).end((err, res) =&#x3E; {
assert.equal(err.statusCode, 403);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>No content</h1>
<dl>
<dt>should not throw a parse error</dt>
<dd><pre><code>request.get(&#x60;${uri}/no-content&#x60;).end((err, res) =&#x3E; {
try {
assert.strictEqual(err, null);
assert.strictEqual(res.text, &#x27;&#x27;);
assert.strictEqual(Object.keys(res.body).length, 0);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>application/json+hal</h1>
<dl>
<dt>should parse the body</dt>
<dd><pre><code>request.get(&#x60;${uri}/json-hal&#x60;).end((err, res) =&#x3E; {
if (err) return done(err);
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;hal 5000&#x22;}&#x27;);
res.body.should.eql({ name: &#x27;hal 5000&#x27; });
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>vnd.collection+json</h1>
<dl>
<dt>should parse the body</dt>
<dd><pre><code>request.get(&#x60;${uri}/collection-json&#x60;).end((err, res) =&#x3E; {
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;chewbacca&#x22;}&#x27;);
res.body.should.eql({ name: &#x27;chewbacca&#x27; });
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>request</h1>
<dl>
<section class="suite">
<h1>on redirect</h1>
<dl>
<dt>should retain header fields</dt>
<dd><pre><code>request
.get(&#x60;${base}/header&#x60;)
.set(&#x27;X-Foo&#x27;, &#x27;bar&#x27;)
.end((err, res) =&#x3E; {
try {
assert(res.body);
res.body.should.have.property(&#x27;x-foo&#x27;, &#x27;bar&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should preserve timeout across redirects</dt>
<dd><pre><code>request
.get(&#x60;${base}/movies/random&#x60;)
.timeout(250)
.end((err, res) =&#x3E; {
try {
assert(err instanceof Error, &#x27;expected an error&#x27;);
err.should.have.property(&#x27;timeout&#x27;, 250);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should successfully redirect after retry on error</dt>
<dd><pre><code>const id = Math.random() * 1000000 * Date.now();
request
.get(&#x60;${base}/error/redirect/${id}&#x60;)
.retry(2)
.end((err, res) =&#x3E; {
assert(res.ok, &#x27;response should be ok&#x27;);
assert(res.text, &#x27;first movie page&#x27;);
done();
});</code></pre></dd>
<dt>should preserve retries across redirects</dt>
<dd><pre><code>const id = Math.random() * 1000000 * Date.now();
request
.get(&#x60;${base}/error/redirect-error${id}&#x60;)
.retry(2)
.end((err, res) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
assert.equal(2, err.retries, &#x27;expected an error with .retries&#x27;);
assert.equal(500, err.status, &#x27;expected an error status of 500&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 303</h1>
<dl>
<dt>should redirect with same method</dt>
<dd><pre><code>request
.put(&#x60;${base}/redirect-303&#x60;)
.send({ msg: &#x27;hello&#x27; })
.redirects(1)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
res.headers.location.should.equal(&#x27;/reply-method&#x27;);
})
.end((err, res) =&#x3E; {
if (err) {
done(err);
return;
}
res.text.should.equal(&#x27;method=get&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 307</h1>
<dl>
<dt>should redirect with same method</dt>
<dd><pre><code>if (isMSIE) return done(); // IE9 broken
request
.put(&#x60;${base}/redirect-307&#x60;)
.send({ msg: &#x27;hello&#x27; })
.redirects(1)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
res.headers.location.should.equal(&#x27;/reply-method&#x27;);
})
.end((err, res) =&#x3E; {
if (err) {
done(err);
return;
}
res.text.should.equal(&#x27;method=put&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 308</h1>
<dl>
<dt>should redirect with same method</dt>
<dd><pre><code>if (isMSIE) return done(); // IE9 broken
request
.put(&#x60;${base}/redirect-308&#x60;)
.send({ msg: &#x27;hello&#x27; })
.redirects(1)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
res.headers.location.should.equal(&#x27;/reply-method&#x27;);
})
.end((err, res) =&#x3E; {
if (err) {
done(err);
return;
}
res.text.should.equal(&#x27;method=put&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>request</h1>
<dl>
<dt>Request inheritance</dt>
<dd><pre><code>assert(request.get(&#x60;${uri}/&#x60;) instanceof request.Request);</code></pre></dd>
<dt>request() simple GET without callback</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x27;test/test.request.js&#x27;).end();
next();</code></pre></dd>
<dt>request() simple GET</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/ok&#x60;).end((err, res) =&#x3E; {
try {
assert(res instanceof request.Response, &#x27;respond with Response&#x27;);
assert(res.ok, &#x27;response should be ok&#x27;);
assert(res.text, &#x27;res.text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() simple HEAD</dt>
<dd><pre><code>request.head(&#x60;${uri}/ok&#x60;).end((err, res) =&#x3E; {
try {
assert(res instanceof request.Response, &#x27;respond with Response&#x27;);
assert(res.ok, &#x27;response should be ok&#x27;);
assert(!res.text, &#x27;res.text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() GET 5xx</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/error&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert.equal(err.message, &#x27;Internal Server Error&#x27;);
assert(!res.ok, &#x27;response should not be ok&#x27;);
assert(res.error, &#x27;response should be an error&#x27;);
assert(!res.clientError, &#x27;response should not be a client error&#x27;);
assert(res.serverError, &#x27;response should be a server error&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() GET 4xx</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/notfound&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert.equal(err.message, &#x27;Not Found&#x27;);
assert(!res.ok, &#x27;response should not be ok&#x27;);
assert(res.error, &#x27;response should be an error&#x27;);
assert(res.clientError, &#x27;response should be a client error&#x27;);
assert(!res.serverError, &#x27;response should not be a server error&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() GET 404 Not Found</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/notfound&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert(res.notFound, &#x27;response should be .notFound&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() GET 400 Bad Request</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/bad-request&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert(res.badRequest, &#x27;response should be .badRequest&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() GET 401 Bad Request</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/unauthorized&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert(res.unauthorized, &#x27;response should be .unauthorized&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() GET 406 Not Acceptable</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/not-acceptable&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert(res.notAcceptable, &#x27;response should be .notAcceptable&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() GET 204 No Content</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/no-content&#x60;).end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(res.noContent, &#x27;response should be .noContent&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() DELETE 204 No Content</dt>
<dd><pre><code>request(&#x27;DELETE&#x27;, &#x60;${uri}/no-content&#x60;).end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(res.noContent, &#x27;response should be .noContent&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() header parsing</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/notfound&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert.equal(&#x27;text/html; charset=utf-8&#x27;, res.header[&#x27;content-type&#x27;]);
assert.equal(&#x27;Express&#x27;, res.header[&#x27;x-powered-by&#x27;]);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request() .status</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/notfound&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert.equal(404, res.status, &#x27;response .status&#x27;);
assert.equal(4, res.statusType, &#x27;response .statusType&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>get()</dt>
<dd><pre><code>request.get(&#x60;${uri}/notfound&#x60;).end((err, res) =&#x3E; {
try {
assert(err);
assert.equal(404, res.status, &#x27;response .status&#x27;);
assert.equal(4, res.statusType, &#x27;response .statusType&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>put()</dt>
<dd><pre><code>request.put(&#x60;${uri}/user/12&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;updated&#x27;, res.text, &#x27;response text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>put().send()</dt>
<dd><pre><code>request
.put(&#x60;${uri}/user/13/body&#x60;)
.send({ user: &#x27;new&#x27; })
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;received new&#x27;, res.text, &#x27;response text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>post()</dt>
<dd><pre><code>request.post(&#x60;${uri}/user&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;created&#x27;, res.text, &#x27;response text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>del()</dt>
<dd><pre><code>request.del(&#x60;${uri}/user/12&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;deleted&#x27;, res.text, &#x27;response text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>delete()</dt>
<dd><pre><code>request.delete(&#x60;${uri}/user/12&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;deleted&#x27;, res.text, &#x27;response text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>post() data</dt>
<dd><pre><code>request
.post(&#x60;${uri}/todo/item&#x60;)
.type(&#x27;application/octet-stream&#x27;)
.send(&#x27;tobi&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;added &#x22;tobi&#x22;&#x27;, res.text, &#x27;response text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .type()</dt>
<dd><pre><code>request
.post(&#x60;${uri}/user/12/pet&#x60;)
.type(&#x27;urlencoded&#x27;)
.send(&#x27;pet=tobi&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;added pet &#x22;tobi&#x22;&#x27;, res.text, &#x27;response text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .type() with alias</dt>
<dd><pre><code>request
.post(&#x60;${uri}/user/12/pet&#x60;)
.type(&#x27;application/x-www-form-urlencoded&#x27;)
.send(&#x27;pet=tobi&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;added pet &#x22;tobi&#x22;&#x27;, res.text, &#x27;response text&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .get() with no data or callback</dt>
<dd><pre><code>request.get(&#x60;${uri}/echo-header/content-type&#x60;);
next();</code></pre></dd>
<dt>request .send() with no data only</dt>
<dd><pre><code>request.post(&#x60;${uri}/user/5/pet&#x60;).type(&#x27;urlencoded&#x27;).send(&#x27;pet=tobi&#x27;);
next();</code></pre></dd>
<dt>request .send() with callback only</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo-header/accept&#x60;)
.set(&#x27;Accept&#x27;, &#x27;foo/bar&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;foo/bar&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .accept() with json</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo-header/accept&#x60;)
.accept(&#x27;json&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;application/json&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .accept() with application/json</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo-header/accept&#x60;)
.accept(&#x27;application/json&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;application/json&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .accept() with xml</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo-header/accept&#x60;)
.accept(&#x27;xml&#x27;)
.end((err, res) =&#x3E; {
try {
// We can&#x27;t depend on mime module to be consistent with this
assert(res.text == &#x27;application/xml&#x27; || res.text == &#x27;text/xml&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .accept() with application/xml</dt>
<dd><pre><code>request
.get(&#x60;${uri}/echo-header/accept&#x60;)
.accept(&#x27;application/xml&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;application/xml&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .end()</dt>
<dd><pre><code>request
.put(&#x60;${uri}/echo-header/content-type&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;text/plain&#x27;)
.send(&#x27;wahoo&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;text/plain&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .send()</dt>
<dd><pre><code>request
.put(&#x60;${uri}/echo-header/content-type&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;text/plain&#x27;)
.send(&#x27;wahoo&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;text/plain&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .set()</dt>
<dd><pre><code>request
.put(&#x60;${uri}/echo-header/content-type&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;text/plain&#x27;)
.send(&#x27;wahoo&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;text/plain&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request .set(object)</dt>
<dd><pre><code>request
.put(&#x60;${uri}/echo-header/content-type&#x60;)
.set({ &#x27;Content-Type&#x27;: &#x27;text/plain&#x27; })
.send(&#x27;wahoo&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;text/plain&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST urlencoded</dt>
<dd><pre><code>request
.post(&#x60;${uri}/pet&#x60;)
.type(&#x27;urlencoded&#x27;)
.send({ name: &#x27;Manny&#x27;, species: &#x27;cat&#x27; })
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;added Manny the cat&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST json</dt>
<dd><pre><code>request
.post(&#x60;${uri}/pet&#x60;)
.type(&#x27;json&#x27;)
.send({ name: &#x27;Manny&#x27;, species: &#x27;cat&#x27; })
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;added Manny the cat&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST json array</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send([1, 2, 3])
.end((err, res) =&#x3E; {
try {
assert.equal(
&#x27;application/json&#x27;,
res.header[&#x27;content-type&#x27;].split(&#x27;;&#x27;)[0]
);
assert.equal(&#x27;[1,2,3]&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST json default</dt>
<dd><pre><code>request
.post(&#x60;${uri}/pet&#x60;)
.send({ name: &#x27;Manny&#x27;, species: &#x27;cat&#x27; })
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;added Manny the cat&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST json contentType charset</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;application/json; charset=UTF-8&#x27;)
.send({ data: [&#x27;data1&#x27;, &#x27;data2&#x27;] })
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;{&#x22;data&#x22;:[&#x22;data1&#x22;,&#x22;data2&#x22;]}&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST json contentType vendor</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;application/vnd.example+json&#x27;)
.send({ data: [&#x27;data1&#x27;, &#x27;data2&#x27;] })
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;{&#x22;data&#x22;:[&#x22;data1&#x22;,&#x22;data2&#x22;]}&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST multiple .send() calls</dt>
<dd><pre><code>request
.post(&#x60;${uri}/pet&#x60;)
.send({ name: &#x27;Manny&#x27; })
.send({ species: &#x27;cat&#x27; })
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;added Manny the cat&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST multiple .send() strings</dt>
<dd><pre><code>request
.post(&#x60;${uri}/echo&#x60;)
.send(&#x27;user[name]=tj&#x27;)
.send(&#x27;user[email]=tj@vision-media.ca&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(
&#x27;application/x-www-form-urlencoded&#x27;,
res.header[&#x27;content-type&#x27;].split(&#x27;;&#x27;)[0]
);
assert.equal(
res.text,
&#x27;user[name]=tj&#x26;user[email]=tj@vision-media.ca&#x27;
);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST with no data</dt>
<dd><pre><code>request
.post(&#x60;${uri}/empty-body&#x60;)
.send()
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(res.noContent, &#x27;response should be .noContent&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET .type</dt>
<dd><pre><code>request.get(&#x60;${uri}/pets&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;application/json&#x27;, res.type);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET Content-Type params</dt>
<dd><pre><code>request.get(&#x60;${uri}/text&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;utf-8&#x27;, res.charset);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET json</dt>
<dd><pre><code>request.get(&#x60;${uri}/pets&#x60;).end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, [&#x27;tobi&#x27;, &#x27;loki&#x27;, &#x27;jane&#x27;]);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET json-seq</dt>
<dd><pre><code>request
.get(&#x60;${uri}/json-seq&#x60;)
.buffer()
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert.deepEqual(res.text, &#x27;\u001E{&#x22;id&#x22;:1}\n\u001E{&#x22;id&#x22;:2}\n&#x27;);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET x-www-form-urlencoded</dt>
<dd><pre><code>request.get(&#x60;${uri}/foo&#x60;).end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, { foo: &#x27;bar&#x27; });
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET shorthand</dt>
<dd><pre><code>request.get(&#x60;${uri}/foo&#x60;, (err, res) =&#x3E; {
try {
assert.equal(&#x27;foo=bar&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST shorthand</dt>
<dd><pre><code>request.post(&#x60;${uri}/user/0/pet&#x60;, { pet: &#x27;tobi&#x27; }, (err, res) =&#x3E; {
try {
assert.equal(&#x27;added pet &#x22;tobi&#x22;&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>POST shorthand without callback</dt>
<dd><pre><code>request.post(&#x60;${uri}/user/0/pet&#x60;, { pet: &#x27;tobi&#x27; }).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;added pet &#x22;tobi&#x22;&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET querystring object with array</dt>
<dd><pre><code>request
.get(&#x60;${uri}/querystring&#x60;)
.query({ val: [&#x27;a&#x27;, &#x27;b&#x27;, &#x27;c&#x27;] })
.end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, { val: [&#x27;a&#x27;, &#x27;b&#x27;, &#x27;c&#x27;] });
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET querystring object with array and primitives</dt>
<dd><pre><code>request
.get(&#x60;${uri}/querystring&#x60;)
.query({ array: [&#x27;a&#x27;, &#x27;b&#x27;, &#x27;c&#x27;], string: &#x27;foo&#x27;, number: 10 })
.end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, {
array: [&#x27;a&#x27;, &#x27;b&#x27;, &#x27;c&#x27;],
string: &#x27;foo&#x27;,
number: 10
});
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET querystring object with two arrays</dt>
<dd><pre><code>request
.get(&#x60;${uri}/querystring&#x60;)
.query({ array1: [&#x27;a&#x27;, &#x27;b&#x27;, &#x27;c&#x27;], array2: [1, 2, 3] })
.end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, {
array1: [&#x27;a&#x27;, &#x27;b&#x27;, &#x27;c&#x27;],
array2: [1, 2, 3]
});
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET querystring object</dt>
<dd><pre><code>request
.get(&#x60;${uri}/querystring&#x60;)
.query({ search: &#x27;Manny&#x27; })
.end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, { search: &#x27;Manny&#x27; });
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET querystring append original</dt>
<dd><pre><code>request
.get(&#x60;${uri}/querystring?search=Manny&#x60;)
.query({ range: &#x27;1..5&#x27; })
.end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, { search: &#x27;Manny&#x27;, range: &#x27;1..5&#x27; });
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET querystring multiple objects</dt>
<dd><pre><code>request
.get(&#x60;${uri}/querystring&#x60;)
.query({ search: &#x27;Manny&#x27; })
.query({ range: &#x27;1..5&#x27; })
.query({ order: &#x27;desc&#x27; })
.end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, {
search: &#x27;Manny&#x27;,
range: &#x27;1..5&#x27;,
order: &#x27;desc&#x27;
});
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET querystring with strings</dt>
<dd><pre><code>request
.get(&#x60;${uri}/querystring&#x60;)
.query(&#x27;search=Manny&#x27;)
.query(&#x27;range=1..5&#x27;)
.query(&#x27;order=desc&#x27;)
.end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, {
search: &#x27;Manny&#x27;,
range: &#x27;1..5&#x27;,
order: &#x27;desc&#x27;
});
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET querystring with strings and objects</dt>
<dd><pre><code>request
.get(&#x60;${uri}/querystring&#x60;)
.query(&#x27;search=Manny&#x27;)
.query({ order: &#x27;desc&#x27;, range: &#x27;1..5&#x27; })
.end((err, res) =&#x3E; {
try {
assert.deepEqual(res.body, {
search: &#x27;Manny&#x27;,
range: &#x27;1..5&#x27;,
order: &#x27;desc&#x27;
});
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>GET shorthand payload goes to querystring</dt>
<dd><pre><code>request.get(
&#x60;${uri}/querystring&#x60;,
{ foo: &#x27;FOO&#x27;, bar: &#x27;BAR&#x27; },
(err, res) =&#x3E; {
try {
assert.deepEqual(res.body, { foo: &#x27;FOO&#x27;, bar: &#x27;BAR&#x27; });
next();
} catch (err_) {
next(err_);
}
}
);</code></pre></dd>
<dt>HEAD shorthand payload goes to querystring</dt>
<dd><pre><code>request.head(
&#x60;${uri}/querystring-in-header&#x60;,
{ foo: &#x27;FOO&#x27;, bar: &#x27;BAR&#x27; },
(err, res) =&#x3E; {
try {
assert.deepEqual(JSON.parse(res.headers.query), {
foo: &#x27;FOO&#x27;,
bar: &#x27;BAR&#x27;
});
next();
} catch (err_) {
next(err_);
}
}
);</code></pre></dd>
<dt>request(method, url)</dt>
<dd><pre><code>request(&#x27;GET&#x27;, &#x60;${uri}/foo&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;bar&#x27;, res.body.foo);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request(url)</dt>
<dd><pre><code>request(&#x60;${uri}/foo&#x60;).end((err, res) =&#x3E; {
try {
assert.equal(&#x27;bar&#x27;, res.body.foo);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request(url, fn)</dt>
<dd><pre><code>request(&#x60;${uri}/foo&#x60;, (err, res) =&#x3E; {
try {
assert.equal(&#x27;bar&#x27;, res.body.foo);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>req.timeout(ms)</dt>
<dd><pre><code>const req = request.get(&#x60;${uri}/delay/3000&#x60;).timeout(1000);
req.end((err, res) =&#x3E; {
try {
assert(err, &#x27;error missing&#x27;);
assert.equal(1000, err.timeout, &#x27;err.timeout missing&#x27;);
assert.equal(
&#x27;Timeout of 1000ms exceeded&#x27;,
err.message,
&#x27;err.message incorrect&#x27;
);
assert.equal(null, res);
assert(req.timedout, true);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>req.timeout(ms) with redirect</dt>
<dd><pre><code>const req = request.get(&#x60;${uri}/delay/const&#x60;).timeout(1000);
req.end((err, res) =&#x3E; {
try {
assert(err, &#x27;error missing&#x27;);
assert.equal(1000, err.timeout, &#x27;err.timeout missing&#x27;);
assert.equal(
&#x27;Timeout of 1000ms exceeded&#x27;,
err.message,
&#x27;err.message incorrect&#x27;
);
assert.equal(null, res);
assert(req.timedout, true);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>request event</dt>
<dd><pre><code>request
.get(&#x60;${uri}/foo&#x60;)
.on(&#x27;request&#x27;, (req) =&#x3E; {
try {
assert.equal(&#x60;${uri}/foo&#x60;, req.url);
next();
} catch (err) {
next(err);
}
})
.end();</code></pre></dd>
<dt>response event</dt>
<dd><pre><code>request
.get(&#x60;${uri}/foo&#x60;)
.on(&#x27;response&#x27;, (res) =&#x3E; {
try {
assert.equal(&#x27;bar&#x27;, res.body.foo);
next();
} catch (err) {
next(err);
}
})
.end();</code></pre></dd>
<dt>response should set statusCode</dt>
<dd><pre><code>request.get(&#x60;${uri}/ok&#x60;, (err, res) =&#x3E; {
try {
assert.strictEqual(res.statusCode, 200);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<dt>req.toJSON()</dt>
<dd><pre><code>request.get(&#x60;${uri}/ok&#x60;).end((err, res) =&#x3E; {
try {
const j = (res.request || res.req).toJSON();
[&#x27;url&#x27;, &#x27;method&#x27;, &#x27;data&#x27;, &#x27;headers&#x27;].forEach((prop) =&#x3E; {
assert(j.hasOwnProperty(prop));
});
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.retry(count)</h1>
<dl>
<dt>should not retry if passed &#x22;0&#x22;</dt>
<dd><pre><code>request
.get(&#x60;${base}/error&#x60;)
.retry(0)
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
undefined,
err.retries,
&#x27;expected an error without .retries&#x27;
);
assert.equal(500, err.status, &#x27;expected an error status of 500&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should not retry if passed an invalid number</dt>
<dd><pre><code>request
.get(&#x60;${base}/error&#x60;)
.retry(-2)
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
undefined,
err.retries,
&#x27;expected an error without .retries&#x27;
);
assert.equal(500, err.status, &#x27;expected an error status of 500&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should not retry if passed undefined</dt>
<dd><pre><code>request
.get(&#x60;${base}/error&#x60;)
.retry(undefined)
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
undefined,
err.retries,
&#x27;expected an error without .retries&#x27;
);
assert.equal(500, err.status, &#x27;expected an error status of 500&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should handle server error after repeat attempt</dt>
<dd><pre><code>request
.get(&#x60;${base}/error&#x60;)
.retry(2)
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(2, err.retries, &#x27;expected an error with .retries&#x27;);
assert.equal(500, err.status, &#x27;expected an error status of 500&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should retry if passed nothing</dt>
<dd><pre><code>request
.get(&#x60;${base}/error&#x60;)
.retry()
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(1, err.retries, &#x27;expected an error with .retries&#x27;);
assert.equal(500, err.status, &#x27;expected an error status of 500&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should retry if passed &#x22;true&#x22;</dt>
<dd><pre><code>request
.get(&#x60;${base}/error&#x60;)
.retry(true)
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(1, err.retries, &#x27;expected an error with .retries&#x27;);
assert.equal(500, err.status, &#x27;expected an error status of 500&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should handle successful request after repeat attempt from server error</dt>
<dd><pre><code>request
.get(&#x60;${base}/error/ok/${uniqid()}&#x60;)
.query({ qs: &#x27;present&#x27; })
.retry(2)
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(res.ok, &#x27;response should be ok&#x27;);
assert(res.text, &#x27;res.text&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should handle server timeout error after repeat attempt</dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/400&#x60;)
.timeout(200)
.retry(2)
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(2, err.retries, &#x27;expected an error with .retries&#x27;);
assert.equal(
&#x27;number&#x27;,
typeof err.timeout,
&#x27;expected an error with .timeout&#x27;
);
assert.equal(&#x27;ECONNABORTED&#x27;, err.code, &#x27;expected abort error code&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should handle successful request after repeat attempt from server timeout</dt>
<dd><pre><code>const url = &#x60;/delay/1200/ok/${uniqid()}?built=in&#x60;;
request
.get(base + url)
.query(&#x27;string=ified&#x27;)
.query({ json: &#x27;ed&#x27; })
.timeout(600)
.retry(2)
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(res.ok, &#x27;response should be ok&#x27;);
assert.equal(res.text, &#x60;ok = ${url}&#x26;string=ified&#x26;json=ed&#x60;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should handle successful request after repeat attempt from server timeout when using .then(fulfill, reject)</dt>
<dd><pre><code>const url = &#x60;/delay/1200/ok/${uniqid()}?built=in&#x60;;
request
.get(base + url)
.query(&#x27;string=ified&#x27;)
.query({ json: &#x27;ed&#x27; })
.timeout(600)
.retry(1)
.then((res, err) =&#x3E; {
try {
assert.ifError(err);
assert(res.ok, &#x27;response should be ok&#x27;);
assert.equal(res.text, &#x60;ok = ${url}&#x26;string=ified&#x26;json=ed&#x60;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should correctly abort a retry attempt</dt>
<dd><pre><code>let aborted = false;
const req = request.get(&#x60;${base}/delay/400&#x60;).timeout(200).retry(2);
req.end((err, res) =&#x3E; {
try {
assert(false, &#x27;should not complete the request&#x27;);
} catch (err_) {
done(err_);
}
});
req.on(&#x27;abort&#x27;, () =&#x3E; {
aborted = true;
});
setTimeout(() =&#x3E; {
req.abort();
setTimeout(() =&#x3E; {
try {
assert(aborted, &#x27;should be aborted&#x27;);
done();
} catch (err) {
done(err);
}
}, 150);
}, 150);</code></pre></dd>
<dt>should correctly retain header fields</dt>
<dd><pre><code>request
.get(&#x60;${base}/error/ok/${uniqid()}&#x60;)
.query({ qs: &#x27;present&#x27; })
.retry(2)
.set(&#x27;X-Foo&#x27;, &#x27;bar&#x27;)
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(res.body);
res.body.should.have.property(&#x27;x-foo&#x27;, &#x27;bar&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should not retry on 4xx responses</dt>
<dd><pre><code>request
.get(&#x60;${base}/bad-request&#x60;)
.retry(2)
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(0, err.retries, &#x27;expected an error with 0 .retries&#x27;);
assert.equal(400, err.status, &#x27;expected an error status of 400&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should execute callback on retry if passed</dt>
<dd><pre><code>let callbackCallCount = 0;
function retryCallback(request) {
callbackCallCount++;
}
request
.get(&#x60;${base}/error&#x60;)
.retry(2, retryCallback)
.end((err, res) =&#x3E; {
try {
assert(err, &#x27;expected an error&#x27;);
assert.equal(2, err.retries, &#x27;expected an error with .retries&#x27;);
assert.equal(500, err.status, &#x27;expected an error status of 500&#x27;);
assert.equal(
2,
callbackCallCount,
&#x27;expected the callback to be called on each retry&#x27;
);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.timeout(ms)</h1>
<dl>
<section class="suite">
<h1>when timeout is exceeded</h1>
<dl>
<dt>should error</dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/500&#x60;)
.timeout(150)
.end((err, res) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
&#x27;number&#x27;,
typeof err.timeout,
&#x27;expected an error with .timeout&#x27;
);
assert.equal(&#x27;ECONNABORTED&#x27;, err.code, &#x27;expected abort error code&#x27;);
done();
});</code></pre></dd>
<dt>should error in promise interface </dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/500&#x60;)
.timeout(150)
.catch((err) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
&#x27;number&#x27;,
typeof err.timeout,
&#x27;expected an error with .timeout&#x27;
);
assert.equal(&#x27;ECONNABORTED&#x27;, err.code, &#x27;expected abort error code&#x27;);
done();
});</code></pre></dd>
<dt>should handle gzip timeout</dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/zip&#x60;)
.timeout(150)
.end((err, res) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
&#x27;number&#x27;,
typeof err.timeout,
&#x27;expected an error with .timeout&#x27;
);
assert.equal(&#x27;ECONNABORTED&#x27;, err.code, &#x27;expected abort error code&#x27;);
done();
});</code></pre></dd>
<dt>should handle buffer timeout</dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/json&#x60;)
.buffer(true)
.timeout(150)
.end((err, res) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
&#x27;number&#x27;,
typeof err.timeout,
&#x27;expected an error with .timeout&#x27;
);
assert.equal(&#x27;ECONNABORTED&#x27;, err.code, &#x27;expected abort error code&#x27;);
done();
});</code></pre></dd>
<dt>should error on deadline</dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/500&#x60;)
.timeout({ deadline: 150 })
.end((err, res) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
&#x27;number&#x27;,
typeof err.timeout,
&#x27;expected an error with .timeout&#x27;
);
assert.equal(&#x27;ECONNABORTED&#x27;, err.code, &#x27;expected abort error code&#x27;);
done();
});</code></pre></dd>
<dt>should support setting individual options</dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/500&#x60;)
.timeout({ deadline: 10 })
.timeout({ response: 99999 })
.end((err, res) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
assert.equal(&#x27;ECONNABORTED&#x27;, err.code, &#x27;expected abort error code&#x27;);
assert.equal(&#x27;ETIME&#x27;, err.errno);
done();
});</code></pre></dd>
<dt>should error on response</dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/500&#x60;)
.timeout({ response: 150 })
.end((err, res) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
assert.equal(
&#x27;number&#x27;,
typeof err.timeout,
&#x27;expected an error with .timeout&#x27;
);
assert.equal(&#x27;ECONNABORTED&#x27;, err.code, &#x27;expected abort error code&#x27;);
assert.equal(&#x27;ETIMEDOUT&#x27;, err.errno);
done();
});</code></pre></dd>
<dt>should accept slow body with fast response</dt>
<dd><pre><code>request
.get(&#x60;${base}/delay/slowbody&#x60;)
.timeout({ response: 1000 })
.on(&#x27;progress&#x27;, () =&#x3E; {
// This only makes the test faster without relying on arbitrary timeouts
request.get(&#x60;${base}/delay/slowbody/finish&#x60;).end();
})
.end(done);</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>request</h1>
<dl>
<section class="suite">
<h1>use</h1>
<dl>
<dt>should use plugin success</dt>
<dd><pre><code>const now = &#x60;${Date.now()}&#x60;;
function uuid(req) {
req.set(&#x27;X-UUID&#x27;, now);
return req;
}
function prefix(req) {
req.url = uri + req.url;
return req;
}
request
.get(&#x27;/echo&#x27;)
.use(uuid)
.use(prefix)
.end((err, res) =&#x3E; {
assert.strictEqual(res.statusCode, 200);
assert.equal(res.get(&#x27;X-UUID&#x27;), now);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>subclass</h1>
<dl>
<dt>should be an instance of Request</dt>
<dd><pre><code>const req = request.get(&#x27;/&#x27;);
assert(req instanceof request.Request);</code></pre></dd>
<dt>should use patched subclass</dt>
<dd><pre><code>assert(OriginalRequest);
let constructorCalled;
let sendCalled;
function NewRequest(...args) {
constructorCalled = true;
OriginalRequest.apply(this, args);
}
NewRequest.prototype = Object.create(OriginalRequest.prototype);
NewRequest.prototype.send = function () {
sendCalled = true;
return this;
};
request.Request = NewRequest;
const req = request.get(&#x27;/&#x27;).send();
assert(constructorCalled);
assert(sendCalled);
assert(req instanceof NewRequest);
assert(req instanceof OriginalRequest);</code></pre></dd>
<dt>should use patched subclass in agent too</dt>
<dd><pre><code>if (!request.agent) return; // Node-only
function NewRequest(...args) {
OriginalRequest.apply(this, args);
}
NewRequest.prototype = Object.create(OriginalRequest.prototype);
request.Request = NewRequest;
const req = request.agent().del(&#x27;/&#x27;);
assert(req instanceof NewRequest);
assert(req instanceof OriginalRequest);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>request</h1>
<dl>
<section class="suite">
<h1>persistent agent</h1>
<dl>
<dt>should gain a session on POST</dt>
<dd><pre><code>agent3.post(&#x60;${base}/signin&#x60;).then((res) =&#x3E; {
res.should.have.status(200);
should.not.exist(res.headers[&#x27;set-cookie&#x27;]);
res.text.should.containEql(&#x27;dashboard&#x27;);
})</code></pre></dd>
<dt>should start with empty session (set cookies)</dt>
<dd><pre><code>agent1.get(&#x60;${base}/dashboard&#x60;).end((err, res) =&#x3E; {
should.exist(err);
res.should.have.status(401);
should.exist(res.headers[&#x27;set-cookie&#x27;]);
done();
});</code></pre></dd>
<dt>should gain a session (cookies already set)</dt>
<dd><pre><code>agent1.post(&#x60;${base}/signin&#x60;).then((res) =&#x3E; {
res.should.have.status(200);
should.not.exist(res.headers[&#x27;set-cookie&#x27;]);
res.text.should.containEql(&#x27;dashboard&#x27;);
})</code></pre></dd>
<dt>should persist cookies across requests</dt>
<dd><pre><code>agent1.get(&#x60;${base}/dashboard&#x60;).then((res) =&#x3E; {
res.should.have.status(200);
})</code></pre></dd>
<dt>should have the cookie set in the end callback</dt>
<dd><pre><code>agent4
.post(&#x60;${base}/setcookie&#x60;)
.then(() =&#x3E; agent4.get(&#x60;${base}/getcookie&#x60;))
.then((res) =&#x3E; {
res.should.have.status(200);
assert.strictEqual(res.text, &#x27;jar&#x27;);
})</code></pre></dd>
<dt>should not share cookies</dt>
<dd><pre><code>agent2.get(&#x60;${base}/dashboard&#x60;).end((err, res) =&#x3E; {
should.exist(err);
res.should.have.status(401);
done();
});</code></pre></dd>
<dt>should not lose cookies between agents</dt>
<dd><pre><code>agent1.get(&#x60;${base}/dashboard&#x60;).then((res) =&#x3E; {
res.should.have.status(200);
})</code></pre></dd>
<dt>should be able to follow redirects</dt>
<dd><pre><code>agent1.get(base).then((res) =&#x3E; {
res.should.have.status(200);
res.text.should.containEql(&#x27;dashboard&#x27;);
})</code></pre></dd>
<dt>should be able to post redirects</dt>
<dd><pre><code>agent1
.post(&#x60;${base}/redirect&#x60;)
.send({ foo: &#x27;bar&#x27;, baz: &#x27;blaaah&#x27; })
.then((res) =&#x3E; {
res.should.have.status(200);
res.text.should.containEql(&#x27;simple&#x27;);
res.redirects.should.eql([&#x60;${base}/simple&#x60;]);
})</code></pre></dd>
<dt>should be able to limit redirects</dt>
<dd><pre><code>agent1
.get(base)
.redirects(0)
.end((err, res) =&#x3E; {
should.exist(err);
res.should.have.status(302);
res.redirects.should.eql([]);
res.header.location.should.equal(&#x27;/dashboard&#x27;);
done();
});</code></pre></dd>
<dt>should be able to create a new session (clear cookie)</dt>
<dd><pre><code>agent1.post(&#x60;${base}/signout&#x60;).then((res) =&#x3E; {
res.should.have.status(200);
should.exist(res.headers[&#x27;set-cookie&#x27;]);
})</code></pre></dd>
<dt>should regenerate with an empty session</dt>
<dd><pre><code>agent1.get(&#x60;${base}/dashboard&#x60;).end((err, res) =&#x3E; {
should.exist(err);
res.should.have.status(401);
should.not.exist(res.headers[&#x27;set-cookie&#x27;]);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>Basic auth</h1>
<dl>
<section class="suite">
<h1>when credentials are present in url</h1>
<dl>
<dt>should set Authorization</dt>
<dd><pre><code>const new_url = URL.parse(base);
new_url.auth = &#x27;tobi:learnboost&#x27;;
new_url.pathname = &#x27;/basic-auth&#x27;;
request.get(URL.format(new_url)).end((err, res) =&#x3E; {
res.status.should.equal(200);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.auth(user, pass)</h1>
<dl>
<dt>should set Authorization</dt>
<dd><pre><code>request
.get(&#x60;${base}/basic-auth&#x60;)
.auth(&#x27;tobi&#x27;, &#x27;learnboost&#x27;)
.end((err, res) =&#x3E; {
res.status.should.equal(200);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.auth(user + &#x22;:&#x22; + pass)</h1>
<dl>
<dt>should set authorization</dt>
<dd><pre><code>request
.get(&#x60;${base}/basic-auth/again&#x60;)
.auth(&#x27;tobi&#x27;)
.end((err, res) =&#x3E; {
res.status.should.eql(200);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>[node] request</h1>
<dl>
<dt>should send body with .get().send()</dt>
<dd><pre><code>request
.get(&#x60;${base}/echo&#x60;)
.set(&#x27;Content-Type&#x27;, &#x27;text/plain&#x27;)
.send(&#x27;wahoo&#x27;)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;wahoo&#x27;, res.text);
next();
} catch (err_) {
next(err_);
}
});</code></pre></dd>
<section class="suite">
<h1>with an url</h1>
<dl>
<dt>should preserve the encoding of the url</dt>
<dd><pre><code>request.get(&#x60;${base}/url?a=(b%29&#x60;).end((err, res) =&#x3E; {
assert.equal(&#x27;/url?a=(b%29&#x27;, res.text);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with an object</h1>
<dl>
<dt>should format the url</dt>
<dd><pre><code>request.get(url.parse(&#x60;${base}/login&#x60;)).then((res) =&#x3E; {
assert(res.ok);
})</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>without a schema</h1>
<dl>
<dt>should default to http</dt>
<dd><pre><code>request.get(&#x27;localhost:5000/login&#x27;).then((res) =&#x3E; {
assert.equal(res.status, 200);
})</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.toJSON()</h1>
<dl>
<dt>should describe the response</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.send({ foo: &#x27;baz&#x27; })
.then((res) =&#x3E; {
const obj = res.toJSON();
assert.equal(&#x27;object&#x27;, typeof obj.header);
assert.equal(&#x27;object&#x27;, typeof obj.req);
assert.equal(200, obj.status);
assert.equal(&#x27;{&#x22;foo&#x22;:&#x22;baz&#x22;}&#x27;, obj.text);
})</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.links</h1>
<dl>
<dt>should default to an empty object</dt>
<dd><pre><code>request.get(&#x60;${base}/login&#x60;).then((res) =&#x3E; {
res.links.should.eql({});
})</code></pre></dd>
<dt>should parse the Link header field</dt>
<dd><pre><code>request.get(&#x60;${base}/links&#x60;).end((err, res) =&#x3E; {
res.links.next.should.equal(
&#x27;https://api.github.com/repos/visionmedia/mocha/issues?page=2&#x27;
);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.unset(field)</h1>
<dl>
<dt>should remove the header field</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.unset(&#x27;User-Agent&#x27;)
.end((err, res) =&#x3E; {
assert.equal(void 0, res.header[&#x27;user-agent&#x27;]);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>case-insensitive</h1>
<dl>
<dt>should set/get header fields case-insensitively</dt>
<dd><pre><code>const r = request.post(&#x60;${base}/echo&#x60;);
r.set(&#x27;MiXeD&#x27;, &#x27;helloes&#x27;);
assert.strictEqual(r.get(&#x27;mixed&#x27;), &#x27;helloes&#x27;);</code></pre></dd>
<dt>should unset header fields case-insensitively</dt>
<dd><pre><code>const r = request.post(&#x60;${base}/echo&#x60;);
r.set(&#x27;MiXeD&#x27;, &#x27;helloes&#x27;);
r.unset(&#x27;MIXED&#x27;);
assert.strictEqual(r.get(&#x27;mixed&#x27;), undefined);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.write(str)</h1>
<dl>
<dt>should write the given data</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/echo&#x60;);
req.set(&#x27;Content-Type&#x27;, &#x27;application/json&#x27;);
assert.equal(&#x27;boolean&#x27;, typeof req.write(&#x27;{&#x22;name&#x22;&#x27;));
assert.equal(&#x27;boolean&#x27;, typeof req.write(&#x27;:&#x22;tobi&#x22;}&#x27;));
req.end((err, res) =&#x3E; {
res.text.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.pipe(stream)</h1>
<dl>
<dt>should pipe the response to the given stream</dt>
<dd><pre><code>const stream = new EventEmitter();
stream.buf = &#x27;&#x27;;
stream.writable = true;
stream.write = function (chunk) {
this.buf += chunk;
};
stream.end = function () {
this.buf.should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
done();
};
request.post(&#x60;${base}/echo&#x60;).send(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;).pipe(stream);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.buffer()</h1>
<dl>
<dt>should enable buffering</dt>
<dd><pre><code>request
.get(&#x60;${base}/custom&#x60;)
.buffer()
.end((err, res) =&#x3E; {
assert.ifError(err);
assert.equal(&#x27;custom stuff&#x27;, res.text);
assert(res.buffered);
done();
});</code></pre></dd>
<dt>should take precedence over request.buffer[&#x27;someMimeType&#x27;] = false</dt>
<dd><pre><code>const type = &#x27;application/barbaz&#x27;;
const send = &#x27;some text&#x27;;
request.buffer[type] = false;
request
.post(&#x60;${base}/echo&#x60;)
.type(type)
.send(send)
.buffer()
.end((err, res) =&#x3E; {
delete request.buffer[type];
assert.ifError(err);
assert.equal(res.type, type);
assert.equal(send, res.text);
assert(res.buffered);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.buffer(false)</h1>
<dl>
<dt>should disable buffering</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.type(&#x27;application/x-dog&#x27;)
.send(&#x27;hello this is dog&#x27;)
.buffer(false)
.end((err, res) =&#x3E; {
assert.ifError(err);
assert.equal(null, res.text);
res.body.should.eql({});
let buf = &#x27;&#x27;;
res.setEncoding(&#x27;utf8&#x27;);
res.on(&#x27;data&#x27;, (chunk) =&#x3E; {
buf += chunk;
});
res.on(&#x27;end&#x27;, () =&#x3E; {
buf.should.equal(&#x27;hello this is dog&#x27;);
done();
});
});</code></pre></dd>
<dt>should take precedence over request.buffer[&#x27;someMimeType&#x27;] = true</dt>
<dd><pre><code>const type = &#x27;application/foobar&#x27;;
const send = &#x27;hello this is a dog&#x27;;
request.buffer[type] = true;
request
.post(&#x60;${base}/echo&#x60;)
.type(type)
.send(send)
.buffer(false)
.end((err, res) =&#x3E; {
delete request.buffer[type];
assert.ifError(err);
assert.equal(null, res.text);
assert.equal(res.type, type);
assert(!res.buffered);
res.body.should.eql({});
let buf = &#x27;&#x27;;
res.setEncoding(&#x27;utf8&#x27;);
res.on(&#x27;data&#x27;, (chunk) =&#x3E; {
buf += chunk;
});
res.on(&#x27;end&#x27;, () =&#x3E; {
buf.should.equal(send);
done();
});
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.withCredentials()</h1>
<dl>
<dt>should not throw an error when using the client-side &#x22;withCredentials&#x22; method</dt>
<dd><pre><code>request
.get(&#x60;${base}/custom&#x60;)
.withCredentials()
.end((err, res) =&#x3E; {
assert.ifError(err);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.agent()</h1>
<dl>
<dt>should return the defaut agent</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/echo&#x60;);
req.agent().should.equal(false);
done();</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.agent(undefined)</h1>
<dl>
<dt>should set an agent to undefined and ensure it is chainable</dt>
<dd><pre><code>const req = request.get(&#x60;${base}/echo&#x60;);
const ret = req.agent(undefined);
ret.should.equal(req);
assert.strictEqual(req.agent(), undefined);
done();</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.agent(new http.Agent())</h1>
<dl>
<dt>should set passed agent</dt>
<dd><pre><code>const http = require(&#x27;http&#x27;);
const req = request.get(&#x60;${base}/echo&#x60;);
const agent = new http.Agent();
const ret = req.agent(agent);
ret.should.equal(req);
req.agent().should.equal(agent);
done();</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with a content type other than application/json or text/*</h1>
<dl>
<dt>should still use buffering</dt>
<dd><pre><code>return request
.post(&#x60;${base}/echo&#x60;)
.type(&#x27;application/x-dog&#x27;)
.send(&#x27;hello this is dog&#x27;)
.then((res) =&#x3E; {
assert.equal(null, res.text);
assert.equal(res.body.toString(), &#x27;hello this is dog&#x27;);
res.buffered.should.be.true;
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>content-length</h1>
<dl>
<dt>should be set to the byte length of a non-buffer object</dt>
<dd><pre><code>const decoder = new StringDecoder(&#x27;utf8&#x27;);
let img = fs.readFileSync(&#x60;${__dirname}/fixtures/test.png&#x60;);
img = decoder.write(img);
request
.post(&#x60;${base}/echo&#x60;)
.type(&#x27;application/x-image&#x27;)
.send(img)
.buffer(false)
.end((err, res) =&#x3E; {
assert.ifError(err);
assert(!res.buffered);
assert.equal(res.header[&#x27;content-length&#x27;], Buffer.byteLength(img));
done();
});</code></pre></dd>
<dt>should be set to the length of a buffer object</dt>
<dd><pre><code>const img = fs.readFileSync(&#x60;${__dirname}/fixtures/test.png&#x60;);
request
.post(&#x60;${base}/echo&#x60;)
.type(&#x27;application/x-image&#x27;)
.send(img)
.buffer(true)
.end((err, res) =&#x3E; {
assert.ifError(err);
assert(res.buffered);
assert.equal(res.header[&#x27;content-length&#x27;], img.length);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>req.buffer[&#x27;someMimeType&#x27;]</h1>
<dl>
<dt>should respect that agent.buffer(true) takes precedent</dt>
<dd><pre><code>const agent = request.agent();
agent.buffer(true);
const type = &#x27;application/somerandomtype&#x27;;
const send = &#x27;somerandomtext&#x27;;
request.buffer[type] = false;
agent
.post(&#x60;${base}/echo&#x60;)
.type(type)
.send(send)
.end((err, res) =&#x3E; {
delete request.buffer[type];
assert.ifError(err);
assert.equal(res.type, type);
assert.equal(send, res.text);
assert(res.buffered);
done();
});</code></pre></dd>
<dt>should respect that agent.buffer(false) takes precedent</dt>
<dd><pre><code>const agent = request.agent();
agent.buffer(false);
const type = &#x27;application/barrr&#x27;;
const send = &#x27;some random text2&#x27;;
request.buffer[type] = true;
agent
.post(&#x60;${base}/echo&#x60;)
.type(type)
.send(send)
.end((err, res) =&#x3E; {
delete request.buffer[type];
assert.ifError(err);
assert.equal(null, res.text);
assert.equal(res.type, type);
assert(!res.buffered);
res.body.should.eql({});
let buf = &#x27;&#x27;;
res.setEncoding(&#x27;utf8&#x27;);
res.on(&#x27;data&#x27;, (chunk) =&#x3E; {
buf += chunk;
});
res.on(&#x27;end&#x27;, () =&#x3E; {
buf.should.equal(send);
done();
});
});</code></pre></dd>
<dt>should disable buffering for that mimetype when false</dt>
<dd><pre><code>const type = &#x27;application/bar&#x27;;
const send = &#x27;some random text&#x27;;
request.buffer[type] = false;
request
.post(&#x60;${base}/echo&#x60;)
.type(type)
.send(send)
.end((err, res) =&#x3E; {
delete request.buffer[type];
assert.ifError(err);
assert.equal(null, res.text);
assert.equal(res.type, type);
assert(!res.buffered);
res.body.should.eql({});
let buf = &#x27;&#x27;;
res.setEncoding(&#x27;utf8&#x27;);
res.on(&#x27;data&#x27;, (chunk) =&#x3E; {
buf += chunk;
});
res.on(&#x27;end&#x27;, () =&#x3E; {
buf.should.equal(send);
done();
});
});</code></pre></dd>
<dt>should enable buffering for that mimetype when true</dt>
<dd><pre><code>const type = &#x27;application/baz&#x27;;
const send = &#x27;woooo&#x27;;
request.buffer[type] = true;
request
.post(&#x60;${base}/echo&#x60;)
.type(type)
.send(send)
.end((err, res) =&#x3E; {
delete request.buffer[type];
assert.ifError(err);
assert.equal(res.type, type);
assert.equal(send, res.text);
assert(res.buffered);
done();
});</code></pre></dd>
<dt>should fallback to default handling for that mimetype when undefined</dt>
<dd><pre><code>const type = &#x27;application/bazzz&#x27;;
const send = &#x27;woooooo&#x27;;
return request
.post(&#x60;${base}/echo&#x60;)
.type(type)
.send(send)
.then((res) =&#x3E; {
assert.equal(res.type, type);
assert.equal(send, res.body.toString());
assert(res.buffered);
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>exports</h1>
<dl>
<dt>should expose .protocols</dt>
<dd><pre><code>Object.keys(request.protocols).should.eql([&#x27;http:&#x27;, &#x27;https:&#x27;, &#x27;http2:&#x27;]);</code></pre></dd>
<dt>should expose .serialize</dt>
<dd><pre><code>Object.keys(request.serialize).should.eql([
&#x27;application/x-www-form-urlencoded&#x27;,
&#x27;application/json&#x27;
]);</code></pre></dd>
<dt>should expose .parse</dt>
<dd><pre><code>Object.keys(request.parse).should.eql([
&#x27;application/x-www-form-urlencoded&#x27;,
&#x27;application/json&#x27;,
&#x27;text&#x27;,
&#x27;application/octet-stream&#x27;,
&#x27;application/pdf&#x27;,
&#x27;image&#x27;
]);</code></pre></dd>
<dt>should export .buffer</dt>
<dd><pre><code>Object.keys(request.buffer).should.eql([]);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>flags</h1>
<dl>
<section class="suite">
<h1>with 4xx response</h1>
<dl>
<dt>should set res.error and res.clientError</dt>
<dd><pre><code>request.get(&#x60;${base}/notfound&#x60;).end((err, res) =&#x3E; {
assert(err);
assert(!res.ok, &#x27;response should not be ok&#x27;);
assert(res.error, &#x27;response should be an error&#x27;);
assert(res.clientError, &#x27;response should be a client error&#x27;);
assert(!res.serverError, &#x27;response should not be a server error&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with 5xx response</h1>
<dl>
<dt>should set res.error and res.serverError</dt>
<dd><pre><code>request.get(&#x60;${base}/error&#x60;).end((err, res) =&#x3E; {
assert(err);
assert(!res.ok, &#x27;response should not be ok&#x27;);
assert(!res.notFound, &#x27;response should not be notFound&#x27;);
assert(res.error, &#x27;response should be an error&#x27;);
assert(!res.clientError, &#x27;response should not be a client error&#x27;);
assert(res.serverError, &#x27;response should be a server error&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with 404 Not Found</h1>
<dl>
<dt>should res.notFound</dt>
<dd><pre><code>request.get(&#x60;${base}/notfound&#x60;).end((err, res) =&#x3E; {
assert(err);
assert(res.notFound, &#x27;response should be .notFound&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with 400 Bad Request</h1>
<dl>
<dt>should set req.badRequest</dt>
<dd><pre><code>request.get(&#x60;${base}/bad-request&#x60;).end((err, res) =&#x3E; {
assert(err);
assert(res.badRequest, &#x27;response should be .badRequest&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with 401 Bad Request</h1>
<dl>
<dt>should set res.unauthorized</dt>
<dd><pre><code>request.get(&#x60;${base}/unauthorized&#x60;).end((err, res) =&#x3E; {
assert(err);
assert(res.unauthorized, &#x27;response should be .unauthorized&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with 406 Not Acceptable</h1>
<dl>
<dt>should set res.notAcceptable</dt>
<dd><pre><code>request.get(&#x60;${base}/not-acceptable&#x60;).end((err, res) =&#x3E; {
assert(err);
assert(res.notAcceptable, &#x27;response should be .notAcceptable&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with 204 No Content</h1>
<dl>
<dt>should set res.noContent</dt>
<dd><pre><code>request.get(&#x60;${base}/no-content&#x60;).end((err, res) =&#x3E; {
assert(!err);
assert(res.noContent, &#x27;response should be .noContent&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with 201 Created</h1>
<dl>
<dt>should set res.created</dt>
<dd><pre><code>request.post(&#x60;${base}/created&#x60;).end((err, res) =&#x3E; {
assert(!err);
assert(res.created, &#x27;response should be .created&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>with 422 Unprocessable Entity</h1>
<dl>
<dt>should set res.unprocessableEntity</dt>
<dd><pre><code>request.post(&#x60;${base}/unprocessable-entity&#x60;).end((err, res) =&#x3E; {
assert(err);
assert(
res.unprocessableEntity,
&#x27;response should be .unprocessableEntity&#x27;
);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>Merging objects</h1>
<dl>
<dt>Don&#x27;t mix Buffer and JSON</dt>
<dd><pre><code>assert.throws(() =&#x3E; {
request
.post(&#x27;/echo&#x27;)
.send(Buffer.from(&#x27;some buffer&#x27;))
.send({ allowed: false });
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.send(String)</h1>
<dl>
<dt>should default to &#x22;form&#x22;</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.send(&#x27;user[name]=tj&#x27;)
.send(&#x27;user[email]=tj@vision-media.ca&#x27;)
.end((err, res) =&#x3E; {
res.header[&#x27;content-type&#x27;].should.equal(
&#x27;application/x-www-form-urlencoded&#x27;
);
res.body.should.eql({
user: { name: &#x27;tj&#x27;, email: &#x27;tj@vision-media.ca&#x27; }
});
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.body</h1>
<dl>
<section class="suite">
<h1>application/x-www-form-urlencoded</h1>
<dl>
<dt>should parse the body</dt>
<dd><pre><code>request.get(&#x60;${base}/form-data&#x60;).end((err, res) =&#x3E; {
res.text.should.equal(&#x27;pet[name]=manny&#x27;);
res.body.should.eql({ pet: { name: &#x27;manny&#x27; } });
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>https</h1>
<dl>
<section class="suite">
<h1>certificate authority</h1>
<dl>
<section class="suite">
<h1>request</h1>
<dl>
<dt>should give a good response</dt>
<dd><pre><code>request
.get(testEndpoint)
.ca(ca)
.end((err, res) =&#x3E; {
assert.ifError(err);
assert(res.ok);
assert.strictEqual(&#x27;Safe and secure!&#x27;, res.text);
done();
});</code></pre></dd>
<dt>should reject unauthorized response</dt>
<dd><pre><code>return request
.get(testEndpoint)
.trustLocalhost(false)
.then(
() =&#x3E; {
throw new Error(&#x27;Allows MITM&#x27;);
},
() =&#x3E; {}
);</code></pre></dd>
<dt>should not reject unauthorized response</dt>
<dd><pre><code>return request
.get(testEndpoint)
.disableTLSCerts()
.then(({ status }) =&#x3E; {
assert.strictEqual(status, 200);
});</code></pre></dd>
<dt>should trust localhost unauthorized response</dt>
<dd><pre><code>return request.get(testEndpoint).trustLocalhost(true);</code></pre></dd>
<dt>should trust overriden localhost unauthorized response</dt>
<dd><pre><code>return request
.get(&#x60;https://example.com:${server.address().port}&#x60;)
.connect(&#x27;127.0.0.1&#x27;)
.trustLocalhost();</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>.agent</h1>
<dl>
<dt>should be able to make multiple requests without redefining the certificate</dt>
<dd><pre><code>const agent = request.agent({ ca });
agent.get(testEndpoint).end((err, res) =&#x3E; {
assert.ifError(err);
assert(res.ok);
assert.strictEqual(&#x27;Safe and secure!&#x27;, res.text);
agent.get(url.parse(testEndpoint)).end((err, res) =&#x3E; {
assert.ifError(err);
assert(res.ok);
assert.strictEqual(&#x27;Safe and secure!&#x27;, res.text);
done();
});
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>client certificates</h1>
<dl>
<section class="suite">
<h1>request</h1>
<dl>
</dl>
</section>
<section class="suite">
<h1>.agent</h1>
<dl>
</dl>
</section>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>res.body</h1>
<dl>
<section class="suite">
<h1>image/png</h1>
<dl>
<dt>should parse the body</dt>
<dd><pre><code>request.get(&#x60;${base}/image&#x60;).end((err, res) =&#x3E; {
res.type.should.equal(&#x27;image/png&#x27;);
Buffer.isBuffer(res.body).should.be.true();
(res.body.length - img.length).should.equal(0);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>application/octet-stream</h1>
<dl>
<dt>should parse the body</dt>
<dd><pre><code>request
.get(&#x60;${base}/image-as-octets&#x60;)
.buffer(true) // that&#x27;s tech debt :(
.end((err, res) =&#x3E; {
res.type.should.equal(&#x27;application/octet-stream&#x27;);
Buffer.isBuffer(res.body).should.be.true();
(res.body.length - img.length).should.equal(0);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>application/octet-stream</h1>
<dl>
<dt>should parse the body (using responseType)</dt>
<dd><pre><code>request
.get(&#x60;${base}/image-as-octets&#x60;)
.responseType(&#x27;blob&#x27;)
.end((err, res) =&#x3E; {
res.type.should.equal(&#x27;application/octet-stream&#x27;);
Buffer.isBuffer(res.body).should.be.true();
(res.body.length - img.length).should.equal(0);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>zlib</h1>
<dl>
<dt>should deflate the content</dt>
<dd><pre><code>request.get(base).end((err, res) =&#x3E; {
res.should.have.status(200);
res.text.should.equal(subject);
res.headers[&#x27;content-length&#x27;].should.be.below(subject.length);
done();
});</code></pre></dd>
<dt>should protect from zip bombs</dt>
<dd><pre><code>request
.get(base)
.buffer(true)
.maxResponseSize(1)
.end((err, res) =&#x3E; {
try {
assert.equal(&#x27;Maximum response size reached&#x27;, err &#x26;&#x26; err.message);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should ignore trailing junk</dt>
<dd><pre><code>request.get(&#x60;${base}/junk&#x60;).end((err, res) =&#x3E; {
res.should.have.status(200);
res.text.should.equal(subject);
done();
});</code></pre></dd>
<dt>should ignore missing data</dt>
<dd><pre><code>request.get(&#x60;${base}/chopped&#x60;).end((err, res) =&#x3E; {
assert.equal(undefined, err);
res.should.have.status(200);
res.text.should.startWith(subject);
done();
});</code></pre></dd>
<dt>should handle corrupted responses</dt>
<dd><pre><code>request.get(&#x60;${base}/corrupt&#x60;).end((err, res) =&#x3E; {
assert(err, &#x27;missing error&#x27;);
assert(!res, &#x27;response should not be defined&#x27;);
done();
});</code></pre></dd>
<dt>should handle no content with gzip header</dt>
<dd><pre><code>request.get(&#x60;${base}/nocontent&#x60;).end((err, res) =&#x3E; {
assert.ifError(err);
assert(res);
res.should.have.status(204);
res.text.should.equal(&#x27;&#x27;);
res.headers.should.not.have.property(&#x27;content-length&#x27;);
done();
});</code></pre></dd>
<section class="suite">
<h1>without encoding set</h1>
<dl>
<dt>should buffer if asked</dt>
<dd><pre><code>return request
.get(&#x60;${base}/binary&#x60;)
.buffer(true)
.then((res) =&#x3E; {
res.should.have.status(200);
assert(res.headers[&#x27;content-length&#x27;]);
assert(res.body.byteLength);
assert.equal(subject, res.body.toString());
});</code></pre></dd>
<dt>should emit buffers</dt>
<dd><pre><code>request.get(&#x60;${base}/binary&#x60;).end((err, res) =&#x3E; {
res.should.have.status(200);
res.headers[&#x27;content-length&#x27;].should.be.below(subject.length);
res.on(&#x27;data&#x27;, (chunk) =&#x3E; {
chunk.should.have.length(subject.length);
});
res.on(&#x27;end&#x27;, done);
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>Multipart</h1>
<dl>
<section class="suite">
<h1>#field(name, value)</h1>
<dl>
<dt>should set a multipart field value</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/echo&#x60;);
req.field(&#x27;user[name]&#x27;, &#x27;tobi&#x27;);
req.field(&#x27;user[age]&#x27;, &#x27;2&#x27;);
req.field(&#x27;user[species]&#x27;, &#x27;ferret&#x27;);
return req.then((res) =&#x3E; {
res.body[&#x27;user[name]&#x27;].should.equal(&#x27;tobi&#x27;);
res.body[&#x27;user[age]&#x27;].should.equal(&#x27;2&#x27;);
res.body[&#x27;user[species]&#x27;].should.equal(&#x27;ferret&#x27;);
});</code></pre></dd>
<dt>should work with file attachments</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/echo&#x60;);
req.field(&#x27;name&#x27;, &#x27;Tobi&#x27;);
req.attach(&#x27;document&#x27;, &#x27;test/node/fixtures/user.html&#x27;);
req.field(&#x27;species&#x27;, &#x27;ferret&#x27;);
return req.then((res) =&#x3E; {
res.body.name.should.equal(&#x27;Tobi&#x27;);
res.body.species.should.equal(&#x27;ferret&#x27;);
const html = res.files.document;
html.name.should.equal(&#x27;user.html&#x27;);
html.type.should.equal(&#x27;text/html&#x27;);
read(html.path).should.equal(&#x27;&#x3C;h1&#x3E;name&#x3C;/h1&#x3E;&#x27;);
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>#attach(name, path)</h1>
<dl>
<dt>should attach a file</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/echo&#x60;);
req.attach(&#x27;one&#x27;, &#x27;test/node/fixtures/user.html&#x27;);
req.attach(&#x27;two&#x27;, &#x27;test/node/fixtures/user.json&#x27;);
req.attach(&#x27;three&#x27;, &#x27;test/node/fixtures/user.txt&#x27;);
return req.then((res) =&#x3E; {
const html = res.files.one;
const json = res.files.two;
const text = res.files.three;
html.name.should.equal(&#x27;user.html&#x27;);
html.type.should.equal(&#x27;text/html&#x27;);
read(html.path).should.equal(&#x27;&#x3C;h1&#x3E;name&#x3C;/h1&#x3E;&#x27;);
json.name.should.equal(&#x27;user.json&#x27;);
json.type.should.equal(&#x27;application/json&#x27;);
read(json.path).should.equal(&#x27;{&#x22;name&#x22;:&#x22;tobi&#x22;}&#x27;);
text.name.should.equal(&#x27;user.txt&#x27;);
text.type.should.equal(&#x27;text/plain&#x27;);
read(text.path).should.equal(&#x27;Tobi&#x27;);
});</code></pre></dd>
<section class="suite">
<h1>when a file does not exist</h1>
<dl>
<dt>should fail the request with an error</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/echo&#x60;);
req.attach(&#x27;name&#x27;, &#x27;foo&#x27;);
req.attach(&#x27;name2&#x27;, &#x27;bar&#x27;);
req.attach(&#x27;name3&#x27;, &#x27;baz&#x27;);
req.end((err, res) =&#x3E; {
assert.ok(Boolean(err), &#x27;Request should have failed.&#x27;);
err.code.should.equal(&#x27;ENOENT&#x27;);
err.message.should.containEql(&#x27;ENOENT&#x27;);
err.path.should.equal(&#x27;foo&#x27;);
done();
});</code></pre></dd>
<dt>promise should fail</dt>
<dd><pre><code>return request
.post(&#x60;${base}/echo&#x60;)
.field({ a: 1, b: 2 })
.attach(&#x27;c&#x27;, &#x27;does-not-exist.txt&#x27;)
.then(
(res) =&#x3E; assert.fail(&#x27;It should not allow this&#x27;),
(err) =&#x3E; {
err.code.should.equal(&#x27;ENOENT&#x27;);
err.path.should.equal(&#x27;does-not-exist.txt&#x27;);
}
);</code></pre></dd>
<dt>should report ECONNREFUSED via the callback</dt>
<dd><pre><code>request
.post(&#x27;http://127.0.0.1:1&#x27;) // nobody is listening there
.attach(&#x27;name&#x27;, &#x27;file-does-not-exist&#x27;)
.end((err, res) =&#x3E; {
assert.ok(Boolean(err), &#x27;Request should have failed&#x27;);
err.code.should.equal(&#x27;ECONNREFUSED&#x27;);
done();
});</code></pre></dd>
<dt>should report ECONNREFUSED via Promise</dt>
<dd><pre><code>return request
.post(&#x27;http://127.0.0.1:1&#x27;) // nobody is listening there
.attach(&#x27;name&#x27;, &#x27;file-does-not-exist&#x27;)
.then(
(res) =&#x3E; assert.fail(&#x27;Request should have failed&#x27;),
(err) =&#x3E; err.code.should.equal(&#x27;ECONNREFUSED&#x27;)
);</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>#attach(name, path, filename)</h1>
<dl>
<dt>should use the custom filename</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.attach(&#x27;document&#x27;, &#x27;test/node/fixtures/user.html&#x27;, &#x27;doc.html&#x27;)
.then((res) =&#x3E; {
const html = res.files.document;
html.name.should.equal(&#x27;doc.html&#x27;);
html.type.should.equal(&#x27;text/html&#x27;);
read(html.path).should.equal(&#x27;&#x3C;h1&#x3E;name&#x3C;/h1&#x3E;&#x27;);
})</code></pre></dd>
<dt>should fire progress event</dt>
<dd><pre><code>let loaded = 0;
let total = 0;
let uploadEventWasFired = false;
request
.post(&#x60;${base}/echo&#x60;)
.attach(&#x27;document&#x27;, &#x27;test/node/fixtures/user.html&#x27;)
.on(&#x27;progress&#x27;, (event) =&#x3E; {
total = event.total;
loaded = event.loaded;
if (event.direction === &#x27;upload&#x27;) {
uploadEventWasFired = true;
}
})
.end((err, res) =&#x3E; {
if (err) return done(err);
const html = res.files.document;
html.name.should.equal(&#x27;user.html&#x27;);
html.type.should.equal(&#x27;text/html&#x27;);
read(html.path).should.equal(&#x27;&#x3C;h1&#x3E;name&#x3C;/h1&#x3E;&#x27;);
total.should.equal(223);
loaded.should.equal(223);
uploadEventWasFired.should.equal(true);
done();
});</code></pre></dd>
<dt>filesystem errors should be caught</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.attach(&#x27;filedata&#x27;, &#x27;test/node/fixtures/non-existent-file.ext&#x27;)
.end((err, res) =&#x3E; {
assert.ok(Boolean(err), &#x27;Request should have failed.&#x27;);
err.code.should.equal(&#x27;ENOENT&#x27;);
err.path.should.equal(&#x27;test/node/fixtures/non-existent-file.ext&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>#field(name, val)</h1>
<dl>
<dt>should set a multipart field value</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.field(&#x27;first-name&#x27;, &#x27;foo&#x27;)
.field(&#x27;last-name&#x27;, &#x27;bar&#x27;)
.end((err, res) =&#x3E; {
if (err) done(err);
res.should.be.ok();
res.body[&#x27;first-name&#x27;].should.equal(&#x27;foo&#x27;);
res.body[&#x27;last-name&#x27;].should.equal(&#x27;bar&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>#field(object)</h1>
<dl>
<dt>should set multiple multipart fields</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.field({ &#x27;first-name&#x27;: &#x27;foo&#x27;, &#x27;last-name&#x27;: &#x27;bar&#x27; })
.end((err, res) =&#x3E; {
if (err) done(err);
res.should.be.ok();
res.body[&#x27;first-name&#x27;].should.equal(&#x27;foo&#x27;);
res.body[&#x27;last-name&#x27;].should.equal(&#x27;bar&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>with network error</h1>
<dl>
<dt>should error</dt>
<dd><pre><code>request.get(&#x60;http://localhost:${this.port}/&#x60;).end((err, res) =&#x3E; {
assert(err, &#x27;expected an error&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>request</h1>
<dl>
<section class="suite">
<h1>not modified</h1>
<dl>
<dt>should start with 200</dt>
<dd><pre><code>request.get(&#x60;${base}/if-mod&#x60;).end((err, res) =&#x3E; {
res.should.have.status(200);
res.text.should.match(/^\d+$/);
ts = Number(res.text);
done();
});</code></pre></dd>
<dt>should then be 304</dt>
<dd><pre><code>request
.get(&#x60;${base}/if-mod&#x60;)
.set(&#x27;If-Modified-Since&#x27;, new Date(ts).toUTCString())
.end((err, res) =&#x3E; {
res.should.have.status(304);
// res.text.should.be.empty
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>req.parse(fn)</h1>
<dl>
<dt>should take precedence over default parsers</dt>
<dd><pre><code>request
.get(&#x60;${base}/manny&#x60;)
.parse(request.parse[&#x27;application/json&#x27;])
.end((err, res) =&#x3E; {
assert(res.ok);
assert.equal(&#x27;{&#x22;name&#x22;:&#x22;manny&#x22;}&#x27;, res.text);
assert.equal(&#x27;manny&#x27;, res.body.name);
done();
});</code></pre></dd>
<dt>should be the only parser</dt>
<dd><pre><code>request
.get(&#x60;${base}/image&#x60;)
.buffer(false)
.parse((res, fn) =&#x3E; {
res.on(&#x27;data&#x27;, () =&#x3E; {});
})
.then((res) =&#x3E; {
assert(res.ok);
assert.strictEqual(res.text, undefined);
res.body.should.eql({});
})</code></pre></dd>
<dt>should emit error if parser throws</dt>
<dd><pre><code>request
.get(&#x60;${base}/manny&#x60;)
.parse(() =&#x3E; {
throw new Error(&#x27;I am broken&#x27;);
})
.on(&#x27;error&#x27;, (err) =&#x3E; {
err.message.should.equal(&#x27;I am broken&#x27;);
done();
})
.end();</code></pre></dd>
<dt>should emit error if parser returns an error</dt>
<dd><pre><code>request
.get(&#x60;${base}/manny&#x60;)
.parse((res, fn) =&#x3E; {
fn(new Error(&#x27;I am broken&#x27;));
})
.on(&#x27;error&#x27;, (err) =&#x3E; {
err.message.should.equal(&#x27;I am broken&#x27;);
done();
})
.end();</code></pre></dd>
<dt>should not emit error on chunked json</dt>
<dd><pre><code>request.get(&#x60;${base}/chunked-json&#x60;).end((err) =&#x3E; {
assert.ifError(err);
done();
});</code></pre></dd>
<dt>should not emit error on aborted chunked json</dt>
<dd><pre><code>const req = request.get(&#x60;${base}/chunked-json&#x60;);
req.end((err) =&#x3E; {
assert.ifError(err);
done();
});
setTimeout(() =&#x3E; {
req.abort();
}, 50);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>pipe on redirect</h1>
<dl>
<dt>should follow Location</dt>
<dd><pre><code>const stream = fs.createWriteStream(destPath);
const redirects = [];
const req = request
.get(base)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.connect({
inapplicable: &#x27;should be ignored&#x27;
});
stream.on(&#x27;finish&#x27;, () =&#x3E; {
redirects.should.eql([&#x27;/movies&#x27;, &#x27;/movies/all&#x27;, &#x27;/movies/all/0&#x27;]);
fs.readFileSync(destPath, &#x27;utf8&#x27;).should.eql(&#x27;first movie page&#x27;);
done();
});
req.pipe(stream);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>request pipe</h1>
<dl>
<dt>should act as a writable stream</dt>
<dd><pre><code>const req = request.post(base);
const stream = fs.createReadStream(&#x27;test/node/fixtures/user.json&#x27;);
req.type(&#x27;json&#x27;);
req.on(&#x27;response&#x27;, (res) =&#x3E; {
res.body.should.eql({ name: &#x27;tobi&#x27; });
done();
});
stream.pipe(req);</code></pre></dd>
<dt>end() stops piping</dt>
<dd><pre><code>const stream = fs.createWriteStream(destPath);
request.get(base).end((err, res) =&#x3E; {
try {
res.pipe(stream);
return done(new Error(&#x27;Did not prevent nonsense pipe&#x27;));
} catch {
/* expected error */
}
done();
});</code></pre></dd>
<dt>should act as a readable stream</dt>
<dd><pre><code>const stream = fs.createWriteStream(destPath);
let responseCalled = false;
const req = request.get(base);
req.type(&#x27;json&#x27;);
req.on(&#x27;response&#x27;, (res) =&#x3E; {
res.status.should.eql(200);
responseCalled = true;
});
stream.on(&#x27;finish&#x27;, () =&#x3E; {
JSON.parse(fs.readFileSync(destPath, &#x27;utf8&#x27;)).should.eql({
name: &#x27;tobi&#x27;
});
responseCalled.should.be.true();
done();
});
req.pipe(stream);</code></pre></dd>
<dt>should follow redirects</dt>
<dd><pre><code>const stream = fs.createWriteStream(destPath);
let responseCalled = false;
const req = request.get(base + &#x27;/redirect&#x27;);
req.type(&#x27;json&#x27;);
req.on(&#x27;response&#x27;, (res) =&#x3E; {
res.status.should.eql(200);
responseCalled = true;
});
stream.on(&#x27;finish&#x27;, () =&#x3E; {
JSON.parse(fs.readFileSync(destPath, &#x27;utf8&#x27;)).should.eql({
name: &#x27;tobi&#x27;
});
responseCalled.should.be.true();
done();
});
req.pipe(stream);</code></pre></dd>
<dt>should not throw on bad redirects</dt>
<dd><pre><code>const stream = fs.createWriteStream(destPath);
let responseCalled = false;
let errorCalled = false;
const req = request.get(base + &#x27;/badRedirectNoLocation&#x27;);
req.type(&#x27;json&#x27;);
req.on(&#x27;response&#x27;, (res) =&#x3E; {
responseCalled = true;
});
req.on(&#x27;error&#x27;, (err) =&#x3E; {
err.message.should.eql(&#x27;No location header for redirect&#x27;);
errorCalled = true;
stream.end();
});
stream.on(&#x27;finish&#x27;, () =&#x3E; {
responseCalled.should.be.false();
errorCalled.should.be.true();
done();
});
req.pipe(stream);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.query(String)</h1>
<dl>
<dt>should support passing in a string</dt>
<dd><pre><code>request
.del(base)
.query(&#x27;name=t%F6bi&#x27;)
.end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;t%F6bi&#x27; });
done();
});</code></pre></dd>
<dt>should work with url query-string and string for query</dt>
<dd><pre><code>request
.del(&#x60;${base}/?name=tobi&#x60;)
.query(&#x27;age=2%20&#x27;)
.end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;tobi&#x27;, age: &#x27;2 &#x27; });
done();
});</code></pre></dd>
<dt>should support compound elements in a string</dt>
<dd><pre><code>request
.del(base)
.query(&#x27;name=t%F6bi&#x26;age=2&#x27;)
.end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;t%F6bi&#x27;, age: &#x27;2&#x27; });
done();
});</code></pre></dd>
<dt>should work when called multiple times with a string</dt>
<dd><pre><code>request
.del(base)
.query(&#x27;name=t%F6bi&#x27;)
.query(&#x27;age=2%F6&#x27;)
.end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;t%F6bi&#x27;, age: &#x27;2%F6&#x27; });
done();
});</code></pre></dd>
<dt>should work with normal &#x60;query&#x60; object and query string</dt>
<dd><pre><code>request
.del(base)
.query(&#x27;name=t%F6bi&#x27;)
.query({ age: &#x27;2&#x27; })
.end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;t%F6bi&#x27;, age: &#x27;2&#x27; });
done();
});</code></pre></dd>
<dt>should not encode raw backticks, but leave encoded ones as is</dt>
<dd><pre><code>return Promise.all([
request
.get(&#x60;${base}/raw-query&#x60;)
.query(&#x27;name=&#x60;t%60bi&#x60;&#x26;age&#x60;=2&#x27;)
.then((res) =&#x3E; {
res.text.should.eql(&#x27;name=&#x60;t%60bi&#x60;&#x26;age&#x60;=2&#x27;);
}),
request.get(base + &#x27;/raw-query?&#x60;age%60&#x60;=2%60&#x60;&#x27;).then((res) =&#x3E; {
res.text.should.eql(&#x27;&#x60;age%60&#x60;=2%60&#x60;&#x27;);
}),
request
.get(&#x60;${base}/raw-query&#x60;)
.query(&#x27;name=&#x60;t%60bi&#x60;&#x27;)
.query(&#x27;age&#x60;=2&#x27;)
.then((res) =&#x3E; {
res.text.should.eql(&#x27;name=&#x60;t%60bi&#x60;&#x26;age&#x60;=2&#x27;);
})
]);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.query(Object)</h1>
<dl>
<dt>should construct the query-string</dt>
<dd><pre><code>request
.del(base)
.query({ name: &#x27;tobi&#x27; })
.query({ order: &#x27;asc&#x27; })
.query({ limit: [&#x27;1&#x27;, &#x27;2&#x27;] })
.end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;tobi&#x27;, order: &#x27;asc&#x27;, limit: [&#x27;1&#x27;, &#x27;2&#x27;] });
done();
});</code></pre></dd>
<dt>should encode raw backticks</dt>
<dd><pre><code>request
.get(&#x60;${base}/raw-query&#x60;)
.query({ name: &#x27;&#x60;tobi&#x60;&#x27; })
.query({ &#x27;orde%60r&#x27;: null })
.query({ &#x27;&#x60;limit&#x60;&#x27;: [&#x27;%602&#x60;&#x27;] })
.end((err, res) =&#x3E; {
res.text.should.eql(&#x27;name=%60tobi%60&#x26;orde%2560r&#x26;%60limit%60=%25602%60&#x27;);
done();
});</code></pre></dd>
<dt>should not error on dates</dt>
<dd><pre><code>const date = new Date(0);
request
.del(base)
.query({ at: date })
.end((err, res) =&#x3E; {
assert.equal(date.toISOString(), res.body.at);
done();
});</code></pre></dd>
<dt>should work after setting header fields</dt>
<dd><pre><code>request
.del(base)
.set(&#x27;Foo&#x27;, &#x27;bar&#x27;)
.set(&#x27;Bar&#x27;, &#x27;baz&#x27;)
.query({ name: &#x27;tobi&#x27; })
.query({ order: &#x27;asc&#x27; })
.query({ limit: [&#x27;1&#x27;, &#x27;2&#x27;] })
.end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;tobi&#x27;, order: &#x27;asc&#x27;, limit: [&#x27;1&#x27;, &#x27;2&#x27;] });
done();
});</code></pre></dd>
<dt>should append to the original query-string</dt>
<dd><pre><code>request
.del(&#x60;${base}/?name=tobi&#x60;)
.query({ order: &#x27;asc&#x27; })
.end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;tobi&#x27;, order: &#x27;asc&#x27; });
done();
});</code></pre></dd>
<dt>should retain the original query-string</dt>
<dd><pre><code>request.del(&#x60;${base}/?name=tobi&#x60;).end((err, res) =&#x3E; {
res.body.should.eql({ name: &#x27;tobi&#x27; });
done();
});</code></pre></dd>
<dt>should keep only keys with null querystring values</dt>
<dd><pre><code>request
.del(&#x60;${base}/url&#x60;)
.query({ nil: null })
.end((err, res) =&#x3E; {
res.text.should.equal(&#x27;/url?nil&#x27;);
done();
});</code></pre></dd>
<dt>query-string should be sent on pipe</dt>
<dd><pre><code>const req = request.put(&#x60;${base}/?name=tobi&#x60;);
const stream = fs.createReadStream(&#x27;test/node/fixtures/user.json&#x27;);
req.on(&#x27;response&#x27;, (res) =&#x3E; {
res.body.should.eql({ name: &#x27;tobi&#x27; });
done();
});
stream.pipe(req);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>request.get</h1>
<dl>
<section class="suite">
<h1>on 301 redirect</h1>
<dl>
<dt>should follow Location with a GET request</dt>
<dd><pre><code>const req = request.get(&#x60;${base}/test-301&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;GET&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 302 redirect</h1>
<dl>
<dt>should follow Location with a GET request</dt>
<dd><pre><code>const req = request.get(&#x60;${base}/test-302&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
res.status.should.eql(200);
res.text.should.eql(&#x27;GET&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 303 redirect</h1>
<dl>
<dt>should follow Location with a GET request</dt>
<dd><pre><code>const req = request.get(&#x60;${base}/test-303&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;GET&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 307 redirect</h1>
<dl>
<dt>should follow Location with a GET request</dt>
<dd><pre><code>const req = request.get(&#x60;${base}/test-307&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;GET&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 308 redirect</h1>
<dl>
<dt>should follow Location with a GET request</dt>
<dd><pre><code>const req = request.get(&#x60;${base}/test-308&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;GET&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>request.post</h1>
<dl>
<section class="suite">
<h1>on 301 redirect</h1>
<dl>
<dt>should follow Location with a GET request</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/test-301&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;GET&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 302 redirect</h1>
<dl>
<dt>should follow Location with a GET request</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/test-302&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;GET&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 303 redirect</h1>
<dl>
<dt>should follow Location with a GET request</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/test-303&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;GET&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 307 redirect</h1>
<dl>
<dt>should follow Location with a POST request</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/test-307&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;POST&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on 308 redirect</h1>
<dl>
<dt>should follow Location with a POST request</dt>
<dd><pre><code>const req = request.post(&#x60;${base}/test-308&#x60;).redirects(1);
req.end((err, res) =&#x3E; {
const headers = req.req.getHeaders
? req.req.getHeaders()
: req.req._headers;
headers.host.should.eql(&#x60;localhost:${server2.address().port}&#x60;);
res.status.should.eql(200);
res.text.should.eql(&#x27;POST&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>request</h1>
<dl>
<section class="suite">
<h1>on redirect</h1>
<dl>
<dt>should merge cookies if agent is used</dt>
<dd><pre><code>request
.agent()
.get(&#x60;${base}/cookie-redirect&#x60;)
.set(&#x27;Cookie&#x27;, &#x27;orig=1; replaced=not&#x27;)
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(/orig=1/.test(res.text), &#x27;orig=1/.test&#x27;);
assert(/replaced=yes/.test(res.text), &#x27;replaced=yes/.test&#x27;);
assert(/from-redir=1/.test(res.text), &#x27;from-redir=1&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should not merge cookies if agent is not used</dt>
<dd><pre><code>request
.get(&#x60;${base}/cookie-redirect&#x60;)
.set(&#x27;Cookie&#x27;, &#x27;orig=1; replaced=not&#x27;)
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(/orig=1/.test(res.text), &#x27;/orig=1&#x27;);
assert(/replaced=not/.test(res.text), &#x27;/replaced=not&#x27;);
assert(!/replaced=yes/.test(res.text), &#x27;!/replaced=yes&#x27;);
assert(!/from-redir/.test(res.text), &#x27;!/from-redir&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should have previously set cookie for subsquent requests when agent is used</dt>
<dd><pre><code>const agent = request.agent();
agent.get(&#x60;${base}/set-cookie&#x60;).end((err) =&#x3E; {
assert.ifError(err);
agent
.get(&#x60;${base}/show-cookies&#x60;)
.set({ Cookie: &#x27;orig=1&#x27; })
.end((err, res) =&#x3E; {
try {
assert.ifError(err);
assert(/orig=1/.test(res.text), &#x27;orig=1/.test&#x27;);
assert(/persist=123/.test(res.text), &#x27;persist=123&#x27;);
done();
} catch (err_) {
done(err_);
}
});
});</code></pre></dd>
<dt>should follow Location</dt>
<dd><pre><code>const redirects = [];
request
.get(base)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.end((err, res) =&#x3E; {
try {
const arr = [&#x27;/movies&#x27;, &#x27;/movies/all&#x27;, &#x27;/movies/all/0&#x27;];
redirects.should.eql(arr);
res.text.should.equal(&#x27;first movie page&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should follow Location with IP override</dt>
<dd><pre><code>const redirects = [];
const url = URL.parse(base);
return request
.get(&#x60;http://redir.example.com:${url.port || &#x27;80&#x27;}${url.pathname}&#x60;)
.connect({
&#x27;*&#x27;: url.hostname
})
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.then((res) =&#x3E; {
const arr = [&#x27;/movies&#x27;, &#x27;/movies/all&#x27;, &#x27;/movies/all/0&#x27;];
redirects.should.eql(arr);
res.text.should.equal(&#x27;first movie page&#x27;);
});</code></pre></dd>
<dt>should follow Location with IP:port override</dt>
<dd><pre><code>const redirects = [];
const url = URL.parse(base);
return request
.get(&#x60;http://redir.example.com:9999${url.pathname}&#x60;)
.connect({
&#x27;*&#x27;: { host: url.hostname, port: url.port || 80 }
})
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.then((res) =&#x3E; {
const arr = [&#x27;/movies&#x27;, &#x27;/movies/all&#x27;, &#x27;/movies/all/0&#x27;];
redirects.should.eql(arr);
res.text.should.equal(&#x27;first movie page&#x27;);
});</code></pre></dd>
<dt>should not follow on HEAD by default</dt>
<dd><pre><code>const redirects = [];
return request
.head(base)
.ok(() =&#x3E; true)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.then((res) =&#x3E; {
redirects.should.eql([]);
res.status.should.equal(302);
});</code></pre></dd>
<dt>should follow on HEAD when redirects are set</dt>
<dd><pre><code>const redirects = [];
request
.head(base)
.redirects(10)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.end((err, res) =&#x3E; {
try {
const arr = [];
arr.push(&#x27;/movies&#x27;);
arr.push(&#x27;/movies/all&#x27;);
arr.push(&#x27;/movies/all/0&#x27;);
redirects.should.eql(arr);
assert(!res.text);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should remove Content-* fields</dt>
<dd><pre><code>request
.post(&#x60;${base}/header&#x60;)
.type(&#x27;txt&#x27;)
.set(&#x27;X-Foo&#x27;, &#x27;bar&#x27;)
.set(&#x27;X-Bar&#x27;, &#x27;baz&#x27;)
.send(&#x27;hey&#x27;)
.end((err, res) =&#x3E; {
try {
assert(res.body);
res.body.should.have.property(&#x27;x-foo&#x27;, &#x27;bar&#x27;);
res.body.should.have.property(&#x27;x-bar&#x27;, &#x27;baz&#x27;);
res.body.should.not.have.property(&#x27;content-type&#x27;);
res.body.should.not.have.property(&#x27;content-length&#x27;);
res.body.should.not.have.property(&#x27;transfer-encoding&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should retain cookies</dt>
<dd><pre><code>request
.get(&#x60;${base}/header&#x60;)
.set(&#x27;Cookie&#x27;, &#x27;foo=bar;&#x27;)
.end((err, res) =&#x3E; {
try {
assert(res.body);
res.body.should.have.property(&#x27;cookie&#x27;, &#x27;foo=bar;&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should not resend query parameters</dt>
<dd><pre><code>const redirects = [];
const query = [];
request
.get(&#x60;${base}/?foo=bar&#x60;)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
query.push(res.headers.query);
redirects.push(res.headers.location);
})
.end((err, res) =&#x3E; {
try {
const arr = [];
arr.push(&#x27;/movies&#x27;);
arr.push(&#x27;/movies/all&#x27;);
arr.push(&#x27;/movies/all/0&#x27;);
redirects.should.eql(arr);
res.text.should.equal(&#x27;first movie page&#x27;);
query.should.eql([&#x27;{&#x22;foo&#x22;:&#x22;bar&#x22;}&#x27;, &#x27;{}&#x27;, &#x27;{}&#x27;]);
res.headers.query.should.eql(&#x27;{}&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should handle no location header</dt>
<dd><pre><code>request.get(&#x60;${base}/bad-redirect&#x60;).end((err, res) =&#x3E; {
try {
err.message.should.equal(&#x27;No location header for redirect&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<section class="suite">
<h1>when relative</h1>
<dl>
<dt>should redirect to a sibling path</dt>
<dd><pre><code>const redirects = [];
request
.get(&#x60;${base}/relative&#x60;)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.end((err, res) =&#x3E; {
try {
redirects.should.eql([&#x27;tobi&#x27;]);
res.text.should.equal(&#x27;tobi&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
<dt>should redirect to a parent path</dt>
<dd><pre><code>const redirects = [];
request
.get(&#x60;${base}/relative/sub&#x60;)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.end((err, res) =&#x3E; {
try {
redirects.should.eql([&#x27;../tobi&#x27;]);
res.text.should.equal(&#x27;tobi&#x27;);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>req.redirects(n)</h1>
<dl>
<dt>should alter the default number of redirects to follow</dt>
<dd><pre><code>const redirects = [];
request
.get(base)
.redirects(2)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.end((err, res) =&#x3E; {
try {
const arr = [];
assert(res.redirect, &#x27;res.redirect&#x27;);
arr.push(&#x27;/movies&#x27;);
arr.push(&#x27;/movies/all&#x27;);
redirects.should.eql(arr);
res.text.should.match(/Moved Temporarily|Found/);
done();
} catch (err_) {
done(err_);
}
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>on POST</h1>
<dl>
<dt>should redirect as GET</dt>
<dd><pre><code>const redirects = [];
return request
.post(&#x60;${base}/movie&#x60;)
.send({ name: &#x27;Tobi&#x27; })
.redirects(2)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.then((res) =&#x3E; {
redirects.should.eql([&#x27;/movies/all/0&#x27;]);
res.text.should.equal(&#x27;first movie page&#x27;);
});</code></pre></dd>
<dt>using multipart/form-data should redirect as GET</dt>
<dd><pre><code>const redirects = [];
request
.post(&#x60;${base}/movie&#x60;)
.type(&#x27;form&#x27;)
.field(&#x27;name&#x27;, &#x27;Tobi&#x27;)
.redirects(2)
.on(&#x27;redirect&#x27;, (res) =&#x3E; {
redirects.push(res.headers.location);
})
.then((res) =&#x3E; {
redirects.should.eql([&#x27;/movies/all/0&#x27;]);
res.text.should.equal(&#x27;first movie page&#x27;);
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>response</h1>
<dl>
<dt>should act as a readable stream</dt>
<dd><pre><code>const req = request.get(base).buffer(false);
req.end((err, res) =&#x3E; {
if (err) return done(err);
let trackEndEvent = 0;
let trackCloseEvent = 0;
res.on(&#x27;end&#x27;, () =&#x3E; {
trackEndEvent++;
trackEndEvent.should.equal(1);
if (!process.env.HTTP2_TEST) {
trackCloseEvent.should.equal(0); // close should not have been called
}
done();
});
res.on(&#x27;close&#x27;, () =&#x3E; {
trackCloseEvent++;
});
(() =&#x3E; {
res.pause();
}).should.not.throw();
(() =&#x3E; {
res.resume();
}).should.not.throw();
(() =&#x3E; {
res.destroy();
}).should.not.throw();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>req.serialize(fn)</h1>
<dl>
<dt>should take precedence over default parsers</dt>
<dd><pre><code>request
.post(&#x60;${base}/echo&#x60;)
.send({ foo: 123 })
.serialize((data) =&#x3E; &#x27;{&#x22;bar&#x22;:456}&#x27;)
.end((err, res) =&#x3E; {
assert.ifError(err);
assert.equal(&#x27;{&#x22;bar&#x22;:456}&#x27;, res.text);
assert.equal(456, res.body.bar);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>request.get().set()</h1>
<dl>
<dt>should set host header after get()</dt>
<dd><pre><code>app.get(&#x27;/&#x27;, (req, res) =&#x3E; {
assert.equal(req.hostname, &#x27;example.com&#x27;);
res.end();
});
server = http.createServer(app);
server.listen(0, function listening() {
request
.get(&#x60;http://localhost:${server.address().port}&#x60;)
.set(&#x27;host&#x27;, &#x27;example.com&#x27;)
.then(() =&#x3E; {
return request
.get(&#x60;http://example.com:${server.address().port}&#x60;)
.connect({
&#x27;example.com&#x27;: &#x27;localhost&#x27;,
&#x27;*&#x27;: &#x27;fail&#x27;
});
})
.then(() =&#x3E; done(), done);
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>res.toError()</h1>
<dl>
<dt>should return an Error</dt>
<dd><pre><code>request.get(base).end((err, res) =&#x3E; {
var err = res.toError();
assert.equal(err.status, 400);
assert.equal(err.method, &#x27;GET&#x27;);
assert.equal(err.path, &#x27;/&#x27;);
assert.equal(err.message, &#x27;cannot GET / (400)&#x27;);
assert.equal(err.text, &#x27;invalid json&#x27;);
done();
});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>[unix-sockets] http</h1>
<dl>
<section class="suite">
<h1>request</h1>
<dl>
<dt>path: / (root)</dt>
<dd><pre><code>request.get(&#x60;${base}/&#x60;).end((err, res) =&#x3E; {
assert(res.ok);
assert.strictEqual(&#x27;root ok!&#x27;, res.text);
done();
});</code></pre></dd>
<dt>path: /request/path</dt>
<dd><pre><code>request.get(&#x60;${base}/request/path&#x60;).end((err, res) =&#x3E; {
assert(res.ok);
assert.strictEqual(&#x27;request path ok!&#x27;, res.text);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>[unix-sockets] https</h1>
<dl>
<section class="suite">
<h1>request</h1>
<dl>
<dt>path: / (root)</dt>
<dd><pre><code>request
.get(&#x60;${base}/&#x60;)
.ca(cacert)
.end((err, res) =&#x3E; {
assert.ifError(err);
assert(res.ok);
assert.strictEqual(&#x27;root ok!&#x27;, res.text);
done();
});</code></pre></dd>
<dt>path: /request/path</dt>
<dd><pre><code>request
.get(&#x60;${base}/request/path&#x60;)
.ca(cacert)
.end((err, res) =&#x3E; {
assert.ifError(err);
assert(res.ok);
assert.strictEqual(&#x27;request path ok!&#x27;, res.text);
done();
});</code></pre></dd>
</dl>
</section>
</dl>
</section>
<section class="suite">
<h1>req.get()</h1>
<dl>
<dt>should not set a default user-agent</dt>
<dd><pre><code>request.get(&#x60;${base}/ua&#x60;).then((res) =&#x3E; {
assert(res.headers);
assert(!res.headers[&#x27;user-agent&#x27;]);
})</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>utils.type(str)</h1>
<dl>
<dt>should return the mime type</dt>
<dd><pre><code>utils
.type(&#x27;application/json; charset=utf-8&#x27;)
.should.equal(&#x27;application/json&#x27;);
utils.type(&#x27;application/json&#x27;).should.equal(&#x27;application/json&#x27;);</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>utils.params(str)</h1>
<dl>
<dt>should return the field parameters</dt>
<dd><pre><code>const obj = utils.params(&#x27;application/json; charset=utf-8; foo = bar&#x27;);
obj.charset.should.equal(&#x27;utf-8&#x27;);
obj.foo.should.equal(&#x27;bar&#x27;);
utils.params(&#x27;application/json&#x27;).should.eql({});</code></pre></dd>
</dl>
</section>
<section class="suite">
<h1>utils.parseLinks(str)</h1>
<dl>
<dt>should parse links</dt>
<dd><pre><code>const str =
&#x27;&#x3C;https://api.github.com/repos/visionmedia/mocha/issues?page=2&#x3E;; rel=&#x22;next&#x22;, &#x3C;https://api.github.com/repos/visionmedia/mocha/issues?page=5&#x3E;; rel=&#x22;last&#x22;&#x27;;
const ret = utils.parseLinks(str);
ret.next.should.equal(
&#x27;https://api.github.com/repos/visionmedia/mocha/issues?page=2&#x27;
);
ret.last.should.equal(
&#x27;https://api.github.com/repos/visionmedia/mocha/issues?page=5&#x27;
);</code></pre></dd>
</dl>
</section>
</div>
<a href="http://github.com/visionmedia/superagent"><img style="position: absolute; top: 0; right: 0; border: 0;" src="https://s3.amazonaws.com/github/ribbons/forkme_right_white_ffffff.png" alt="Fork me on GitHub"></a>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.0/jquery.min.js"></script>
<script>
$('code').each(function(){
$(this).html(highlight($(this).text()));
});
function highlight(js) {
return js
.replace(/</g, '&lt;')
.replace(/>/g, '&gt;')
.replace(/('.*?')/gm, '<span class="string">$1</span>')
.replace(/(\d+\.\d+)/gm, '<span class="number">$1</span>')
.replace(/(\d+)/gm, '<span class="number">$1</span>')
.replace(/\bnew *(\w+)/gm, '<span class="keyword">new</span> <span class="init">$1</span>')
.replace(/\b(function|new|throw|return|var|if|else)\b/gm, '<span class="keyword">$1</span>')
}
</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/tocbot/3.0.0/tocbot.js"></script>
<script>
// Only use tocbot for main docs, not test docs
if (document.querySelector('#superagent')) {
tocbot.init({
// Where to render the table of contents.
tocSelector: '#menu',
// Where to grab the headings to build the table of contents.
contentSelector: '#content',
// Which headings to grab inside of the contentSelector element.
headingSelector: 'h2',
smoothScroll: false
});
}
</script>
</body>
</html>