|
|
'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 one argument', () => { assert.lengthOf(parse, 1) })
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 eleven times', () => { assert.strictEqual(log.counts.on, 11) 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]) assert.strictEqual(log.these.on[10], 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]) })
test('EventEmitter.on was called correctly eleventh time', () => { assert.lengthOf(log.args.on[10], 2) assert.strictEqual(log.args.on[10][0], 'err-data') assert.isFunction(log.args.on[10][1]) assert.strictEqual(log.args.on[10][1], log.args.on[9][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 eleven times', () => { assert.strictEqual(log.counts.on, 11) })
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 twelve times', () => { assert.strictEqual(log.counts.on, 12) assert.strictEqual(log.these.on[11], results.walk[0]) })
test('EventEmitter.on was called correctly first eleven 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') assert.strictEqual(log.args.on[10][0], 'err-data') })
test('EventEmitter.on was called correctly twelfth time', () => { assert.lengthOf(log.args.on[11], 2) assert.strictEqual(log.args.on[11][0], 'end-line') assert.isFunction(log.args.on[11][1]) assert.notStrictEqual(log.args.on[11][1], log.args.on[0][1]) assert.notStrictEqual(log.args.on[11][1], log.args.on[1][1]) assert.notStrictEqual(log.args.on[11][1], log.args.on[2][1]) assert.notStrictEqual(log.args.on[11][1], log.args.on[3][1]) assert.notStrictEqual(log.args.on[11][1], log.args.on[6][1]) assert.notStrictEqual(log.args.on[11][1], log.args.on[8][1]) assert.notStrictEqual(log.args.on[11][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[11][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 twelve times', () => { assert.strictEqual(log.counts.on, 24) })
test('walk was not called', () => { assert.strictEqual(log.counts.walk, 1) })
suite('string, end:', () => { setup(done => { log.args.on[15][1]('foo') log.args.on[20][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 twelve times', () => { assert.strictEqual(log.counts.on, 36) })
test('walk was not called', () => { assert.strictEqual(log.counts.walk, 1) })
suite('end:', () => { setup(done => { log.args.on[32][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 twelve times', () => { assert.strictEqual(log.counts.on, 24) })
test('walk was called once', () => { assert.strictEqual(log.counts.walk, 2) }) }) }) }) }) })
|