UNPKG

faastjs

Version:

Serverless batch computing made simple.

244 lines 31.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const tslib_1 = require("tslib"); const ava_1 = tslib_1.__importDefault(require("ava")); const serialize_1 = require("../src/serialize"); const shared_1 = require("../src/shared"); const util_1 = require("./fixtures/util"); (0, ava_1.default)("deepCopyUndefined copies undefined properties", t => { const obj = { prop: undefined }; const obj2 = {}; (0, serialize_1.deepCopyUndefined)(obj2, obj); t.deepEqual(obj2, obj); }); (0, ava_1.default)("deepCopyUndefined copies nested undefined properties", t => { const obj = { outer: { inner: undefined } }; const obj2 = { outer: {} }; (0, serialize_1.deepCopyUndefined)(obj2, obj); t.deepEqual(obj2, obj); }); (0, ava_1.default)("deepCopyUndefined should not hang on cyclical references", t => { const obj = { ref: {} }; obj.ref = obj; const obj2 = { ref: {} }; obj2.ref = obj2; (0, serialize_1.deepCopyUndefined)(obj2, obj); t.deepEqual(obj2, obj); }); (0, ava_1.default)("deepCopyUndefined copies symbol properties", t => { const obj = { [Symbol()]: "value" }; const obj2 = {}; (0, serialize_1.deepCopyUndefined)(obj2, obj); t.deepEqual(obj2, obj); }); (0, ava_1.default)("deepCopyUndefined copies symbol values", t => { const obj = { symbolValuedKey: Symbol() }; const obj2 = {}; (0, serialize_1.deepCopyUndefined)(obj2, obj); t.deepEqual(obj2, obj); }); (0, ava_1.default)("deep copy should not fail when objects are not shaped similarly", t => { const obj = { geometry: { theorem: { name: "Pythagorean" } } }; const obj2 = { hypothesis: "Riemann" }; t.notThrows(() => (0, serialize_1.deepCopyUndefined)(obj2, obj)); }); function check(t, values) { const stat = new shared_1.Statistics(); values.forEach(value => stat.update(value)); t.true(Math.abs(stat.mean - (0, util_1.avg)(values)) < 0.000000001); t.true(Math.abs(stat.stdev - (0, util_1.stdev)(values)) < 0.000000001); t.is(stat.samples, values.length); } (0, ava_1.default)("statistics empty values", t => { const emptyStat = new shared_1.Statistics(); t.is(emptyStat.mean, NaN); t.is(emptyStat.stdev, 0); t.is(emptyStat.samples, 0); }); (0, ava_1.default)("statistics single values", t => { check(t, [0]); check(t, [1]); check(t, [-1]); check(t, [0.5]); check(t, [-0.5]); check(t, [0.1]); check(t, [-0.1]); }); (0, ava_1.default)("statistics multiple values", t => { check(t, [0, 1]); check(t, [0, 1, 2]); check(t, [42, 100, 1000]); check(t, [1, 0.1]); check(t, [-0.5, 0.5]); check(t, [-1, 1]); check(t, [3.14159, 2.717]); }); (0, ava_1.default)("statistics random values", t => { const a = []; const b = []; const c = []; for (let i = 0; i < 1000; i++) { a.push(Math.random()); b.push(Math.random() * 10); c.push(Math.random() * 100); } check(t, a); check(t, b); check(t, c); }); (0, ava_1.default)(`statistics clone`, t => { const stats = new shared_1.Statistics(); stats.update(10); stats.update(100); stats.update(5); const cloned = stats.clone(); t.deepEqual(cloned, stats); t.is(cloned.toString(), stats.toString()); cloned.update(42); t.true(cloned.mean !== stats.mean); t.true(cloned.stdev !== stats.stdev); t.is(stats.samples, 3); t.is(cloned.samples, 4); }); (0, ava_1.default)("MaxHeap basics", t => { const h = new shared_1.MaxHeap(); h.insert(5); h.insert(10); h.insert(100); h.insert(1); t.is(h.extractMax(), 100); t.is(h.extractMax(), 10); t.is(h.extractMax(), 5); t.is(h.extractMax(), 1); t.throws(() => h.extractMax(), { message: /empty/ }); }); (0, ava_1.default)("MaxHeap empty", t => { const h = new shared_1.MaxHeap(); t.throws(() => h.extractMax(), { message: /empty/ }); }); (0, ava_1.default)("MaxHeap sorting", t => { const h = new shared_1.MaxHeap(); const N = 10000; const size = 100; for (let attempt = 0; attempt < N; attempt++) { let orig = []; const a = []; for (let i = 0; i < size; i++) { const value = Math.round(Math.random() * 1000); a.push(value); h.insert(value); } orig = a.slice(); a.sort((x, y) => y - x); const b = []; while (h.size > 0) { b.push(h.extractMax()); } t.deepEqual(a, b, `difference sorting ${orig}`); } }); (0, ava_1.default)("MaxHeap specific ordering", t => { const h = new shared_1.MaxHeap(); h.insert(7); h.insert(2); h.insert(0); h.insert(3); h.insert(4); h.insert(1); h.insert(6); h.insert(5); t.is(h.extractMax(), 7); t.is(h.extractMax(), 6); t.is(h.extractMax(), 5); t.is(h.extractMax(), 4); t.is(h.extractMax(), 3); t.is(h.extractMax(), 2); t.is(h.extractMax(), 1); t.is(h.extractMax(), 0); }); (0, ava_1.default)("MaxHeap iterator", t => { const h = new shared_1.MaxHeap(); h.insert(10); h.insert(42); h.insert(12); t.deepEqual([...h], [42, 10, 12]); }); (0, ava_1.default)("SmallestN saves smallest N keys", t => { const s = new shared_1.SmallestN(3); s.update(100); s.update(42); s.update(-1); s.update(0); s.update(4); s.update(1000); t.deepEqual(s.keys().sort(), [-1, 0, 4].sort()); }); (0, ava_1.default)("SmallestN saves smallest N values", t => { const N = 3; const s = new shared_1.SmallestN(N); s.update(100, "100"); s.update(42, "42"); s.update(-1, "-1"); s.update(0, "0"); s.update(4, "4"); s.update(1000, "1000"); t.deepEqual([...s], [ [-1, "-1"], [0, "0"], [4, "4"] ]); }); (0, ava_1.default)("SmallestN duplicate values", t => { const N = 5; const s = new shared_1.SmallestN(N); s.update(88, "88.1"); s.update(88, "88.2"); s.update(88, "88.3"); s.update(42, "42"); s.update(88, "88.4"); s.update(88, "88.5"); s.update(88, "88.6"); s.update(10, "10.1"); s.update(10, "10.2"); s.update(88, "88.7"); s.update(88, "88.8"); t.deepEqual([...s], [ [88, "88.1"], [88, "88.2"], [42, "42"], [10, "10.1"], [10, "10.2"] ]); }); function vals(a) { return a.map(i => [i, undefined]); } (0, ava_1.default)("SmallestN can reduce size", t => { const N = 5; const s = new shared_1.SmallestN(N); s.update(1); s.update(2); s.update(3); s.update(4); s.update(5); s.update(6); s.update(7); s.setSize(3); t.deepEqual([...s], vals([1, 2, 3])); }); (0, ava_1.default)("SmallestN can increase size", t => { const N = 3; const s = new shared_1.SmallestN(N); s.update(1); s.update(2); s.update(3); s.update(4); s.update(5); t.deepEqual([...s], vals([1, 2, 3])); s.setSize(5); s.update(6); s.update(7); s.update(8); t.deepEqual([...s], vals([1, 2, 3, 6, 7])); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unit-shared.test.js","sourceRoot":"","sources":["../../test/unit-shared.test.ts"],"names":[],"mappings":"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","sourcesContent":["import test, { Assertions } from \"ava\";\nimport { deepCopyUndefined } from \"../src/serialize\";\nimport { MaxHeap, SmallestN, Statistics } from \"../src/shared\";\nimport { avg, stdev } from \"./fixtures/util\";\n\ntest(\"deepCopyUndefined copies undefined properties\", t => {\n    const obj = { prop: undefined };\n    const obj2 = {};\n    deepCopyUndefined(obj2, obj);\n    t.deepEqual(obj2, obj);\n});\n\ntest(\"deepCopyUndefined copies nested undefined properties\", t => {\n    const obj = { outer: { inner: undefined } };\n    const obj2 = { outer: {} };\n    deepCopyUndefined(obj2, obj);\n    t.deepEqual(obj2, obj);\n});\n\ntest(\"deepCopyUndefined should not hang on cyclical references\", t => {\n    const obj = { ref: {} };\n    obj.ref = obj;\n\n    const obj2 = { ref: {} };\n    obj2.ref = obj2;\n\n    deepCopyUndefined(obj2, obj);\n    t.deepEqual(obj2, obj);\n});\n\ntest(\"deepCopyUndefined copies symbol properties\", t => {\n    const obj = { [Symbol()]: \"value\" };\n    const obj2 = {};\n    deepCopyUndefined(obj2, obj);\n    t.deepEqual(obj2, obj);\n});\n\ntest(\"deepCopyUndefined copies symbol values\", t => {\n    const obj = { symbolValuedKey: Symbol() };\n    const obj2 = {};\n    deepCopyUndefined(obj2, obj);\n    t.deepEqual(obj2, obj);\n});\n\ntest(\"deep copy should not fail when objects are not shaped similarly\", t => {\n    const obj = { geometry: { theorem: { name: \"Pythagorean\" } } };\n    const obj2 = { hypothesis: \"Riemann\" };\n    t.notThrows(() => deepCopyUndefined(obj2, obj));\n});\n\nfunction check(t: Assertions, values: number[]) {\n    const stat = new Statistics();\n    values.forEach(value => stat.update(value));\n    t.true(Math.abs(stat.mean - avg(values)) < 0.000000001);\n    t.true(Math.abs(stat.stdev - stdev(values)) < 0.000000001);\n    t.is(stat.samples, values.length);\n}\n\ntest(\"statistics empty values\", t => {\n    const emptyStat = new Statistics();\n    t.is(emptyStat.mean, NaN);\n    t.is(emptyStat.stdev, 0);\n    t.is(emptyStat.samples, 0);\n});\n\ntest(\"statistics single values\", t => {\n    check(t, [0]);\n    check(t, [1]);\n    check(t, [-1]);\n    check(t, [0.5]);\n    check(t, [-0.5]);\n    check(t, [0.1]);\n    check(t, [-0.1]);\n});\n\ntest(\"statistics multiple values\", t => {\n    check(t, [0, 1]);\n    check(t, [0, 1, 2]);\n    check(t, [42, 100, 1000]);\n    check(t, [1, 0.1]);\n    check(t, [-0.5, 0.5]);\n    check(t, [-1, 1]);\n    check(t, [3.14159, 2.717]);\n});\n\ntest(\"statistics random values\", t => {\n    const a = [];\n    const b = [];\n    const c = [];\n    for (let i = 0; i < 1000; i++) {\n        a.push(Math.random());\n        b.push(Math.random() * 10);\n        c.push(Math.random() * 100);\n    }\n    check(t, a);\n    check(t, b);\n    check(t, c);\n});\n\ntest(`statistics clone`, t => {\n    const stats = new Statistics();\n    stats.update(10);\n    stats.update(100);\n    stats.update(5);\n\n    const cloned = stats.clone();\n    t.deepEqual(cloned, stats);\n    t.is(cloned.toString(), stats.toString());\n    cloned.update(42);\n    t.true(cloned.mean !== stats.mean);\n    t.true(cloned.stdev !== stats.stdev);\n    t.is(stats.samples, 3);\n    t.is(cloned.samples, 4);\n});\n\ntest(\"MaxHeap basics\", t => {\n    const h = new MaxHeap();\n    h.insert(5);\n    h.insert(10);\n    h.insert(100);\n    h.insert(1);\n\n    t.is(h.extractMax(), 100);\n    t.is(h.extractMax(), 10);\n    t.is(h.extractMax(), 5);\n    t.is(h.extractMax(), 1);\n    t.throws(() => h.extractMax(), { message: /empty/ });\n});\n\ntest(\"MaxHeap empty\", t => {\n    const h = new MaxHeap();\n    t.throws(() => h.extractMax(), { message: /empty/ });\n});\n\ntest(\"MaxHeap sorting\", t => {\n    const h = new MaxHeap();\n    const N = 10000;\n    const size = 100;\n\n    for (let attempt = 0; attempt < N; attempt++) {\n        let orig: number[] = [];\n        const a: number[] = [];\n        for (let i = 0; i < size; i++) {\n            const value = Math.round(Math.random() * 1000);\n            a.push(value);\n            h.insert(value);\n        }\n        orig = a.slice();\n        a.sort((x, y) => y - x);\n        const b = [];\n        while (h.size > 0) {\n            b.push(h.extractMax());\n        }\n        t.deepEqual(a, b, `difference sorting ${orig}`);\n    }\n});\n\ntest(\"MaxHeap specific ordering\", t => {\n    const h = new MaxHeap();\n    h.insert(7);\n    h.insert(2);\n    h.insert(0);\n    h.insert(3);\n    h.insert(4);\n    h.insert(1);\n    h.insert(6);\n    h.insert(5);\n\n    t.is(h.extractMax(), 7);\n    t.is(h.extractMax(), 6);\n    t.is(h.extractMax(), 5);\n    t.is(h.extractMax(), 4);\n    t.is(h.extractMax(), 3);\n    t.is(h.extractMax(), 2);\n    t.is(h.extractMax(), 1);\n    t.is(h.extractMax(), 0);\n});\n\ntest(\"MaxHeap iterator\", t => {\n    const h = new MaxHeap();\n    h.insert(10);\n    h.insert(42);\n    h.insert(12);\n    t.deepEqual([...h], [42, 10, 12]);\n});\n\ntest(\"SmallestN saves smallest N keys\", t => {\n    const s = new SmallestN(3);\n    s.update(100);\n    s.update(42);\n    s.update(-1);\n    s.update(0);\n    s.update(4);\n    s.update(1000);\n    t.deepEqual(s.keys().sort(), [-1, 0, 4].sort());\n});\n\ntest(\"SmallestN saves smallest N values\", t => {\n    const N = 3;\n    const s = new SmallestN<string>(N);\n    s.update(100, \"100\");\n    s.update(42, \"42\");\n    s.update(-1, \"-1\");\n    s.update(0, \"0\");\n    s.update(4, \"4\");\n    s.update(1000, \"1000\");\n    t.deepEqual(\n        [...s],\n        [\n            [-1, \"-1\"],\n            [0, \"0\"],\n            [4, \"4\"]\n        ]\n    );\n});\n\ntest(\"SmallestN duplicate values\", t => {\n    const N = 5;\n    const s = new SmallestN<string>(N);\n    s.update(88, \"88.1\");\n    s.update(88, \"88.2\");\n    s.update(88, \"88.3\");\n    s.update(42, \"42\");\n    s.update(88, \"88.4\");\n    s.update(88, \"88.5\");\n    s.update(88, \"88.6\");\n    s.update(10, \"10.1\");\n    s.update(10, \"10.2\");\n    s.update(88, \"88.7\");\n    s.update(88, \"88.8\");\n    t.deepEqual(\n        [...s],\n        [\n            [88, \"88.1\"],\n            [88, \"88.2\"],\n            [42, \"42\"],\n            [10, \"10.1\"],\n            [10, \"10.2\"]\n        ]\n    );\n});\n\nfunction vals(a: number[]): [number, undefined][] {\n    return a.map(i => [i, undefined] as [number, undefined]);\n}\n\ntest(\"SmallestN can reduce size\", t => {\n    const N = 5;\n    const s = new SmallestN(N);\n    s.update(1);\n    s.update(2);\n    s.update(3);\n    s.update(4);\n    s.update(5);\n    s.update(6);\n    s.update(7);\n\n    s.setSize(3);\n    t.deepEqual([...s], vals([1, 2, 3]));\n});\n\ntest(\"SmallestN can increase size\", t => {\n    const N = 3;\n    const s = new SmallestN(N);\n    s.update(1);\n    s.update(2);\n    s.update(3);\n    s.update(4);\n    s.update(5);\n    t.deepEqual([...s], vals([1, 2, 3]));\n\n    s.setSize(5);\n    s.update(6);\n    s.update(7);\n    s.update(8);\n    t.deepEqual([...s], vals([1, 2, 3, 6, 7]));\n});\n"]}