| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 | 'use strict'const assert = require('chai').assertconst 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')      })  })})
 |