1012 lines
34 KiB
JavaScript
1012 lines
34 KiB
JavaScript
|
'use strict'
|
||
|
|
||
|
const assert = require('chai').assert
|
||
|
const proxyquire = require('proxyquire')
|
||
|
const spooks = require('spooks')
|
||
|
const Promise = require('bluebird')
|
||
|
|
||
|
const modulePath = '../../src/parse'
|
||
|
|
||
|
suite('parse:', () => {
|
||
|
test('require does not throw', () => {
|
||
|
assert.doesNotThrow(() => {
|
||
|
require(modulePath)
|
||
|
})
|
||
|
})
|
||
|
|
||
|
test('require returns function', () => {
|
||
|
assert.isFunction(require(modulePath))
|
||
|
})
|
||
|
|
||
|
suite('require:', () => {
|
||
|
let log, results, parse
|
||
|
|
||
|
setup(() => {
|
||
|
log = {}
|
||
|
results = {
|
||
|
walk: [
|
||
|
{
|
||
|
on: spooks.fn({ name: 'on', log: log }),
|
||
|
pause: spooks.fn({ name: 'pause', log: log, results: [ () => {} ] }),
|
||
|
removeAllListeners: spooks.fn({ name: 'removeAllListeners', log: log })
|
||
|
}
|
||
|
]
|
||
|
}
|
||
|
parse = proxyquire(modulePath, {
|
||
|
'./walk': spooks.fn({
|
||
|
name: 'walk',
|
||
|
log: log,
|
||
|
results: results.walk
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
test('parse expects two arguments', () => {
|
||
|
assert.lengthOf(parse, 2)
|
||
|
})
|
||
|
|
||
|
test('parse does not throw', () => {
|
||
|
assert.doesNotThrow(() => {
|
||
|
parse()
|
||
|
})
|
||
|
})
|
||
|
|
||
|
test('parse does not throw if reviver is an object', () => {
|
||
|
assert.doesNotThrow(() => {
|
||
|
parse({}, { reviver: {} }).catch(() => {})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
test('parse does not throw if revive is a function', () => {
|
||
|
assert.doesNotThrow(() => {
|
||
|
parse({}, { reviver: () => {} })
|
||
|
})
|
||
|
})
|
||
|
|
||
|
test('parse returns a promise', () => {
|
||
|
assert.instanceOf(parse(), Promise)
|
||
|
})
|
||
|
|
||
|
test('parse returns a different type of promise if the option is set', () => {
|
||
|
assert.isFunction(global.Promise)
|
||
|
assert.notStrictEqual(Promise, global.Promise)
|
||
|
assert.instanceOf(parse('', { Promise: global.Promise }), global.Promise)
|
||
|
})
|
||
|
|
||
|
test('parse rejects immediately if reviver is an object', () => {
|
||
|
return parse({}, { reviver: {} })
|
||
|
.then(() => assert(false))
|
||
|
.catch(error => assert.instanceOf(error, Error))
|
||
|
})
|
||
|
|
||
|
test('parse does not reject immediately if reviver is a function', () => {
|
||
|
parse({}, { reviver: () => {} })
|
||
|
.catch(error => assert(false))
|
||
|
})
|
||
|
|
||
|
test('walk was not called', () => {
|
||
|
assert.strictEqual(log.counts.walk, 0)
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was not called', () => {
|
||
|
assert.strictEqual(log.counts.on, 0)
|
||
|
})
|
||
|
|
||
|
suite('parse:', () => {
|
||
|
let stream, options
|
||
|
|
||
|
setup(() => {
|
||
|
stream = {}
|
||
|
options = {}
|
||
|
parse(stream, options)
|
||
|
.then(spooks.fn({ name: 'resolve', log: log }))
|
||
|
.catch(spooks.fn({ name: 'reject', log: log }))
|
||
|
})
|
||
|
|
||
|
test('walk was called once', () => {
|
||
|
assert.strictEqual(log.counts.walk, 1)
|
||
|
assert.isUndefined(log.these.walk[0])
|
||
|
})
|
||
|
|
||
|
test('walk was called correctly', () => {
|
||
|
assert.lengthOf(log.args.walk[0], 2)
|
||
|
assert.strictEqual(log.args.walk[0][0], stream)
|
||
|
assert.lengthOf(Object.keys(log.args.walk[0][0]), 0)
|
||
|
assert.strictEqual(log.args.walk[0][1], options)
|
||
|
assert.lengthOf(Object.keys(log.args.walk[0][1]), 0)
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called ten times', () => {
|
||
|
assert.strictEqual(log.counts.on, 10)
|
||
|
assert.strictEqual(log.these.on[0], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[1], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[2], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[3], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[4], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[5], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[6], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[7], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[8], results.walk[0])
|
||
|
assert.strictEqual(log.these.on[9], results.walk[0])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly first time', () => {
|
||
|
assert.lengthOf(log.args.on[0], 2)
|
||
|
assert.strictEqual(log.args.on[0][0], 'arr')
|
||
|
assert.isFunction(log.args.on[0][1])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly second time', () => {
|
||
|
assert.lengthOf(log.args.on[1], 2)
|
||
|
assert.strictEqual(log.args.on[1][0], 'obj')
|
||
|
assert.isFunction(log.args.on[1][1])
|
||
|
assert.notStrictEqual(log.args.on[1][1], log.args.on[0][1])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly third time', () => {
|
||
|
assert.lengthOf(log.args.on[2], 2)
|
||
|
assert.strictEqual(log.args.on[2][0], 'pro')
|
||
|
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('EventEmitter.on was called correctly fourth time', () => {
|
||
|
assert.lengthOf(log.args.on[3], 2)
|
||
|
assert.strictEqual(log.args.on[3][0], 'str')
|
||
|
assert.isFunction(log.args.on[3][1])
|
||
|
assert.notStrictEqual(log.args.on[3][1], log.args.on[0][1])
|
||
|
assert.notStrictEqual(log.args.on[3][1], log.args.on[1][1])
|
||
|
assert.notStrictEqual(log.args.on[3][1], log.args.on[2][1])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly fifth time', () => {
|
||
|
assert.lengthOf(log.args.on[4], 2)
|
||
|
assert.strictEqual(log.args.on[4][0], 'num')
|
||
|
assert.isFunction(log.args.on[4][1])
|
||
|
assert.strictEqual(log.args.on[4][1], log.args.on[3][1])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly sixth time', () => {
|
||
|
assert.lengthOf(log.args.on[5], 2)
|
||
|
assert.strictEqual(log.args.on[5][0], 'lit')
|
||
|
assert.isFunction(log.args.on[5][1])
|
||
|
assert.strictEqual(log.args.on[5][1], log.args.on[3][1])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly seventh time', () => {
|
||
|
assert.lengthOf(log.args.on[6], 2)
|
||
|
assert.strictEqual(log.args.on[6][0], 'end-arr')
|
||
|
assert.isFunction(log.args.on[6][1])
|
||
|
assert.notStrictEqual(log.args.on[6][1], log.args.on[0][1])
|
||
|
assert.notStrictEqual(log.args.on[6][1], log.args.on[1][1])
|
||
|
assert.notStrictEqual(log.args.on[6][1], log.args.on[2][1])
|
||
|
assert.notStrictEqual(log.args.on[6][1], log.args.on[3][1])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly eighth time', () => {
|
||
|
assert.lengthOf(log.args.on[7], 2)
|
||
|
assert.strictEqual(log.args.on[7][0], 'end-obj')
|
||
|
assert.isFunction(log.args.on[7][1])
|
||
|
assert.strictEqual(log.args.on[7][1], log.args.on[6][1])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly ninth time', () => {
|
||
|
assert.lengthOf(log.args.on[8], 2)
|
||
|
assert.strictEqual(log.args.on[8][0], 'end')
|
||
|
assert.isFunction(log.args.on[8][1])
|
||
|
assert.notStrictEqual(log.args.on[8][1], log.args.on[0][1])
|
||
|
assert.notStrictEqual(log.args.on[8][1], log.args.on[1][1])
|
||
|
assert.notStrictEqual(log.args.on[8][1], log.args.on[2][1])
|
||
|
assert.notStrictEqual(log.args.on[8][1], log.args.on[3][1])
|
||
|
assert.notStrictEqual(log.args.on[8][1], log.args.on[6][1])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly tenth time', () => {
|
||
|
assert.lengthOf(log.args.on[9], 2)
|
||
|
assert.strictEqual(log.args.on[9][0], 'err')
|
||
|
assert.isFunction(log.args.on[9][1])
|
||
|
assert.notStrictEqual(log.args.on[9][1], log.args.on[0][1])
|
||
|
assert.notStrictEqual(log.args.on[9][1], log.args.on[1][1])
|
||
|
assert.notStrictEqual(log.args.on[9][1], log.args.on[2][1])
|
||
|
assert.notStrictEqual(log.args.on[9][1], log.args.on[3][1])
|
||
|
assert.notStrictEqual(log.args.on[9][1], log.args.on[6][1])
|
||
|
assert.notStrictEqual(log.args.on[9][1], log.args.on[8][1])
|
||
|
})
|
||
|
|
||
|
suite('array event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[0][1]()
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.isUndefined(log.these.resolve[0])
|
||
|
assert.lengthOf(log.args.resolve[0], 1)
|
||
|
assert.isArray(log.args.resolve[0][0])
|
||
|
assert.lengthOf(log.args.resolve[0][0], 0)
|
||
|
})
|
||
|
|
||
|
test('reject was not called', () => {
|
||
|
assert.strictEqual(log.counts.reject, 0)
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('string event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[3][1]('foo')
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0], 1)
|
||
|
assert.isArray(log.args.resolve[0][0])
|
||
|
assert.lengthOf(log.args.resolve[0][0], 1)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('string event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[3][1]('bar')
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.strictEqual(log.args.resolve[0][0][1], 'bar')
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('array event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[0][1]()
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.isArray(log.args.resolve[0][0][1])
|
||
|
assert.lengthOf(log.args.resolve[0][0][1], 0)
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('string event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[3][1]('bar')
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.isArray(log.args.resolve[0][0][1])
|
||
|
assert.lengthOf(log.args.resolve[0][0][1], 1)
|
||
|
assert.strictEqual(log.args.resolve[0][0][1][0], 'bar')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('string event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[3][1]('baz')
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.isArray(log.args.resolve[0][0][1])
|
||
|
assert.lengthOf(log.args.resolve[0][0][1], 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][1][0], 'bar')
|
||
|
assert.strictEqual(log.args.resolve[0][0][1][1], 'baz')
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('endArray event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[6][1]()
|
||
|
})
|
||
|
|
||
|
suite('string event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[3][1]('baz')
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 3)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.isArray(log.args.resolve[0][0][1])
|
||
|
assert.lengthOf(log.args.resolve[0][0][1], 1)
|
||
|
assert.strictEqual(log.args.resolve[0][0][1][0], 'bar')
|
||
|
assert.strictEqual(log.args.resolve[0][0][2], 'baz')
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('object event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[1][1]()
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.isObject(log.args.resolve[0][0][1])
|
||
|
assert.lengthOf(Object.keys(log.args.resolve[0][0][1]), 0)
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('property event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[2][1]('bar')
|
||
|
})
|
||
|
|
||
|
suite('string event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[3][1]('baz')
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.isObject(log.args.resolve[0][0][1])
|
||
|
assert.lengthOf(Object.keys(log.args.resolve[0][0][1]), 1)
|
||
|
assert.strictEqual(log.args.resolve[0][0][1].bar, 'baz')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('property event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[2][1]('qux')
|
||
|
})
|
||
|
|
||
|
suite('string event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[3][1]('wibble')
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.isObject(log.args.resolve[0][0][1])
|
||
|
assert.lengthOf(Object.keys(log.args.resolve[0][0][1]), 2)
|
||
|
assert.strictEqual(log.args.resolve[0][0][1].bar, 'baz')
|
||
|
assert.strictEqual(log.args.resolve[0][0][1].qux, 'wibble')
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('endObject event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[7][1]()
|
||
|
})
|
||
|
|
||
|
suite('string event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[3][1]('wibble')
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0][0], 3)
|
||
|
assert.strictEqual(log.args.resolve[0][0][0], 'foo')
|
||
|
assert.isObject(log.args.resolve[0][0][1])
|
||
|
assert.lengthOf(Object.keys(log.args.resolve[0][0][1]), 1)
|
||
|
assert.strictEqual(log.args.resolve[0][0][1].bar, 'baz')
|
||
|
assert.strictEqual(log.args.resolve[0][0][2], 'wibble')
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('error event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[9][1]('foo')
|
||
|
})
|
||
|
|
||
|
test('reject was not called', () => {
|
||
|
assert.strictEqual(log.counts.reject, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('reject was called once', () => {
|
||
|
assert.strictEqual(log.counts.reject, 1)
|
||
|
})
|
||
|
|
||
|
test('reject was called correctly', () => {
|
||
|
assert.isUndefined(log.these.reject[0])
|
||
|
assert.lengthOf(log.args.reject[0], 1)
|
||
|
assert.strictEqual(log.args.reject[0][0], 'foo')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('error event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[9][1]('bar')
|
||
|
})
|
||
|
|
||
|
test('reject was not called', () => {
|
||
|
assert.strictEqual(log.counts.reject, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('reject was called once', () => {
|
||
|
assert.strictEqual(log.counts.reject, 1)
|
||
|
})
|
||
|
|
||
|
test('reject was called correctly', () => {
|
||
|
assert.strictEqual(log.args.reject[0][0], 'foo')
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('object event:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[1][1]()
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.isObject(log.args.resolve[0][0])
|
||
|
assert.lengthOf(Object.keys(log.args.resolve[0][0]), 0)
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('parse with reviver:', () => {
|
||
|
let stream, options
|
||
|
|
||
|
setup(() => {
|
||
|
stream = {}
|
||
|
options = { reviver: spooks.fn({ name: 'reviver', log: log, results: [ 'reviver result' ] }) }
|
||
|
parse(stream, options)
|
||
|
.then(spooks.fn({ name: 'resolve', log: log }))
|
||
|
.catch(spooks.fn({ name: 'reject', log: log }))
|
||
|
})
|
||
|
|
||
|
test('walk was called once', () => {
|
||
|
assert.strictEqual(log.counts.walk, 1)
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called ten times', () => {
|
||
|
assert.strictEqual(log.counts.on, 10)
|
||
|
})
|
||
|
|
||
|
suite('populated array events:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[0][1]()
|
||
|
log.args.on[3][1]('foo')
|
||
|
log.args.on[3][1]('bar')
|
||
|
log.args.on[0][1]()
|
||
|
log.args.on[0][1]()
|
||
|
log.args.on[3][1]('baz')
|
||
|
log.args.on[6][1]()
|
||
|
log.args.on[3][1]('qux')
|
||
|
log.args.on[6][1]()
|
||
|
log.args.on[6][1]()
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
test('reviver was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('reviver was called six times', () => {
|
||
|
assert.strictEqual(log.counts.reviver, 7)
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly first time', () => {
|
||
|
assert.lengthOf(log.args.reviver[0], 2)
|
||
|
assert.strictEqual(log.args.reviver[0][0], '0')
|
||
|
assert.strictEqual(log.args.reviver[0][1], 'foo')
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly second time', () => {
|
||
|
assert.strictEqual(log.args.reviver[1][0], '1')
|
||
|
assert.strictEqual(log.args.reviver[1][1], 'bar')
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly third time', () => {
|
||
|
assert.strictEqual(log.args.reviver[2][0], '0')
|
||
|
assert.strictEqual(log.args.reviver[2][1], 'baz')
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly fourth time', () => {
|
||
|
assert.strictEqual(log.args.reviver[3][0], '0')
|
||
|
assert.isArray(log.args.reviver[3][1])
|
||
|
assert.lengthOf(log.args.reviver[3][1], 1)
|
||
|
assert.strictEqual(log.args.reviver[3][1][0], 'reviver result')
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly fifth time', () => {
|
||
|
assert.strictEqual(log.args.reviver[4][0], '1')
|
||
|
assert.strictEqual(log.args.reviver[4][1], 'qux')
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly sixth time', () => {
|
||
|
assert.strictEqual(log.args.reviver[5][0], '2')
|
||
|
assert.isArray(log.args.reviver[5][1])
|
||
|
assert.lengthOf(log.args.reviver[5][1], 2)
|
||
|
assert.strictEqual(log.args.reviver[5][1][0], 'reviver result')
|
||
|
assert.strictEqual(log.args.reviver[5][1][1], 'reviver result')
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly seventh time', () => {
|
||
|
assert.strictEqual(log.args.reviver[6][0], '')
|
||
|
assert.isArray(log.args.reviver[6][1])
|
||
|
assert.lengthOf(log.args.reviver[6][1], 3)
|
||
|
assert.strictEqual(log.args.reviver[6][1][0], 'reviver result')
|
||
|
assert.strictEqual(log.args.reviver[6][1][1], 'reviver result')
|
||
|
assert.strictEqual(log.args.reviver[6][1][2], 'reviver result')
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('populated object events:', () => {
|
||
|
setup(() => {
|
||
|
log.args.on[1][1]()
|
||
|
log.args.on[2][1]('foo')
|
||
|
log.args.on[1][1]()
|
||
|
log.args.on[2][1]('bar')
|
||
|
log.args.on[4][1](3.14159265359)
|
||
|
log.args.on[7][1]()
|
||
|
log.args.on[2][1]('baz')
|
||
|
log.args.on[5][1](null)
|
||
|
log.args.on[7][1]()
|
||
|
})
|
||
|
|
||
|
test('resolve was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
test('reviver was not called', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 0)
|
||
|
})
|
||
|
|
||
|
suite('end event:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[8][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('reviver was called four times', () => {
|
||
|
assert.strictEqual(log.counts.reviver, 4)
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly first time', () => {
|
||
|
assert.lengthOf(log.args.reviver[0], 2)
|
||
|
assert.strictEqual(log.args.reviver[0][0], 'bar')
|
||
|
assert.strictEqual(log.args.reviver[0][1], 3.14159265359)
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly second time', () => {
|
||
|
assert.strictEqual(log.args.reviver[1][0], 'foo')
|
||
|
assert.isObject(log.args.reviver[1][1])
|
||
|
assert.lengthOf(Object.keys(log.args.reviver[1][1]), 1)
|
||
|
assert.strictEqual(log.args.reviver[1][1].bar, 'reviver result')
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly third time', () => {
|
||
|
assert.strictEqual(log.args.reviver[2][0], 'baz')
|
||
|
assert.isNull(log.args.reviver[2][1])
|
||
|
})
|
||
|
|
||
|
test('reviver was called correctly fourth time', () => {
|
||
|
assert.strictEqual(log.args.reviver[3][0], '')
|
||
|
assert.isObject(log.args.reviver[3][1])
|
||
|
assert.lengthOf(Object.keys(log.args.reviver[3][1]), 2)
|
||
|
assert.strictEqual(log.args.reviver[3][1].foo, 'reviver result')
|
||
|
assert.strictEqual(log.args.reviver[3][1].baz, 'reviver result')
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('parse with ndjson:', () => {
|
||
|
let stream
|
||
|
|
||
|
setup(() => {
|
||
|
stream = {}
|
||
|
parse(stream, { ndjson: true })
|
||
|
.then(spooks.fn({ name: 'resolve', log: log }))
|
||
|
.catch(spooks.fn({ name: 'reject', log: log }))
|
||
|
})
|
||
|
|
||
|
test('walk was called once', () => {
|
||
|
assert.strictEqual(log.counts.walk, 1)
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called eleven times', () => {
|
||
|
assert.strictEqual(log.counts.on, 11)
|
||
|
assert.strictEqual(log.these.on[10], results.walk[0])
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly first ten times', () => {
|
||
|
assert.strictEqual(log.args.on[0][0], 'arr')
|
||
|
assert.strictEqual(log.args.on[1][0], 'obj')
|
||
|
assert.strictEqual(log.args.on[2][0], 'pro')
|
||
|
assert.strictEqual(log.args.on[3][0], 'str')
|
||
|
assert.strictEqual(log.args.on[4][0], 'num')
|
||
|
assert.strictEqual(log.args.on[5][0], 'lit')
|
||
|
assert.strictEqual(log.args.on[6][0], 'end-arr')
|
||
|
assert.strictEqual(log.args.on[7][0], 'end-obj')
|
||
|
assert.strictEqual(log.args.on[8][0], 'end')
|
||
|
assert.strictEqual(log.args.on[9][0], 'err')
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called correctly eleventh time', () => {
|
||
|
assert.lengthOf(log.args.on[10], 2)
|
||
|
assert.strictEqual(log.args.on[10][0], 'end-line')
|
||
|
assert.isFunction(log.args.on[10][1])
|
||
|
assert.notStrictEqual(log.args.on[10][1], log.args.on[0][1])
|
||
|
assert.notStrictEqual(log.args.on[10][1], log.args.on[1][1])
|
||
|
assert.notStrictEqual(log.args.on[10][1], log.args.on[2][1])
|
||
|
assert.notStrictEqual(log.args.on[10][1], log.args.on[3][1])
|
||
|
assert.notStrictEqual(log.args.on[10][1], log.args.on[6][1])
|
||
|
assert.notStrictEqual(log.args.on[10][1], log.args.on[8][1])
|
||
|
assert.notStrictEqual(log.args.on[10][1], log.args.on[9][1])
|
||
|
})
|
||
|
|
||
|
test('emitter.pause was not called', () => {
|
||
|
assert.strictEqual(log.counts.pause, 0)
|
||
|
})
|
||
|
|
||
|
test('emitter.removeAllListeners was not called', () => {
|
||
|
assert.strictEqual(log.counts.removeAllListeners, 0)
|
||
|
})
|
||
|
|
||
|
suite('array, endArray, endLine:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[0][1]()
|
||
|
log.args.on[6][1]()
|
||
|
log.args.on[10][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve[0], 1)
|
||
|
assert.isArray(log.args.resolve[0][0])
|
||
|
assert.lengthOf(log.args.resolve[0][0], 0)
|
||
|
})
|
||
|
|
||
|
test('emitter.pause was called once', () => {
|
||
|
assert.strictEqual(log.counts.pause, 1)
|
||
|
})
|
||
|
|
||
|
test('emitter.pause was called correctly', () => {
|
||
|
assert.lengthOf(log.args.pause[0], 0)
|
||
|
})
|
||
|
|
||
|
test('emitter.removeAllListeners was called once', () => {
|
||
|
assert.strictEqual(log.counts.removeAllListeners, 1)
|
||
|
})
|
||
|
|
||
|
test('emitter.removeAllListeners was called correctly', () => {
|
||
|
assert.lengthOf(log.args.removeAllListeners[0], 0)
|
||
|
})
|
||
|
|
||
|
test('reject was not called', () => {
|
||
|
assert.strictEqual(log.counts.reject, 0)
|
||
|
})
|
||
|
|
||
|
suite('parse with ndjson:', () => {
|
||
|
setup(() => {
|
||
|
parse(stream, { ndjson: true })
|
||
|
.then(spooks.fn({ name: 'resolve2', log: log }))
|
||
|
.catch(spooks.fn({ name: 'reject2', log: log }))
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called eleven times', () => {
|
||
|
assert.strictEqual(log.counts.on, 22)
|
||
|
})
|
||
|
|
||
|
test('walk was not called', () => {
|
||
|
assert.strictEqual(log.counts.walk, 1)
|
||
|
})
|
||
|
|
||
|
suite('string, end:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[14][1]('foo')
|
||
|
log.args.on[19][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
assert.strictEqual(log.counts.resolve2, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve2[0], 1)
|
||
|
assert.strictEqual(log.args.resolve2[0][0], 'foo')
|
||
|
})
|
||
|
|
||
|
test('emitter.pause was called once', () => {
|
||
|
assert.strictEqual(log.counts.pause, 2)
|
||
|
})
|
||
|
|
||
|
test('emitter.removeAllListeners was called once', () => {
|
||
|
assert.strictEqual(log.counts.removeAllListeners, 2)
|
||
|
})
|
||
|
|
||
|
test('reject was not called', () => {
|
||
|
assert.strictEqual(log.counts.reject, 0)
|
||
|
assert.strictEqual(log.counts.reject2, 0)
|
||
|
})
|
||
|
|
||
|
suite('parse with ndjson:', () => {
|
||
|
setup(() => {
|
||
|
parse(stream, { ndjson: true })
|
||
|
.then(spooks.fn({ name: 'resolve3', log: log }))
|
||
|
.catch(spooks.fn({ name: 'reject3', log: log }))
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called eleven times', () => {
|
||
|
assert.strictEqual(log.counts.on, 33)
|
||
|
})
|
||
|
|
||
|
test('walk was not called', () => {
|
||
|
assert.strictEqual(log.counts.walk, 1)
|
||
|
})
|
||
|
|
||
|
suite('end:', () => {
|
||
|
setup(done => {
|
||
|
log.args.on[30][1]()
|
||
|
setImmediate(done)
|
||
|
})
|
||
|
|
||
|
test('resolve was called once', () => {
|
||
|
assert.strictEqual(log.counts.resolve, 1)
|
||
|
assert.strictEqual(log.counts.resolve2, 1)
|
||
|
assert.strictEqual(log.counts.resolve3, 1)
|
||
|
})
|
||
|
|
||
|
test('resolve was called correctly', () => {
|
||
|
assert.lengthOf(log.args.resolve3[0], 1)
|
||
|
assert.strictEqual(log.args.resolve3[0][0], undefined)
|
||
|
})
|
||
|
|
||
|
test('emitter.pause was called once', () => {
|
||
|
assert.strictEqual(log.counts.pause, 3)
|
||
|
})
|
||
|
|
||
|
test('emitter.removeAllListeners was called once', () => {
|
||
|
assert.strictEqual(log.counts.removeAllListeners, 3)
|
||
|
})
|
||
|
|
||
|
test('reject was not called', () => {
|
||
|
assert.strictEqual(log.counts.reject, 0)
|
||
|
assert.strictEqual(log.counts.reject2, 0)
|
||
|
assert.strictEqual(log.counts.reject3, 0)
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
suite('parse with ndjson and fresh stream:', () => {
|
||
|
setup(() => {
|
||
|
parse({}, { ndjson: true })
|
||
|
.then(spooks.fn({ name: 'resolve2', log: log }))
|
||
|
.catch(spooks.fn({ name: 'reject2', log: log }))
|
||
|
})
|
||
|
|
||
|
test('EventEmitter.on was called eleven times', () => {
|
||
|
assert.strictEqual(log.counts.on, 22)
|
||
|
})
|
||
|
|
||
|
test('walk was called once', () => {
|
||
|
assert.strictEqual(log.counts.walk, 2)
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|