Skip to content
This repository has been archived by the owner on Apr 22, 2023. It is now read-only.

Commit

Permalink
net: Socket write encoding case sensitivity
Browse files Browse the repository at this point in the history
Fixes #1586.
  • Loading branch information
koichik committed Sep 3, 2011
1 parent 3e853e6 commit 55e6be1
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 9 deletions.
12 changes: 3 additions & 9 deletions lib/net.js
Original file line number Diff line number Diff line change
Expand Up @@ -409,16 +409,10 @@ Socket.prototype._writeOut = function(data, encoding, fd, cb) {
allocNewPool();
}

if (!encoding || encoding == 'utf8' || encoding == 'utf-8') {
// default to utf8
bytesWritten = pool.write(data, 'utf8', pool.used);
charsWritten = Buffer._charsWritten;
} else {
bytesWritten = pool.write(data, encoding, pool.used);
charsWritten = bytesWritten;
}
bytesWritten = pool.write(data, encoding, pool.used);
charsWritten = Buffer._charsWritten;

if (encoding && data.length > 0) {
if (data.length > 0) {
assert(bytesWritten > 0);
}

Expand Down
54 changes: 54 additions & 0 deletions test/simple/test-net-large-string.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
// Copyright Joyent, Inc. and other Node contributors.
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to permit
// persons to whom the Software is furnished to do so, subject to the
// following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
// USE OR OTHER DEALINGS IN THE SOFTWARE.

var common = require('../common');
var assert = require('assert');
var net = require('net');

var kPoolSize = 40 * 1024;
var data = '';
for (var i = 0; i < kPoolSize; ++i) {
data += 'あ'; // 3bytes
}
var receivedSize = 0;
var encoding = 'UTF-8';

var server = net.createServer(function(socket) {
socket.setEncoding(encoding);
socket.on('data', function(data) {
receivedSize += data.length;
}).on('end', function() {

This comment has been minimized.

Copy link
@bnoordhuis

bnoordhuis Sep 4, 2011

Member

Make that .on a separate statement (i.e. socket.on(..)), easier to read. LGTM otherwise.

This comment has been minimized.

Copy link
@koichik

koichik Sep 4, 2011

Author

Thanks!

socket.end();
});
});

server.listen(common.PORT, function() {
var client = net.createConnection(common.PORT);
client.on('end', function() {
server.close();
});
client.write(data, encoding);
client.end();
});

process.on('exit', function() {
assert.equal(receivedSize, kPoolSize);
});

0 comments on commit 55e6be1

Please sign in to comment.