From d81afcb3a6d2ee38d731dfe97e42bff8911fcddf Mon Sep 17 00:00:00 2001 From: Ali Farhadi Date: Mon, 24 Jan 2011 01:13:59 +0330 Subject: [PATCH] Fixing bug in http request's end method. --- lib/http.js | 1 + test/simple/test-http-request-end.js | 37 ++++++++++++++++++++++++++++ 2 files changed, 38 insertions(+) create mode 100644 test/simple/test-http-request-end.js diff --git a/lib/http.js b/lib/http.js index eb8beb1f2a5..70adece38b0 100644 --- a/lib/http.js +++ b/lib/http.js @@ -565,6 +565,7 @@ OutgoingMessage.prototype.end = function(data, encoding) { typeof(data) === 'string' && data.length > 0 && this.output.length === 0 && + this.connection && this.connection.writable && this.connection._httpMessage === this; diff --git a/test/simple/test-http-request-end.js b/test/simple/test-http-request-end.js new file mode 100644 index 00000000000..ce9bbd1cabb --- /dev/null +++ b/test/simple/test-http-request-end.js @@ -0,0 +1,37 @@ +var common = require('../common'); +var assert = require('assert'); +var http = require('http'); + +var expected = 'Post Body For Test'; +var result = ''; + +var server = http.Server(function(req, res) { + req.setEncoding('utf8'); + req.on('data', function(chunk) { + result += chunk; + }); + + req.on('end', function() { + server.close(); + }); + + res.writeHead(200); + res.end("hello world\n"); +}); + +server.listen(common.PORT, function() { + http.request({ + port: common.PORT, + path: '/', + method: 'POST' + }, function(res) { + console.log(res.statusCode); + }).on('error', function(e) { + console.log(e.message); + process.exit(1); + }).end(expected); +}); + +process.on('exit', function() { + assert.equal(expected, result); +});