nodejs/test/parallel/test-zlib-flush-drain.js
James M Snell 85ab4a5f12 buffer: add .from(), .alloc() and .allocUnsafe()
Several changes:

* Soft-Deprecate Buffer() constructors
* Add `Buffer.from()`, `Buffer.alloc()`, and `Buffer.allocUnsafe()`
* Add `--zero-fill-buffers` command line option
* Add byteOffset and length to `new Buffer(arrayBuffer)` constructor
* buffer.fill('') previously had no effect, now zero-fills
* Update the docs

PR-URL: https://github.com/nodejs/node/pull/4682
Reviewed-By: Сковорода Никита Андреевич <chalkerx@gmail.com>
Reviewed-By: Stephen Belanger <admin@stephenbelanger.com>
2016-03-16 08:34:02 -07:00

49 lines
1.1 KiB
JavaScript

'use strict';
require('../common');
const assert = require('assert');
const zlib = require('zlib');
const bigData = Buffer.alloc(10240, 'x');
const opts = {
level: 0,
highWaterMark: 16
};
const deflater = zlib.createDeflate(opts);
// shim deflater.flush so we can count times executed
var flushCount = 0;
var drainCount = 0;
const flush = deflater.flush;
deflater.flush = function(kind, callback) {
flushCount++;
flush.call(this, kind, callback);
};
deflater.write(bigData);
const ws = deflater._writableState;
const beforeFlush = ws.needDrain;
var afterFlush = ws.needDrain;
deflater.flush(function(err) {
afterFlush = ws.needDrain;
});
deflater.on('drain', function() {
drainCount++;
});
process.once('exit', function() {
assert.equal(beforeFlush, true,
'before calling flush the writable stream should need to drain');
assert.equal(afterFlush, false,
'after calling flush the writable stream should not need to drain');
assert.equal(drainCount, 1,
'the deflater should have emitted a single drain event');
assert.equal(flushCount, 2,
'flush should be called twice');
});