1 |
3a515b92
|
cagy
|
'use strict'
|
2 |
|
|
var fs = require('graceful-fs')
|
3 |
|
|
var path = require('path')
|
4 |
|
|
var test = require('tap').test
|
5 |
|
|
var rimraf = require('rimraf')
|
6 |
|
|
var writeStream = require('../index.js')
|
7 |
|
|
|
8 |
|
|
var target = path.resolve(__dirname, 'test-chown')
|
9 |
|
|
|
10 |
|
|
test('slow close', function (t) {
|
11 |
|
|
t.plan(2)
|
12 |
|
|
// The goal here is to simulate the "file close" step happening so slowly
|
13 |
|
|
// that the whole close/rename process could finish before the file is
|
14 |
|
|
// actually closed (and thus buffers truely flushed to the OS). In
|
15 |
|
|
// previous versions of this module, this would result in the module
|
16 |
|
|
// emitting finish & close before the file was fully written and in
|
17 |
|
|
// turn, could break other layers that tried to read the new file.
|
18 |
|
|
var realEmit = fs.WriteStream.prototype.emit
|
19 |
|
|
var reallyClosed = false
|
20 |
|
|
fs.WriteStream.prototype.emit = function (event) {
|
21 |
|
|
if (event !== 'close') return realEmit.apply(this, arguments)
|
22 |
|
|
setTimeout(function () {
|
23 |
|
|
reallyClosed = true
|
24 |
|
|
realEmit.call(this, 'close')
|
25 |
|
|
}.bind(this), 200)
|
26 |
|
|
}
|
27 |
|
|
var stream = writeStream(target)
|
28 |
|
|
stream.on('finish', function () {
|
29 |
|
|
t.is(reallyClosed, true, "didn't finish before target was closed")
|
30 |
|
|
})
|
31 |
|
|
stream.on('close', function () {
|
32 |
|
|
t.is(reallyClosed, true, "didn't close before target was closed")
|
33 |
|
|
})
|
34 |
|
|
stream.end()
|
35 |
|
|
})
|
36 |
|
|
|
37 |
|
|
test('cleanup', function (t) {
|
38 |
|
|
rimraf.sync(target)
|
39 |
|
|
t.end()
|
40 |
|
|
})
|