Improve fs.write tests
authorRyan Dahl <ry@tinyclouds.org>
Thu, 10 Jun 2010 21:59:06 +0000 (14:59 -0700)
committerRyan Dahl <ry@tinyclouds.org>
Thu, 10 Jun 2010 22:17:46 +0000 (15:17 -0700)
test/simple/test-fs-write-sync.js
test/simple/test-fs-write.js
test/simple/test-stdin-from-file.js

index 2e30cc704ebbbbc6fc1187b73647572e913e3f9c..27dea4af76b2e8c19e99ca106b1bab1ded2bed71 100644 (file)
@@ -1,12 +1,16 @@
 require('../common');
-var path = require('path')
-  , Buffer = require('buffer').Buffer
-  , fs = require('fs')
-  , fn = path.join(fixturesDir, 'write.txt');
+path = require('path'),
+Buffer = require('buffer').Buffer
+fs = require('fs')
+fn = path.join(fixturesDir, 'write.txt');
 
+
+foo = 'foo'
 var fd = fs.openSync(fn, 'w');
-fs.writeSync(fd, 'foo');
-fs.writeSync(fd, new Buffer('bar'), 0, 3);
+fs.writeSync(fd, foo);
+
+bar = 'bár'
+fs.writeSync(fd, new Buffer(bar), 0, Buffer.byteLength(bar));
 fs.closeSync(fd);
 
-assert.equal(fs.readFileSync(fn), 'foobar');
\ No newline at end of file
+assert.equal(fs.readFileSync(fn), 'foobár');
index 8290d9a086c71de588520c2467425d745b0e43fa..24a8b8cf604383745ae04d5b7eb140e924cc1e48 100644 (file)
@@ -1,8 +1,9 @@
 require("../common");
 var path = require('path');
+var Buffer = require('buffer').Buffer;
 var fs = require('fs');
 var fn = path.join(fixturesDir, "write.txt");
-var expected = "hello";
+var expected = "ümlaut.";
 var found;
 
 fs.open(fn, 'w', 0644, function (err, fd) {
@@ -11,7 +12,7 @@ fs.open(fn, 'w', 0644, function (err, fd) {
   fs.write(fd, expected, 0, "utf8", function (err, written) {
     puts('write done');
     if (err) throw err;
-    assert.equal(expected.length, written);
+    assert.equal(Buffer.byteLength(expected), written);
     fs.closeSync(fd);
     found = fs.readFileSync(fn, 'utf8');
     puts('expected: ' + expected.toJSON());
index 3167adfd6400ddab059201146f77db507f00f0df..0c7e8f7a8fbdfee1d6d3ad39b5d2dd73b7d753c4 100644 (file)
@@ -1,12 +1,17 @@
 require('../common');
-var TEST_STR = "abc\n123\nhello world\nsomething else"
-  , path = require('path')
-  , childProccess = require('child_process')
-  , fs = require('fs')
-  , stdoutScript = path.join(fixturesDir, 'echo.js')
-  , tmpFile = path.join(fixturesDir, 'stdin.txt')
-  , cmd = process.argv[0] + ' ' + stdoutScript + ' < ' + tmpFile
-  ;
+
+join = require('path').join;
+childProccess = require('child_process');
+fs = require('fs');
+
+stdoutScript = join(fixturesDir, 'echo.js');
+tmpFile = join(fixturesDir, 'stdin.txt');
+
+cmd = process.argv[0] + ' ' + stdoutScript + ' < ' + tmpFile;
+
+string = "abc\nümlaut.\nsomething else\n"
+       + "南越国是前203年至前111年存在于岭南地区的一个国家,国都位于番禺,疆域包括今天中国的广东、广西两省区的大部份地区,福建省、湖南、贵州、云南的一小部份地区和越南的北部。南越国是秦朝灭亡后,由南海郡尉赵佗于前203年起兵兼并桂林郡和象郡后建立。前196年和前179年,南越国曾先后两次名义上臣属于西汉,成为西汉的“外臣”。前112年,南越国末代君主赵建德与西汉发生战争,被汉武帝于前111年所灭。南越国共存在93年,历经五代君主。南越国是岭南地区的第一个有记载的政权国家,采用封建制和郡县制并存的制度,它的建立保证了秦末乱世岭南地区社会秩序的稳定,有效的改善了岭南地区落后的政治、##济现状。\n";
+
 
 puts(cmd + "\n\n");
 
@@ -14,13 +19,13 @@ try {
   fs.unlinkSync(tmpFile);
 } catch (e) {}
 
-fs.writeFileSync(tmpFile, TEST_STR);
+fs.writeFileSync(tmpFile, string);
 
 childProccess.exec(cmd, function(err, stdout, stderr) {
   fs.unlinkSync(tmpFile);
 
   if (err) throw err;
   puts(stdout);
-  assert.equal(stdout, "hello world\r\n" + TEST_STR);
+  assert.equal(stdout, "hello world\r\n" + string);
   assert.equal("", stderr);
 });