rttc
Version:
Runtime type-checking for JavaScript.
690 lines (565 loc) • 31.3 kB
JavaScript
// ██████╗ ████████╗████████╗ ██████╗ ███████╗██████╗ ███████╗ ██████╗
// ██╔══██╗╚══██╔══╝╚══██╔══╝██╔════╝ ██╔════╝██╔══██╗██╔════╝██╔════╝ ██╗██╗
// ██████╔╝ ██║ ██║ ██║ ███████╗██████╔╝█████╗ ██║ ╚═╝╚═╝
// ██╔══██╗ ██║ ██║ ██║ ╚════██║██╔═══╝ ██╔══╝ ██║ ██╗██╗
// ██║ ██║ ██║ ██║ ╚██████╗ ███████║██║ ███████╗╚██████╗ ╚═╝╚═╝
// ╚═╝ ╚═╝ ╚═╝ ╚═╝ ╚═════╝ ╚══════╝╚═╝ ╚══════╝ ╚═════╝
//
// ██╗ ██╗ █████╗ ██╗ ██╗██████╗ █████╗ ████████╗██╗ ██████╗ ███╗ ██╗
// ██║ ██║██╔══██╗██║ ██║██╔══██╗██╔══██╗╚══██╔══╝██║██╔═══██╗████╗ ██║
// ██║ ██║███████║██║ ██║██║ ██║███████║ ██║ ██║██║ ██║██╔██╗ ██║
// ╚██╗ ██╔╝██╔══██║██║ ██║██║ ██║██╔══██║ ██║ ██║██║ ██║██║╚██╗██║
// ╚████╔╝ ██║ ██║███████╗██║██████╔╝██║ ██║ ██║ ██║╚██████╔╝██║ ╚████║
// ╚═══╝ ╚═╝ ╚═╝╚══════╝╚═╝╚═════╝ ╚═╝ ╚═╝ ╚═╝ ╚═╝ ╚═════╝ ╚═╝ ╚═══╝
//
// Export the array of tests below
module.exports = [
////////////////////////////////////////////
// STRINGS
////////////////////////////////////////////
{ example: 'foo', actual: 'bar', result: 'bar' },
{ example: 'foo', actual: '', result: '' },
{ example: 'foo', actual: 0, result: '0' },
{ example: 'foo', actual: 1, result: '1' },
{ example: 'foo', actual: -1.1, result: '-1.1' },
{ example: 'foo', actual: -0, result: '0' },
{ example: 'foo', actual: +0, result: '0' },
{ example: 'foo', actual: true, result: 'true' },
{ example: 'foo', actual: false, result: 'false' },
{ example: 'foo', actual: {}, error: true },
{ example: 'foo', actual: {foo:'bar'}, error: true },
{ example: 'foo', actual: {foo:{bar:{baz:{}}}}, error: true },
{ example: 'foo', actual: {foo:['bar']}, error: true },
{ example: 'foo', actual: {foo:{bar:{baz:[{}]}}}, error: true },
{ example: 'foo', actual: [], error: true },
{ example: 'foo', actual: ['asdf'], error: true },
{ example: 'foo', actual: [''], error: true },
{ example: 'foo', actual: [235], error: true },
{ example: 'foo', actual: [false], error: true },
{ example: 'foo', actual: [{}], error: true },
{ example: 'foo', actual: [{foo:'bar'}], error: true },
{ example: 'foo', actual: undefined, error: true },
{ example: 'foo', actual: NaN, error: true },
{ example: 'foo', actual: Infinity, error: true },
{ example: 'foo', actual: -Infinity, error: true },
{ example: 'foo', actual: null, error: true },
{ example: 'foo', actual: /some regexp/, error: true },
{ example: 'foo', actual: function(){}, error: true },
{ example: 'foo', actual: new Date('November 5, 1605 GMT'), result: '1605-11-05T00:00:00.000Z' },
{ example: 'foo', actual: new (require('stream').Readable)(), error: true },
{ example: 'foo', actual: new Buffer('asdf'), error: true },
{ example: 'foo', actual: new Error('asdf'), error: true },
////////////////////////////////////////////
// NUMBERS
////////////////////////////////////////////
{ example: 123, actual: 'bar', error: true },
{ example: 123, actual: '', error: true },
{ example: 123, actual: '0', result: 0 },
{ example: 123, actual: '1', result: 1 },
{ example: 123, actual: '-1.1', result: -1.1 },
{ example: 123, actual: 'NaN', error: true },
{ example: 123, actual: 'undefined', error: true },
{ example: 123, actual: 'null', error: true },
{ example: 123, actual: '-Infinity', error: true },
{ example: 123, actual: 'Infinity', error: true },
{ example: 123, actual: 0, result: 0 },
{ example: 123, actual: 1, result: 1 },
{ example: 123, actual: -1.1, result: -1.1 },
{ example: 123, actual: -0, result: 0 },
{ example: 123, actual: +0, result: 0 },
{ example: 123, actual: true, result: 1 },
{ example: 123, actual: false, result: 0 },
{ example: 123, actual: {}, error: true },
{ example: 123, actual: {foo:'bar'}, error: true },
{ example: 123, actual: {foo:{bar:{baz:{}}}}, error: true },
{ example: 123, actual: {foo:['bar']}, error: true },
{ example: 123, actual: {foo:{bar:{baz:[{}]}}}, error: true },
{ example: 123, actual: [], error: true },
{ example: 123, actual: ['asdf'], error: true },
{ example: 123, actual: [''], error: true },
{ example: 123, actual: [235], error: true },
{ example: 123, actual: [false], error: true },
{ example: 123, actual: [{}], error: true },
{ example: 123, actual: [{foo:'bar'}], error: true },
{ example: 123, actual: undefined, error: true },
{ example: 123, actual: NaN, error: true },
{ example: 123, actual: Infinity, error: true },
{ example: 123, actual: -Infinity, error: true },
{ example: 123, actual: null, error: true },
{ example: 123, actual: /some regexp/, error: true },
{ example: 123, actual: function(){}, error: true },
{ example: 123, actual: new Date('November 5, 1605 GMT'), result: -11491632000000 },
{ example: 123, actual: new (require('stream').Readable)(), error: true },
{ example: 123, actual: new Buffer('asdf'), error: true },
{ example: 123, actual: new Error('asdf'), error: true },
////////////////////////////////////////////
// BOOLEANS
////////////////////////////////////////////
{ example: true, actual: 'bar', error: true },
{ example: true, actual: '', error: true },
{ example: true, actual: '-1.1', error: true },
{ example: true, actual: 'NaN', error: true },
{ example: true, actual: 'undefined', error: true },
{ example: true, actual: 'null', error: true },
{ example: true, actual: '-Infinity', error: true },
{ example: true, actual: 'Infinity', error: true },
{ example: true, actual: 'true', result: true },
{ example: true, actual: 'false', result: false },
{ example: true, actual: '0', result: false },
{ example: true, actual: '1', result: true },
{ example: true, actual: 0, result: false },
{ example: true, actual: 1, result: true },
{ example: true, actual: -1.1, error: true },
{ example: true, actual: -0, result: false },
{ example: true, actual: +0, result: false },
{ example: true, actual: true, result: true },
{ example: true, actual: false, result: false },
{ example: true, actual: {}, error: true },
{ example: true, actual: {foo:'bar'}, error: true },
{ example: true, actual: {foo:{bar:{baz:{}}}}, error: true },
{ example: true, actual: {foo:['bar']}, error: true },
{ example: true, actual: {foo:{bar:{baz:[{}]}}}, error: true },
{ example: true, actual: [], error: true },
{ example: true, actual: ['asdf'], error: true },
{ example: true, actual: [''], error: true },
{ example: true, actual: [235], error: true },
{ example: true, actual: [false], error: true },
{ example: true, actual: [{}], error: true },
{ example: true, actual: [{foo:'bar'}], error: true },
{ example: true, actual: undefined, error: true },
{ example: true, actual: NaN, error: true },
{ example: true, actual: Infinity, error: true },
{ example: true, actual: -Infinity, error: true },
{ example: true, actual: null, error: true },
{ example: true, actual: /some regexp/, error: true },
{ example: true, actual: function(){}, error: true },
{ example: true, actual: new Date('November 5, 1605 GMT'), error: true },
{ example: true, actual: new (require('stream').Readable)(), error: true },
{ example: true, actual: new Buffer('asdf'), error: true },
{ example: true, actual: new Error('asdf'), error: true },
////////////////////////////////////////////
// DICTIONARIES (json-serializable, except `null` not allowed)
////////////////////////////////////////////
{ example: {}, actual: 'bar', error: true },
{ example: {}, actual: 123, error: true },
{ example: {}, actual: true, error: true },
{ example: {}, actual: {}, result: {} },
{ example: {}, actual: {foo:'bar'}, result: {foo:'bar'} },
{ example: {}, actual: {foo:{bar:{baz:{}}}}, result: {foo:{bar:{baz:{}}}} },
{ example: {}, actual: {foo:['bar']}, result: {foo:['bar']} },
{ example: {}, actual: {foo:{bar:{baz:[{}]}}}, result: {foo:{bar:{baz:[{}]}}} },
{ example: {}, actual: [], error: true },
{ example: {}, actual: ['asdf'], error: true },
{ example: {}, actual: [''], error: true },
{ example: {}, actual: [235], error: true },
{ example: {}, actual: [false], error: true },
{ example: {}, actual: [{}], error: true },
{ example: {}, actual: [{foo:'bar'}], error: true },
{ example: {}, actual: undefined, error: true },
{ example: {}, actual: NaN, error: true },
{ example: {}, actual: Infinity, error: true },
{ example: {}, actual: -Infinity, error: true },
{ example: {}, actual: null, error: true },
{ example: {}, actual: /some regexp/, error: true },
{ example: {}, actual: function(){}, error: true },
{ example: {}, actual: new Date('November 5, 1605 GMT'), error: true },
// Note that the enumerable properties for Streams vary between Node.js versions.
{ example: {}, actual: new (require('stream').Readable)(), error: true },
// Note that the enumerable properties for Buffers vary between Node.js versions.
{ example: {}, actual: new Buffer('asdf'), error: true },
{ example: {}, actual: new Error('asdf'), error: true },
////////////////////////////////////////////
// ARRAYS (json-serializable, except `null` not allowed)
// (all of the tests below pass w/ [], not necessarily ['==='])
////////////////////////////////////////////
{ example: [], actual: 'bar', error: true },
{ example: [], actual: 123, error: true },
{ example: [], actual: true, error: true },
{ example: [], actual: {}, error: true },
{ example: [], actual: {foo:'bar'}, error: true },
{ example: [], actual: {foo:{bar:{baz:{}}}}, error: true },
{ example: [], actual: {foo:['bar']}, error: true },
{ example: [], actual: {foo:{bar:{baz:[{}]}}}, error: true },
{ example: [], actual: [], result: [] },
{ example: [], actual: ['asdf'], result: ['asdf'] },
{ example: [], actual: [''], result: [''] },
{ example: [], actual: [235], result: [235] },
{ example: [], actual: [false], result: [false] },
{ example: [], actual: [{}], result: [{}] },
{ example: [], actual: [{foo:'bar'}], result: [{foo: 'bar'}] },
{ example: [], actual: undefined, error: true },
{ example: [], actual: NaN, error: true },
{ example: [], actual: Infinity, error: true },
{ example: [], actual: -Infinity, error: true },
{ example: [], actual: null, error: true },
{ example: [], actual: /some regexp/, error: true },
{ example: [], actual: function(){}, error: true },
{ example: [], actual: new Date('November 5, 1605 GMT'), error: true },
{ example: [], actual: new (require('stream').Readable)(), error: true }, // TODO: consider enhancing this behavior to concat the stream contents? Needs community discussion.
// Skip Buffer tests for now since the enumerable properties vary between Node.js versions.
// { example: [], actual: new Buffer('asdf'), result: [ 97, 115, 100, 102 ] },
// Note: we could bring back support for this by explicitly filtering properties of buffers in `.exec()`
// TODO: but actually, this should cause an error- use `example: '==='` for things like this.
{ example: [], actual: new Error('asdf'), error: true },
//////////////////////////////////////////////////////
// nested contents of `example: []` and `example: {}`
//////////////////////////////////////////////////////
// Follow JSON-serialization rules for nested objects within `example: []` and `example: {}`
// with the following exceptions:
// • convert Error instances to their `.stack` property (a string)
// • convert RegExp instances to a string
// • convert functions to a string
// • after doing the rest of the things, prune undefined/null items
// • after doing the rest of the things, strip keys w/ undefined/null values
{ example: {}, actual: { x: undefined }, result: {} },
{ example: {}, actual: { x: NaN }, result: {x:0} },
{ example: {}, actual: { x: Infinity }, result: {x:0} },
{ example: {}, actual: { x: -Infinity }, result: {x:0} },
{ example: {}, actual: { x: null }, result: {x: null} },
{ example: {}, actual: { x: function foo(a,b){return a+' '+b;} }, result: { x: 'function foo(a,b){return a+\' \'+b;}' } },
// { example: {}, actual: { x: undefined, null, NaN, -Infinity, Infinity, function(){} }, result: [] },
{ example: {}, actual: { x: /some regexp/ig }, result: {x:'/some regexp/gi' }},
{ example: {}, actual: { x: new Date('November 5, 1605 GMT') }, result: {x: '1605-11-05T00:00:00.000Z'} },
// Skip Readable stream tests for now since the enumerable properties vary between Node.js versions.
// { example: {}, actual: { x: new (require('stream').Readable)() }, result: { x: { _readableState: {},readable: true,_events: {},_maxListeners: 10 } } },
// Skip Buffer stream tests for now since the enumerable properties vary between Node.js versions.
// { example: {}, actual: { x: new Buffer('asdf') } , result: {x: {}} },
(function (){
// Hard-code a fake `.stack` to avoid differences between computers that would cause tests to fail
var e = new Error('asdf');
e.stack = 'fake_error';
return { example: {}, actual: { x: e }, result: {x:'fake_error'} };
})(),
{ example: [], actual: [undefined], result: [] },
{ example: [], actual: [null], result: [null] },
{ example: [], actual: [NaN], result: [0] },
{ example: [], actual: [Infinity], result: [0] },
{ example: [], actual: [-Infinity], result: [0] },
{ example: [], actual: [function foo(a,b){return a+' '+b;}], result: ['function foo(a,b){return a+\' \'+b;}'] },
{ example: [], actual: [/some regexp/gi], result: ['/some regexp/gi'] },
{ example: [], actual: [new Date('November 5, 1605 GMT')], result: ['1605-11-05T00:00:00.000Z'] },
// Skip Readable stream tests for now since the enumerable properties vary between Node.js versions.
// { example: [], actual: [new (require('stream').Readable)()], result: [ { _readableState: {},readable: true,_events: {},_maxListeners: 10 }] },
// Skip Buffer stream tests for now since the enumerable properties vary between Node.js versions.
// { example: [], actual: [new Buffer('asdf')], result: [{}] },
(function (){
var e = new Error('asdf');
e.stack = 'fake_error';
return { example: [], actual: [e], result: ['fake_error'] };
})(),
////////////////////////////////////////////
// example: '*' (any JSON-serializable value)
////////////////////////////////////////////
{ example: '*', actual: 'bar', result: 'bar', },
{ example: '*', actual: '', result: '', },
{ example: '*', actual: '-1.1', result: '-1.1', },
{ example: '*', actual: 'NaN', result: 'NaN', },
{ example: '*', actual: 'undefined', result: 'undefined', },
{ example: '*', actual: 'null', result: 'null', },
{ example: '*', actual: '-Infinity', result: '-Infinity', },
{ example: '*', actual: 'Infinity', result: 'Infinity', },
{ example: '*', actual: 'true', result: 'true', },
{ example: '*', actual: 'false', result: 'false', },
{ example: '*', actual: '0', result: '0', },
{ example: '*', actual: '1', result: '1', },
{ example: '*', actual: -0, result: 0, },
{ example: '*', actual: +0, result: 0, },
{ example: '*', actual: 0, result: 0, },
{ example: '*', actual: 1, result: 1, },
{ example: '*', actual: -1.1, result: -1.1, },
{ example: '*', actual: true, result: true, },
{ example: '*', actual: false, result: false, },
{ example: '*', actual: {}, result: {}, },
{ example: '*', actual: {foo:'bar'}, result: {foo:'bar'}, },
{ example: '*', actual: {foo:{bar:{baz:{}}}}, result: {foo:{bar:{baz:{}}}}, },
{ example: '*', actual: {foo:['bar']}, result: {foo:['bar']}, },
{ example: '*', actual: {foo:{bar:{baz:[{}]}}}, result: {foo:{bar:{baz:[{}]}}}, },
{ example: '*', actual: [], result: [], },
{ example: '*', actual: ['asdf'], result: ['asdf'], },
{ example: '*', actual: [''], result: [''], },
{ example: '*', actual: [235], result: [235], },
{ example: '*', actual: [false], result: [false], },
{ example: '*', actual: [{}], result: [{}], },
{ example: '*', actual: [{foo:'bar'}], result: [{foo:'bar'}], },
{ example: '*', actual: undefined, error: true, },
{ example: '*', actual: NaN, result: 0 },
{ example: '*', actual: Infinity, result: 0 },
{ example: '*', actual: -Infinity, result: 0 },
{ example: '*', actual: null, result: null, },
{ example: '*', actual: /some regexp/gi, result: '/some regexp/gi' },
{ example: '*', actual: new Date('November 5, 1605 GMT'), result: '1605-11-05T00:00:00.000Z' },
{ example: '*', actual: (function(){var err=new Error();err.stack='test';return err;})(), result: 'test' },
{ example: '*', actual: function(){}, result: 'function (){}' },
{ example: '*', actual: new (require('stream').Readable)(), error: true },
////////////////////////////////////////////
// RECURSIVE OBJECTS
////////////////////////////////////////////
// Missing keys (general case)
{ example: {a:1, b:'hi', c: false}, actual: {a: 11}, error: true },
{ example: {a:1, b:'hi', c: false}, actual: {a: 23, b: undefined, c: undefined}, error: true },
{ example: {a:1}, actual: {a: undefined}, error: true },
{ example: {a:1}, actual: {}, error: true },
// Missing keys (`===` case)
{ example: {a:'==='}, actual: {a: undefined}, error: true },
{ example: {a:'==='}, actual: {}, error: true },
// Strip keys with `undefined` values (`{}` case)
{ example: {}, actual: {a: undefined, b: 3}, result: {b: 3} },
{ example: [{}], actual: [{a: undefined, b: 3}], result: [{b: 3}] },
{ example: {x:{}}, actual: {x:{a: undefined, b: 3}}, result: {x:{b: 3}} },
// Don't strip keys with `undefined` values (`===` case)
{ example: '===', actual: {a: undefined, b: 3}, result: {a: undefined, b: 3} },
// Extra keys:
{ example: {a:1, b:'hi'}, actual: {a: 23, b: 'stuff', d: true}, result: {a: 23, b: 'stuff'} },
{ example: {a:1, b:'hi'}, actual: {a: 23, b: 'stuff', d: undefined}, result: {a: 23, b: 'stuff'} },
////////////////////////////////////////////
// example: ===
////////////////////////////////////////////
{ example: '===', actual: 'bar', result: 'bar', },
{ example: '===', actual: '', result: '', },
{ example: '===', actual: '-1.1', result: '-1.1', },
{ example: '===', actual: 'NaN', result: 'NaN', },
{ example: '===', actual: 'undefined', result: 'undefined', },
{ example: '===', actual: 'null', result: 'null', },
{ example: '===', actual: '-Infinity', result: '-Infinity', },
{ example: '===', actual: 'Infinity', result: 'Infinity', },
{ example: '===', actual: 'true', result: 'true', },
{ example: '===', actual: 'false', result: 'false', },
{ example: '===', actual: '0', result: '0', },
{ example: '===', actual: '1', result: '1', },
{ example: '===', actual: -0, result: -0, },
{ example: '===', actual: +0, result: +0, },
{ example: '===', actual: 0, result: 0, },
{ example: '===', actual: 1, result: 1, },
{ example: '===', actual: -1.1, result: -1.1, },
{ example: '===', actual: true, result: true, },
{ example: '===', actual: false, result: false, },
{ example: '===', actual: {}, result: {}, },
{ example: '===', actual: {foo:'bar'}, result: {foo:'bar'}, },
{ example: '===', actual: {foo:{bar:{baz:{}}}}, result: {foo:{bar:{baz:{}}}}, },
{ example: '===', actual: {foo:['bar']}, result: {foo:['bar']}, },
{ example: '===', actual: {foo:{bar:{baz:[{}]}}}, result: {foo:{bar:{baz:[{}]}}}, },
{ example: '===', actual: [], result: [], },
{ example: '===', actual: ['asdf'], result: ['asdf'], },
{ example: '===', actual: [''], result: [''], },
{ example: '===', actual: [235], result: [235], },
{ example: '===', actual: [false], result: [false], },
{ example: '===', actual: [{}], result: [{}], },
{ example: '===', actual: [{foo:'bar'}], result: [{foo:'bar'}], },
{ example: '===', actual: undefined, error: true },
{ example: '===', actual: NaN, result: NaN, },
{ example: '===', actual: Infinity, result: Infinity, },
{ example: '===', actual: -Infinity, result: -Infinity, },
{ example: '===', actual: null, result: null, },
////////////////////////////////////////////
// example: '->'
////////////////////////////////////////////
{ example: '->', actual: 'bar', error: true },
{ example: '->', actual: '', error: true },
{ example: '->', actual: '-1.1', error: true },
{ example: '->', actual: 'NaN', error: true },
{ example: '->', actual: 'undefined', error: true },
{ example: '->', actual: 'null', error: true },
{ example: '->', actual: '-Infinity', error: true },
{ example: '->', actual: 'Infinity', error: true },
{ example: '->', actual: 'true', error: true },
{ example: '->', actual: 'false', error: true },
{ example: '->', actual: '0', error: true },
{ example: '->', actual: '1', error: true },
{ example: '->', actual: -0, error: true },
{ example: '->', actual: +0, error: true },
{ example: '->', actual: 0, error: true },
{ example: '->', actual: 1, error: true },
{ example: '->', actual: -1.1, error: true },
{ example: '->', actual: true, error: true },
{ example: '->', actual: false, error: true },
{ example: '->', actual: {}, error: true },
{ example: '->', actual: {foo:'bar'}, error: true },
{ example: '->', actual: {foo:{bar:{baz:{}}}}, error: true },
{ example: '->', actual: {foo:['bar']}, error: true },
{ example: '->', actual: {foo:{bar:{baz:[{}]}}}, error: true },
{ example: '->', actual: [], error: true },
{ example: '->', actual: ['asdf'], error: true },
{ example: '->', actual: [''], error: true },
{ example: '->', actual: [235], error: true },
{ example: '->', actual: [false], error: true },
{ example: '->', actual: [{}], error: true },
{ example: '->', actual: [{foo:'bar'}], error: true },
{ example: '->', actual: undefined, error: true },
{ example: '->', actual: NaN, error: true },
{ example: '->', actual: Infinity, error: true },
{ example: '->', actual: -Infinity, error: true },
{ example: '->', actual: null, error: true },
{ example: '->', actual: function (inputs, exits){return exits.success();}, result: function (inputs, exits){return exits.success();} },
// $$\
// \__|
// $$$$$$\ $$$$$$\ $$$$$$$\ $$\ $$\ $$$$$$\ $$$$$$$\ $$\ $$\ $$\ $$$$$$\
// $$ __$$\ $$ __$$\ $$ _____|$$ | $$ |$$ __$$\ $$ _____|$$ |\$$\ $$ |$$ __$$\
// $$ | \__|$$$$$$$$ |$$ / $$ | $$ |$$ | \__|\$$$$$$\ $$ | \$$\$$ / $$$$$$$$ |
// $$ | $$ ____|$$ | $$ | $$ |$$ | \____$$\ $$ | \$$$ / $$ ____|
// $$ | \$$$$$$$\ \$$$$$$$\ \$$$$$$ |$$ | $$$$$$$ |$$ | \$ / \$$$$$$$\
// \__| \_______| \_______| \______/ \__| \_______/ \__| \_/ \_______|
//
//
//
// Some basic deep dicts and array
{
example: {a:1, b:'hi', c: false},
actual: {a: 23},
error: true
},
{
example: {a:1, b:'hi', c: false},
actual: {a: 23, d: true},
error: true
},
// Ensure that this allows extra keys when coercing to `example: {}`
{
example: {},
actual: {a: 23, d: true},
result: {a: 23, d: true}
},
// Omit extra keys when coercing to `example: {...}`
{
example: { a:23 },
actual: {a: 23, d: true},
result: {a: 23}
},
// Reject when there are missing or undefined required keys
{ example: {b: 235}, actual: {b: undefined}, error: true },
{ example: {b: 235}, actual: {}, error: true },
// Strip extra keys with `undefined` values (`{...}` case)
{ example: {b: 235}, actual: {a: undefined, b: 3}, result: {b: 3} },
// Strip extra nested keys with `undefined` values (`{...}` case)
{ example: {a: {}, b: 235}, actual: {a: {x: undefined}, b: 3}, result: {a: {}, b: 3} },
// Strip keys with `undefined` values (`{}` case)
{ example: {}, actual: {a: undefined, b: 3}, result: {b: 3} },
// Strip nested keys with `undefined` values (`{}` case)
{ example: {}, actual: {a: {x: undefined}, b: 3}, result: {a: {}, b: 3} },
// Don't strip keys or nested keys with `undefined` values (`===` and nested `===` cases)
{ example: '===', actual: {a: undefined, b: 3, c: {x: undefined}}, result: {a: undefined, b: 3, c: {x: undefined}} },
{ example: {c:'==='}, actual: {a: undefined, b: 3, c: {x: undefined}}, result: { c: {x: undefined}} },
// Ensure that this allows arbitary arrays when coercing to `example: []`
{
example: [],
actual: [{a: 23, d: true}],
result: [{a: 23, d: true}]
},
// Ensure that nested dictionaries inside of an array passed
// through `example: []` are stripped of keys with undefined values
{
example: [],
actual: [{a:3, b: undefined}, {a: undefined}],
result: [{a: 3},{}]
},
{
example: [],
actual: [{a:3,someStuff: [{x: undefined, y: 'foo'}, {x: 'bar', y: undefined}]},{a: 5, b: undefined}],
result: [{a: 3, someStuff: [{y:'foo'}, {x:'bar'}]}, {a: 5}]
},
// Prune `undefined` items from arrays and nested arrays (`[]` case)
{
example: [],
actual: [{a:3}, undefined, {a: 5}, undefined, {a: 7}, {a:9, b: [undefined, 9,2,4,undefined,8]}],
result: [{a: 3}, {a: 5}, {a:7}, {a:9, b:[9,2,4,8]}]
},
// DO allow `undefined` items from arrays and nested arrays (`===` case)
{
example: '===',
actual: [{a:3}, undefined, {a: 5}, undefined, {a: 7}, {a:9, b: [undefined, 9,2,4,undefined,8]}],
result: [{a:3}, undefined, {a: 5}, undefined, {a: 7}, {a:9, b: [undefined, 9,2,4,undefined,8]}]
},
// Don't allow `undefined` items from arrays and nested arrays (`[===]` case)
// (because '===' does not allow `undefined`)
{
example: ['==='],
actual: [{a:3}, undefined, {a: 5}, undefined, {a: 7}, {a:9, b: [undefined, 9,2,4,undefined,8]}],
result: [{a:3}, {a: 5}, {a: 7}, {a:9, b: [undefined, 9,2,4,undefined,8]}]
},
// Ensure that nested dictionaries inside of an array passed
// through `example: ['===']` are NOT stripped of keys with undefined values--
// and are left utterly alone
{
example: ['==='],
actual: [{a:3, b: undefined}, {a: undefined}],
result: [{a: 3, b: undefined},{a:undefined}]
},
{
example: ['==='],
actual: [{a:3,someStuff: [{x: undefined, y: 'foo'}, {x: 'bar', y: undefined}]},{a: 5, b: undefined}],
result: [{a:3,someStuff: [{x: undefined, y: 'foo'}, {x: 'bar', y: undefined}]},{a: 5, b: undefined}]
},
// Ensure the recursive cloning / undefined-key-stripping doesn't get
// stumped by circular dictionaries/arrays.
// • dict keys whose values point to a past reference should be deleted
// • array items that point to past references should be pruned
(function (){
var someDict = {};
var someArray = [];
someDict.x = {z: someDict, foo: undefined};
someDict.y = someArray;
someArray.push(someDict);
someArray.push(someDict.x);
var test = {
example: {},
actual: {
someDict: someDict,
someArray: someArray
},
result: {
someDict: {
x: {
z: '[Circular ~.someDict]'
},
y: [
'[Circular ~.someDict]',
{
z: '[Circular ~.someDict]'
}
]
},
someArray: [
{
x: {
z: '[Circular ~.someArray.0]'
},
y: '[Circular ~.someArray]'
},
{
z: {
x: '[Circular ~.someArray.1]',
y: '[Circular ~.someArray]'
}
}
]
}
};
return test;
})(),
{
example: [{}],
actual: [ { name: 'Lucy' }, { name: 'Ricky' }, { name: 'Louise' }, { name: 'Estelle' } ],
expected: [ { name: 'Lucy' }, { name: 'Ricky' }, { name: 'Louise' }, { name: 'Estelle' } ]
},
// $$\ $$\ $$\ $$$\ $$$\
// $$ | \__| $$ | $$ _| \$$\
// $$$$$$$\ $$$$$$\ $$$$$$\ $$\ $$$$$$$\ $$$$$$\ $$$$$$\ $$$$$$\ $$ /$$$$\ $$$$\ $$$$\ \$$\
// $$ _____|\_$$ _| $$ __$$\ $$ |$$ _____|\_$$ _| $$ __$$\ $$ __$$\ $$ | \____|\____|\____| $$ |
// \$$$$$$\ $$ | $$ | \__|$$ |$$ / $$ | $$$$$$$$ |$$ / $$ | $$ | $$$$\ $$$$\ $$$$\ $$ |
// \____$$\ $$ |$$\ $$ | $$ |$$ | $$ |$$\ $$ ____|$$ | $$ | \$$\ \____|\____|\____|$$ |
// $$$$$$$ | \$$$$ |$$ | $$ |\$$$$$$$\ \$$$$ | \$$$$$$$\ \$$$$$$$ | \$$$\ $$$ /
// \_______/ \____/ \__| \__| \_______| \____/ \_______| \____$$ | \___| \___/
// $$ |
// $$ |
// \__|
//
// (strictEq / isNew checks to assert for and
// against passing-by-reference in different
// situations)
////////////////////////////////////////////////
{ example: '===', actual: /some regexp/, strictEq: true },
{ example: '===', actual: function (){}, strictEq: true },
{ example: '===', actual: new Date('November 5, 1605 GMT'), strictEq: true },
{ example: '===', actual: new (require('stream').Readable)(), strictEq: true },
{ example: '===', actual: new Buffer('asdf'), strictEq: true },
{ example: '===', actual: new Error('asdf'), strictEq: true },
];