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

View File

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