types.js/test.js

332 lines
7.4 KiB
JavaScript
Raw Normal View History

#!/usr/bin/env node
/**********************************************************************
*
*
*
**********************************************/ /* c8 ignore next 2 */
((typeof define)[0]=='u'?function(f){module.exports=f(require)}:define)
(function(require){ var module={} // make module AMD/node compatible...
/*********************************************************************/
var colors = require('colors')
var test = require('ig-test')
var object = require('ig-object')
var types = require('./main')
var containers = require('./containers')
//---------------------------------------------------------------------
/*
var setups = test.Setups({
})
var modifiers = test.Modifiers({
})
var tests = test.Tests({
})
//*/
var cases = test.Cases({
// Object.js
//
Object: function(assert){
var o = Object.assign(
Object.create({
x: 111,
y: 222,
}), {
y: 333,
z: 444,
})
var oo = assert(Object.flatCopy(o), 'Object.flatCopy(..)')
assert(Object.match(oo, {x: 111, y: 333, z: 444}), 'Object.match(..)')
var k = ['z', 'x', 'y']
assert(Object.keys(Object.sort(oo, k)).cmp(k), 'Object.sort(,,)')
assert(Object.keys(Object.sort(oo)).cmp(k.slice().sort()), 'Object.sort(,,)')
var cmp = function(a, b){
return a == 'y' ?
1
: a == 'z' ?
-1
: 0 }
assert(Object.keys(Object.sort(oo, cmp)).cmp(k.slice().sort(cmp)), 'Object.sort(,,)')
},
// Array.js
// - flat (???)
// - includes (???)
// - first
// - last
// - compact
// - len
// - unique
// - tailUnique
// - cmp
// - setCmp
// - sortAs
// - mapChunks
// - filterChunks
// - reduceChunks
// - toKeys
// - toMap
Array: function(assert){
},
// Set.js
// - unite
// - intersect
// - subtract
// - sort
Set: function(assert){
},
// Map.js
// - sort
Map: function(assert){
},
String: function(assert){
assert(''.capitalize() == '')
assert('a'.capitalize() == 'A')
assert('abc'.capitalize() == 'Abc')
},
RegExp: function(assert){
},
Promise: function(assert){
var p = assert(Promise.cooperative())
assert(!p.isSet, '.isSet is false')
var RESOLVE = 123
var then
p.then(function(v){
console.log('then')
then = RESOLVE })
assert(!p.isSet, '.isSet is false')
var fin
p.finally(function(){
console.log('finally')
fin = true })
assert(!p.isSet, '.isSet is false')
// XXX for some reason this does not resolve p...
p.set(123)
assert(p.isSet, '.isSet')
assert(then == RESOLVE, '.then(..)')
assert(fin, '.finally(..)')
},
// Date.js
Date: function(assert){
var d = new Date()
var ts = assert(d.getTimeStamp(), '.getTimeStamp()')
var tsm = assert(d.getTimeStamp(true), '.getTimeStamp(true)')
var dd = assert(Date.fromTimeStamp(tsm), '.fromTimeStamp(..)')
var dds = assert(Date.fromTimeStamp(ts), '.fromTimeStamp(..)')
assert(d.toString() == dd.toString(), 'timestamp reversable')
assert(d.toShortDate() == dd.toShortDate(), '.toShortDate()')
assert(d.toShortDate() == dds.toShortDate(), '.toShortDate()')
assert(d.toShortDate(true) == dd.toShortDate(true), '.toShortDate(true)')
var a = Date.timeStamp()
var b = Date.timeStamp(true)
assert(a == Date.fromTimeStamp(a).getTimeStamp())
assert(a + '000' == Date.fromTimeStamp(a).getTimeStamp(true))
assert(b == Date.fromTimeStamp(b).getTimeStamp(true))
assert(Date.str2ms('1') == 1, 'Date.str2ms("1")')
assert(Date.str2ms(1) == 1, 'Date.str2ms(1)')
assert(Date.str2ms('1ms') == 1, 'Date.str2ms("1ms")')
assert(Date.str2ms('1s') == 1000, 'Date.str2ms("1s")')
assert(Date.str2ms('1m') == 60*1000, 'Date.str2ms("1m")')
assert(Date.str2ms('1h') == 60*60*1000, 'Date.str2ms("1h")')
assert(Date.str2ms('1d') == 24*60*60*1000, 'Date.str2ms("1d")')
assert(Date.str2ms('5 sec') == 5000, 'Date.str2ms("1 sec")')
assert(Date.str2ms('5 second') == 5000, 'Date.str2ms("1 second")')
assert(Date.str2ms('5 seconds') == 5000, 'Date.str2ms("1 seconds")')
assert(Date.str2ms('2hour') == 2*60*60*1000, 'Date.str2ms("1hour")')
assert(Date.str2ms('2 Hour') == 2*60*60*1000, 'Date.str2ms("1 Hour")')
assert(Date.str2ms('2 hours') == 2*60*60*1000, 'Date.str2ms("1 hours")')
assert(Number.isNaN(Date.str2ms('moo')), 'Date.str2ms("moo")')
assert(Number.isNaN(Date.str2ms('123 moo')), 'Date.str2ms("moo")')
},
// containers.js
// XXX move this out to a separate test set...
UniqueKeyMap: function(assert){
var a = assert(containers.UniqueKeyMap(), '')
var b = assert(containers.UniqueKeyMap([]), '')
var c = assert(containers.UniqueKeyMap([
['a', 111],
['b', 222],
['a', 333],
]), '')
assert(a.size == 0)
assert(b.size == 0)
assert(c.size == 3)
assert(c.get('a') == 111)
assert(c.has('a (1)'))
assert(c.get('a (1)') == 333)
var n
assert((n = c.set('a', 444, true)) == 'a (2)')
assert(c.get(n) == 444)
assert(c.reset(n, 555))
assert(c.get(n) == 555)
assert(c.delete('a (1)'))
assert(!c.has('a (1)'))
assert((n = c.set('a', 222, true)) == 'a (1)')
assert(c.keysOf(222).sort().cmp(['b', 'a'].sort()))
var k = [...c.keys()]
k[k.indexOf('a')] = 'b (1)'
assert((n = c.rename('a', 'b', true)) == 'b (1)')
// check order...
// XXX since we are using Array's .cmp(..) would be nice to be
// able to fail this test if that fails to test correctly...
// ...not sure how to do this though...
assert(k.cmp([...c.keys()]), '.rename(..) order')
},
})
//---------------------------------------------------------------------
// UniqueKeyMap testing...
var UniqueKeyMap = test.TestSet()
test.Case('UniqueKeyMap-new', UniqueKeyMap)
// XXX
UniqueKeyMap.setups({
empty: function(assert){
return {
value: assert(containers.UniqueKeyMap()),
// metadata...
size: 0,
}},
'empty-input': function(assert){
return {
value: assert(containers.UniqueKeyMap([])),
// metadata...
size: 0,
}},
// XXX non-empty input...
// XXX intersecting unput...
})
// XXX
UniqueKeyMap.modifiers({
set: function(assert, e, k='a', o){
o = o || {}
var n
var exists = e.value.has(k)
var expected = e.value.uniqieKey(k)
assert(n = e.value.set(k, o, true), '.set(..)')
// key update...
assert(n.startsWith(k), 'key prefix')
assert(n == expected, 'unexpected key')
exists
|| assert(n == k, 'key unexpectedly changed')
// size...
e.size += 1
assert(e.value.size == e.size, 'inc size')
return e },
reset: function(assert, e, k='a', o){
o = o || {}
var exists = e.value.has(k)
assert(e.value.reset(k, o))
assert(e.value.get(k) === o)
// size...
exists
|| (e.size += 1)
assert(e.value.size == e.size)
return e },
delete: function(assert, e, k='a'){
var exists = e.value.has(k)
assert(e.value.delete(k) == exists, '.delete(..)')
assert(!e.value.has(k), 'delete successful')
// size...
exists
&& (e.size -= 1)
assert(e.value.size == e.size)
return e },
'set-set': function(assert, e){
this.set(assert, e, 'x')
this.set(assert, e, 'y')
this.set(assert, e, 'x')
return e },
})
// XXX
UniqueKeyMap.tests({
consistent: function(assert, e){
assert(e.value.size == e.size, '.size')
assert([...e.value.keys()].length == e.value.size, '.keys() same size as .size')
return e }
})
//---------------------------------------------------------------------
typeof(__filename) != 'undefined'
&& __filename == (require.main || {}).filename
&& test.run()
/**********************************************************************
* vim:set ts=4 sw=4 : */ return module })