Skip to content

Commit fdbfc9c

Browse files
committed
net: Socket write encoding case sensitivity
Fixes nodejs#1586.
1 parent 3e853e6 commit fdbfc9c

File tree

2 files changed

+58
-9
lines changed

2 files changed

+58
-9
lines changed

lib/net.js

Lines changed: 3 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -409,16 +409,10 @@ Socket.prototype._writeOut = function(data, encoding, fd, cb) {
409409
allocNewPool();
410410
}
411411

412-
if (!encoding || encoding == 'utf8' || encoding == 'utf-8') {
413-
// default to utf8
414-
bytesWritten = pool.write(data, 'utf8', pool.used);
415-
charsWritten = Buffer._charsWritten;
416-
} else {
417-
bytesWritten = pool.write(data, encoding, pool.used);
418-
charsWritten = bytesWritten;
419-
}
412+
bytesWritten = pool.write(data, encoding, pool.used);
413+
charsWritten = Buffer._charsWritten;
420414

421-
if (encoding && data.length > 0) {
415+
if (data.length > 0) {
422416
assert(bytesWritten > 0);
423417
}
424418

test/simple/test-net-large-string.js

Lines changed: 55 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
// Copyright Joyent, Inc. and other Node contributors.
2+
//
3+
// Permission is hereby granted, free of charge, to any person obtaining a
4+
// copy of this software and associated documentation files (the
5+
// "Software"), to deal in the Software without restriction, including
6+
// without limitation the rights to use, copy, modify, merge, publish,
7+
// distribute, sublicense, and/or sell copies of the Software, and to permit
8+
// persons to whom the Software is furnished to do so, subject to the
9+
// following conditions:
10+
//
11+
// The above copyright notice and this permission notice shall be included
12+
// in all copies or substantial portions of the Software.
13+
//
14+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
15+
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16+
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
17+
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
18+
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
19+
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20+
// USE OR OTHER DEALINGS IN THE SOFTWARE.
21+
22+
var common = require('../common');
23+
var assert = require('assert');
24+
var net = require('net');
25+
26+
var kPoolSize = 40 * 1024;
27+
var data = '';
28+
for (var i = 0; i < kPoolSize; ++i) {
29+
data += 'あ'; // 3bytes
30+
}
31+
var receivedSize = 0;
32+
var encoding = 'UTF-8';
33+
34+
var server = net.createServer(function(socket) {
35+
socket.setEncoding(encoding);
36+
socket.on('data', function(data) {
37+
receivedSize += data.length;
38+
});
39+
socket.on('end', function() {
40+
socket.end();
41+
});
42+
});
43+
44+
server.listen(common.PORT, function() {
45+
var client = net.createConnection(common.PORT);
46+
client.on('end', function() {
47+
server.close();
48+
});
49+
client.write(data, encoding);
50+
client.end();
51+
});
52+
53+
process.on('exit', function() {
54+
assert.equal(receivedSize, kPoolSize);
55+
});

0 commit comments

Comments
 (0)