From a695065305b710044569e0ee24b15b932fd2bd67 Mon Sep 17 00:00:00 2001 From: Ryan Dahl Date: Sun, 7 Feb 2010 18:05:58 -0800 Subject: [PATCH] Add failing test for stdout flush on exit --- test/mjsunit/fixtures/print-chars.js | 12 ++++++++ test/mjsunit/test-readdir.js | 1 + test/mjsunit/test-stdout-flush.js | 44 ++++++++++++++++++++++++++++ 3 files changed, 57 insertions(+) create mode 100644 test/mjsunit/fixtures/print-chars.js create mode 100644 test/mjsunit/test-stdout-flush.js diff --git a/test/mjsunit/fixtures/print-chars.js b/test/mjsunit/fixtures/print-chars.js new file mode 100644 index 00000000000..c4202b60365 --- /dev/null +++ b/test/mjsunit/fixtures/print-chars.js @@ -0,0 +1,12 @@ +process.mixin(require("../common")); + +var n = parseInt(process.argv[2]); + +var s = ""; +for (var i = 0; i < n-1; i++) { + s += 'c'; +} + +puts(s); // \n is the nth char. + +process.exit(0); diff --git a/test/mjsunit/test-readdir.js b/test/mjsunit/test-readdir.js index 766dc6ef46c..8cc0ee8c938 100644 --- a/test/mjsunit/test-readdir.js +++ b/test/mjsunit/test-readdir.js @@ -13,6 +13,7 @@ promise.addCallback(function (files) { , 'echo.js' , 'multipart.js' , 'nested-index' + , 'print-chars.js' , 'test_ca.pem' , 'test_cert.pem' , 'test_key.pem' diff --git a/test/mjsunit/test-stdout-flush.js b/test/mjsunit/test-stdout-flush.js new file mode 100644 index 00000000000..52d96336412 --- /dev/null +++ b/test/mjsunit/test-stdout-flush.js @@ -0,0 +1,44 @@ +process.mixin(require("./common")); + +var sub = path.join(fixturesDir, 'print-chars.js'); + +completedTests = 0; + +function test (n, cb) { + var child = process.createChildProcess(process.argv[0], [sub, n]); + + var count = 0; + + child.addListener("error", function (data){ + if (data) { + puts("parent stderr: " + data); + assert.ok(false); + } + }); + + child.addListener("output", function (data){ + if (data) { + count += data.length; + } + }); + + child.addListener("exit", function (data) { + assert.equal(n, count); + puts(n + " okay"); + completedTests++; + if (cb) cb(); + }); +} + + + +test(5000, function () { + test(50000, function () { + test(500000); + }); +}); + + +process.addListener('exit', function () { + assert.equal(3, completedTests); +});