| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 | 
							- 'use strict'
 
- const assert = require('chai').assert
 
- const proxyquire = require('proxyquire')
 
- const spooks = require('spooks')
 
- const Promise = require('bluebird')
 
- const modulePath = '../../src/write'
 
- suite('write:', () => {
 
-   test('require does not throw', () => {
 
-     assert.doesNotThrow(() => {
 
-       require(modulePath)
 
-     })
 
-   })
 
-   test('require returns function', () => {
 
-     assert.isFunction(require(modulePath))
 
-   })
 
-   suite('require:', () => {
 
-     let log, results, write
 
-     setup(() => {
 
-       log = {}
 
-       results = {
 
-         createWriteStream: [ {} ]
 
-       }
 
-       write = proxyquire(modulePath, {
 
-         'fs': {
 
-           createWriteStream: spooks.fn({
 
-             name: 'createWriteStream',
 
-             log: log,
 
-             results: results.createWriteStream
 
-           })
 
-         },
 
-         './streamify': spooks.fn({
 
-           name: 'streamify',
 
-           log: log,
 
-           results: [
 
-             {
 
-               pipe: spooks.fn({ name: 'pipe', log: log, chain: true }),
 
-               on: spooks.fn({ name: 'on', log: log, chain: true })
 
-             }
 
-           ]
 
-         })
 
-       })
 
-     })
 
-     test('write expects three arguments', () => {
 
-       assert.lengthOf(write, 3)
 
-     })
 
-     test('write does not throw', () => {
 
-       assert.doesNotThrow(() => {
 
-         write()
 
-       })
 
-     })
 
-     test('streamify was not called', () => {
 
-       assert.strictEqual(log.counts.streamify, 0)
 
-     })
 
-     test('fs.createWriteStream was not called', () => {
 
-       assert.strictEqual(log.counts.createWriteStream, 0)
 
-     })
 
-     test('stream.pipe was not called', () => {
 
-       assert.strictEqual(log.counts.pipe, 0)
 
-     })
 
-     test('stream.on was not called', () => {
 
-       assert.strictEqual(log.counts.on, 0)
 
-     })
 
-     suite('write:', () => {
 
-       let path, data, options, result
 
-       setup(() => {
 
-         path = {}
 
-         data = {}
 
-         options = {}
 
-         result = write(path, data, options)
 
-       })
 
-       test('streamify was called once', () => {
 
-         assert.strictEqual(log.counts.streamify, 1)
 
-         assert.isUndefined(log.these.streamify[0])
 
-       })
 
-       test('streamify was called correctly', () => {
 
-         assert.lengthOf(log.args.streamify[0], 2)
 
-         assert.strictEqual(log.args.streamify[0][0], data)
 
-         assert.lengthOf(Object.keys(log.args.streamify[0][0]), 0)
 
-         assert.strictEqual(log.args.streamify[0][1], options)
 
-         assert.lengthOf(Object.keys(log.args.streamify[0][1]), 0)
 
-       })
 
-       test('fs.createWriteStream was called once', () => {
 
-         assert.strictEqual(log.counts.createWriteStream, 1)
 
-       })
 
-       test('fs.createWriteStream was called correctly', () => {
 
-         assert.lengthOf(log.args.createWriteStream[0], 2)
 
-         assert.strictEqual(log.args.createWriteStream[0][0], path)
 
-         assert.lengthOf(Object.keys(log.args.createWriteStream[0][0]), 0)
 
-         assert.strictEqual(log.args.createWriteStream[0][1], options)
 
-         assert.lengthOf(Object.keys(log.args.createWriteStream[0][1]), 0)
 
-       })
 
-       test('stream.pipe was called once', () => {
 
-         assert.strictEqual(log.counts.pipe, 1)
 
-       })
 
-       test('stream.pipe was called correctly', () => {
 
-         assert.lengthOf(log.args.pipe[0], 1)
 
-         assert.strictEqual(log.args.pipe[0][0], results.createWriteStream[0])
 
-         assert.lengthOf(Object.keys(log.args.pipe[0][0]), 0)
 
-       })
 
-       test('stream.on was called three times', () => {
 
-         assert.strictEqual(log.counts.on, 3)
 
-       })
 
-       test('stream.on was called correctly first time', () => {
 
-         assert.lengthOf(log.args.on[0], 2)
 
-         assert.strictEqual(log.args.on[0][0], 'finish')
 
-         assert.isFunction(log.args.on[0][1])
 
-       })
 
-       test('stream.on was called correctly second time', () => {
 
-         assert.lengthOf(log.args.on[1], 2)
 
-         assert.strictEqual(log.args.on[1][0], 'error')
 
-         assert.isFunction(log.args.on[1][1])
 
-         assert.notStrictEqual(log.args.on[1][1], log.args.on[0][1])
 
-       })
 
-       test('stream.on was called correctly third time', () => {
 
-         assert.lengthOf(log.args.on[2], 2)
 
-         assert.strictEqual(log.args.on[2][0], 'dataError')
 
-         assert.isFunction(log.args.on[2][1])
 
-         assert.notStrictEqual(log.args.on[2][1], log.args.on[0][1])
 
-         assert.strictEqual(log.args.on[2][1], log.args.on[1][1])
 
-       })
 
-       test('promise was returned', () => {
 
-         assert.instanceOf(result, Promise)
 
-       })
 
-       suite('dispatch finish event:', () => {
 
-         let resolved, error, passed, failed
 
-         setup(done => {
 
-           passed = failed = false
 
-           result.then(res => {
 
-             resolved = res
 
-             passed = true
 
-             done()
 
-           }).catch(err => {
 
-             error = err
 
-             failed = true
 
-             done()
 
-           })
 
-           log.args.on[0][1]('foo')
 
-         })
 
-         test('promise was resolved', () => {
 
-           assert.isTrue(passed)
 
-           assert.isFalse(failed)
 
-           assert.isUndefined(resolved)
 
-         })
 
-       })
 
-       suite('dispatch error event:', () => {
 
-         let resolved, error, passed, failed
 
-         setup(done => {
 
-           passed = failed = false
 
-           result.then(r => {
 
-             resolved = r
 
-             passed = true
 
-             done()
 
-           }).catch(e => {
 
-             error = e
 
-             failed = true
 
-             done()
 
-           })
 
-           log.args.on[1][1]('foo')
 
-         })
 
-         test('promise was rejected', () => {
 
-           assert.isTrue(failed)
 
-           assert.isFalse(passed)
 
-           assert.strictEqual(error, 'foo')
 
-         })
 
-       })
 
-       suite('dispatch dataError event:', () => {
 
-         let resolved, error, passed, failed
 
-         setup(done => {
 
-           passed = failed = false
 
-           result.then(r => {
 
-             resolved = r
 
-             passed = true
 
-             done()
 
-           }).catch(e => {
 
-             error = e
 
-             failed = true
 
-             done()
 
-           })
 
-           log.args.on[2][1]('wibble')
 
-         })
 
-         test('promise was rejected', () => {
 
-           assert.isTrue(failed)
 
-           assert.isFalse(passed)
 
-           assert.strictEqual(error, 'wibble')
 
-         })
 
-       })
 
-     })
 
-   })
 
- })
 
- suite('write with error thrown by fs.createWriteStream:', () => {
 
-   let write
 
-   setup(() => {
 
-     write = proxyquire(modulePath, {
 
-       fs: {
 
-         createWriteStream () {
 
-           throw new Error('foo')
 
-         }
 
-       },
 
-       './streamify': () => ({
 
-         pipe: spooks.fn({ name: 'pipe', log: {}, chain: true }),
 
-         on: spooks.fn({ name: 'on', log: {}, chain: true })
 
-       })
 
-     })
 
-   })
 
-   test('write does not throw', () => {
 
-     assert.doesNotThrow(() => {
 
-       write().catch(() => {})
 
-     })
 
-   })
 
-   test('write rejects', () => {
 
-     write()
 
-       .then(() => assert.fail('write should reject'))
 
-       .catch(error => {
 
-         assert.instanceOf(error, Error)
 
-         assert.equal(error.message, 'foo')
 
-       })
 
-   })
 
- })
 
 
  |