lib/http.js - nested loop stepping on variables of outer loop

Fixes #318.
This commit is contained in:
Ryan Dahl 2010-10-04 10:50:35 -07:00
parent 48d7a1edc1
commit 38f8665f3a
2 changed files with 24 additions and 10 deletions

View File

@ -410,9 +410,8 @@ OutgoingMessage.prototype._storeHeader = function (firstLine, headers) {
if (headers) {
var keys = Object.keys(headers);
var isArray = (Array.isArray(headers));
var i, l;
for (i = 0, l = keys.length; i < l; i++) {
for (var i = 0, l = keys.length; i < l; i++) {
var key = keys[i];
if (isArray) {
field = headers[key][0];
@ -423,8 +422,8 @@ OutgoingMessage.prototype._storeHeader = function (firstLine, headers) {
}
if (Array.isArray(value)) {
for (i = 0, l = value.length; i < l; i++) {
store(field, value[i]);
for (var j = 0; j < value.length; j++) {
store(field, value[j]);
}
} else {
store(field, value);

View File

@ -6,14 +6,16 @@ url = require("url");
var PROXY_PORT = common.PORT;
var BACKEND_PORT = common.PORT+1;
var cookies = [
"session_token=; path=/; expires=Sun, 15-Sep-2030 13:48:52 GMT",
"prefers_open_id=; path=/; expires=Thu, 01-Jan-1970 00:00:00 GMT"
];
var cookies = [ "session_token=; path=/; expires=Sun, 15-Sep-2030 13:48:52 GMT",
"prefers_open_id=; path=/; expires=Thu, 01-Jan-1970 00:00:00 GMT" ];
var headers = {"content-type": "text/plain",
"set-cookie": cookies,
"hello": "world" };
var backend = http.createServer(function (req, res) {
common.debug("backend request");
res.writeHead(200, {"content-type": "text/plain", "set-cookie": cookies});
res.writeHead(200, headers);
res.write("hello world\n");
res.end();
});
@ -24,10 +26,19 @@ var proxy = http.createServer(function (req, res) {
var proxy_req = proxy_client.request(url.parse(req.url).pathname);
proxy_req.end();
proxy_req.addListener('response', function(proxy_res) {
common.debug("proxy res headers: " + JSON.stringify(proxy_res.headers));
assert.equal('world', proxy_res.headers['hello']);
assert.equal('text/plain', proxy_res.headers['content-type']);
assert.deepEqual(cookies, proxy_res.headers['set-cookie']);
res.writeHead(proxy_res.statusCode, proxy_res.headers);
proxy_res.addListener("data", function(chunk) {
res.write(chunk);
});
proxy_res.addListener("end", function() {
res.end();
common.debug("proxy res");
@ -48,7 +59,11 @@ function startReq () {
req.addListener('response', function (res) {
common.debug("got res");
assert.equal(200, res.statusCode);
assert.deepEqual(cookies, res.headers["set-cookie"]);
assert.equal('world', res.headers['hello']);
assert.equal('text/plain', res.headers['content-type']);
assert.deepEqual(cookies, res.headers['set-cookie']);
res.setEncoding("utf8");
res.addListener('data', function (chunk) { body += chunk; });
res.addListener('end', function () {