faastjs
Version:
Serverless batch computing made simple.
244 lines • 31.8 kB
JavaScript
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"]}
;