| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195 | 'use strict'const assert = require('chai').assertconst proxyquire = require('proxyquire')const spooks = require('spooks')const Promise = require('bluebird')const modulePath = '../../src/stringify'suite('stringify:', () => {  test('require does not throw', () => {    assert.doesNotThrow(() => {      require(modulePath)    })  })  test('require returns function', () => {    assert.isFunction(require(modulePath))  })  suite('require:', () => {    let log, stringify    setup(() => {      log = {}      stringify = proxyquire(modulePath, {        './streamify': spooks.fn({          name: 'streamify',          log: log,          results: [            { on: spooks.fn({ name: 'on', log: log }) }          ]        })      })    })    test('stringify expects two arguments', () => {      assert.lengthOf(stringify, 2)    })    test('stringify does not throw', () => {      assert.doesNotThrow(() => {        stringify()      })    })    test('stringify returns promise', () => {      assert.instanceOf(stringify(), Promise)    })    test('streamify was not called', () => {      assert.strictEqual(log.counts.streamify, 0)    })    suite('stringify:', () => {      let data, options, resolved, rejected, result, done      setup(() => {        data = {}        options = {}        stringify(data, options)          .then(res => {            resolved = res            done()          })          .catch(rej => {            rejected = rej            done()          })      })      teardown(() => {        resolved = rejected = undefined      })      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('stream.on was called four times', () => {        assert.strictEqual(log.counts.on, 4)      })      test('stream.on was called correctly first time', () => {        assert.lengthOf(log.args.on[0], 2)        assert.strictEqual(log.args.on[0][0], 'data')        assert.isFunction(log.args.on[0][1])      })      test('stream.on was called correctly second time', () => {        assert.strictEqual(log.args.on[1][0], 'end')        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.strictEqual(log.args.on[2][0], 'error')        assert.isFunction(log.args.on[2][1])        assert.notStrictEqual(log.args.on[2][1], log.args.on[0][1])        assert.notStrictEqual(log.args.on[2][1], log.args.on[1][1])      })      test('stream.on was called correctly fourth time', () => {        assert.strictEqual(log.args.on[3][0], 'dataError')        assert.isFunction(log.args.on[3][1])        assert.strictEqual(log.args.on[3][1], log.args.on[2][1])      })      test('promise is unfulfilled', () => {        assert.isUndefined(resolved)        assert.isUndefined(rejected)      })      suite('data event:', () => {        setup(() => {          log.args.on[0][1]('foo')        })        test('promise is unfulfilled', () => {          assert.isUndefined(resolved)          assert.isUndefined(rejected)        })        suite('end event:', () => {          setup(d => {            done = d            log.args.on[1][1]()          })          test('promise is resolved', () => {            assert.strictEqual(resolved, 'foo')          })          test('promise is not rejected', () => {            assert.isUndefined(rejected)          })        })        suite('data event:', () => {          setup(() => {            log.args.on[0][1]('bar')          })          test('promise is unfulfilled', () => {            assert.isUndefined(resolved)            assert.isUndefined(rejected)          })          suite('end event:', () => {            setup(d => {              done = d              log.args.on[1][1]()            })            test('promise is resolved', () => {              assert.strictEqual(resolved, 'foobar')            })          })          suite('error event:', () => {            setup(d => {              done = d              log.args.on[2][1]('wibble')            })            test('promise is rejected', () => {              assert.strictEqual(rejected, 'wibble')            })          })          suite('dataError event:', () => {            setup(d => {              done = d              log.args.on[3][1]('wibble')            })            test('promise is rejected', () => {              assert.strictEqual(rejected, 'wibble')            })          })        })      })    })  })})
 |