0
0
mirror of https://github.com/nodejs/node.git synced 2024-12-01 16:10:02 +01:00
nodejs/test/parallel/test-fs-write-stream-err.js
Gibson Fahnestock 3d2aef3979 test: s/assert.equal/assert.strictEqual/
Use assert.strictEqual instead of assert.equal in tests, manually
convert types where necessary.

PR-URL: https://github.com/nodejs/node/pull/10698
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Sakthipriyan Vairamani <thechargingvolcano@gmail.com>
Reviewed-By: Michaël Zasso <targos@protonmail.com>
Reviewed-By: Teddy Katz <teddy.katz@gmail.com>
2017-01-11 14:19:26 +00:00

54 lines
1.3 KiB
JavaScript

'use strict';
const common = require('../common');
const assert = require('assert');
const fs = require('fs');
common.refreshTmpDir();
const stream = fs.createWriteStream(common.tmpDir + '/out', {
highWaterMark: 10
});
const err = new Error('BAM');
const write = fs.write;
let writeCalls = 0;
fs.write = function() {
switch (writeCalls++) {
case 0:
console.error('first write');
// first time is ok.
return write.apply(fs, arguments);
case 1:
// then it breaks
console.error('second write');
const cb = arguments[arguments.length - 1];
return process.nextTick(function() {
cb(err);
});
default:
// and should not be called again!
throw new Error('BOOM!');
}
};
fs.close = common.mustCall(function(fd_, cb) {
console.error('fs.close', fd_, stream.fd);
assert.strictEqual(fd_, stream.fd);
process.nextTick(cb);
});
stream.on('error', common.mustCall(function(err_) {
console.error('error handler');
assert.strictEqual(stream.fd, null);
assert.strictEqual(err_, err);
}));
stream.write(Buffer.allocUnsafe(256), function() {
console.error('first cb');
stream.write(Buffer.allocUnsafe(256), common.mustCall(function(err_) {
console.error('second cb');
assert.strictEqual(err_, err);
}));
});