import * as test from "./libtest.so"; function assert(actual, expected, message) { if (arguments.length == 1) expected = true; if (actual === expected) return; if (actual !== null && expected !== null && typeof actual == 'object' && typeof expected == 'object' && actual.toString() === expected.toString()) return; throw Error("assertion failed: got |" + actual + "|" + ", expected |" + expected + "|" + (message ? " (" + message + ")" : "")); } const eq = assert; const floateq = (actual, expected) => { assert(Math.abs(actual - expected) < Number.EPSILON) } const ascii = v => v.charCodeAt(0) function builtins() { eq(test.ReturnsVoid(), undefined) eq(test.ReturnsBool(), true) eq(test.PassAndReturnsBool(false), false) eq(test.ReturnsNullptr(), null) //eq(test.PassAndReturnsNullptr(null), null) eq(test.ReturnsNullptr(), null) eq(test.ReturnsChar (), ascii('a')); eq(test.ReturnsSChar(), ascii('a')); eq(test.ReturnsUChar(), ascii('a')); eq(test.PassAndReturnsChar (ascii('a')), ascii('a')); eq(test.PassAndReturnsSChar(ascii('b')), ascii('b')); eq(test.PassAndReturnsUChar(ascii('c')), ascii('c')); // TODO: add wchar_t tests eq(test.ReturnsFloat (), 5.0); eq(test.ReturnsDouble(), -5.0); //eq(test.ReturnsLongDouble(), -5.0); //floateq(test.PassAndReturnsFloat (1.32), 1.32); floateq(test.PassAndReturnsDouble(1.32), 1.32); //float(test.PassAndReturnsLongDouble(1.32), 1.32); eq(test.ReturnsInt8 (), -5); eq(test.ReturnsUInt8 (), 5); eq(test.ReturnsInt16 (), -5); eq(test.ReturnsUInt16(), 5); eq(test.ReturnsInt32 (), -5); eq(test.ReturnsUInt32(), 5); eq(test.ReturnsInt64 (), -5n); eq(test.ReturnsUInt64(), 5n); const int8 = { min: -(2**7), max: (2**7) - 1 }; eq(test.PassAndReturnsInt8(int8.min), int8.min); eq(test.PassAndReturnsInt8(int8.max), int8.max); const uint8 = { min: 0, max: (2**8) - 1 }; eq(test.PassAndReturnsUInt8(uint8.min), uint8.min); eq(test.PassAndReturnsUInt8(uint8.max), uint8.max); const int16 = { min: -(2**15), max: (2**15) - 1 }; eq(test.PassAndReturnsInt16(int16.min), int16.min); eq(test.PassAndReturnsInt16(int16.max), int16.max); const uint16 = { min: 0, max: (2**16) - 1 }; eq(test.PassAndReturnsUInt16(uint16.min), uint16.min); eq(test.PassAndReturnsUInt16(uint16.max), uint16.max); const int32 = { min: -(2**31), max: (2**31) - 1 }; eq(test.PassAndReturnsInt32(int32.min), int32.min); eq(test.PassAndReturnsInt32(int32.max), int32.max); const uint32 = { min: 0, max: (2**32) - 1 }; eq(test.PassAndReturnsUInt32(uint32.min), uint32.min); eq(test.PassAndReturnsUInt32(uint32.max), uint32.max); const int64 = { min: BigInt(2**63) * -1n, max: BigInt(2**63) - 1n }; eq(test.PassAndReturnsInt64(int64.min), int64.min); eq(test.PassAndReturnsInt64(int64.max), int64.max); const uint64 = { min: BigInt(0), max: BigInt(2**64) - 1n }; eq(test.PassAndReturnsUInt64(uint64.min), uint64.min); eq(test.PassAndReturnsUInt64(uint64.max), uint64.max); } function enums() { eq(test.Enum0.Item0, 0); eq(test.Enum0.Item1, 1); eq(test.Enum0.Item2, 5); eq(test.ReturnsEnum(), test.Enum0.Item0); eq(test.PassAndReturnsEnum(test.Enum0.Item1), test.Enum0.Item1); } function overloads() { eq(test.Overload0(), undefined); eq(test.Overload1(), 1); eq(test.Overload1(2), 2); eq(test.Overload(1, 2), 1); //eq(test.Overload(1, 2.032), 2); //eq(test.Overload(1.23, 2), 3); eq(test.DefaultParamsOverload(0, 0), 2); eq(test.DefaultParamsOverload(0, 0.0), 2); eq(test.DefaultParamsOverload(0), 3); eq(test.DefaultParamsOverload2(), 1); eq(test.DefaultParamsOverload2(1), 1); eq(test.DefaultParamsOverload2(1, 2), 1); eq(test.DefaultParamsOverload2(1, 2, 3), 1); } function classes() { var c = new test.Class(); eq(typeof(c), "object") eq(c.ReturnsVoid(), undefined) //eq(c.ReturnsInt(), 0) //eq(c.PassAndReturnsClassPtr(null), null) var c1 = new test.ClassWithSingleInheritance(); eq(c1.__proto__.constructor.name, 'ClassWithSingleInheritance') eq(c1.__proto__.__proto__.constructor.name, 'Class') eq(c1.ReturnsVoid(), undefined); //eq(c1.ReturnsInt(), 0); //eq(c1.ChildMethod(), 2); var classWithField = new test.ClassWithField(); //eq(classWithField.ReturnsField(), 10); } function delegates() { const signal = new test.Signal(); eq(signal.toString(), "Signal"); const classWithDelegate = new test.ClassWithDelegate(); const event0 = classWithDelegate.OnEvent0; eq(event0.__proto__.constructor.name, "Signal") const event0_1 = classWithDelegate.OnEvent0; eq(event0 === event0_1, true); let anon_cb_called = false; const anon_cb = () => { anon_cb_called = true; return 32; }; event0.connect(anon_cb); classWithDelegate.FireEvent0(10); eq(anon_cb_called, true); } function delegates2() { let anon_cb_called = false; const anon_cb = () => { anon_cb_called = true; return 32; }; const classInheritsDelegate = new test.ClassInheritsDelegate(); const event0 = classInheritsDelegate.OnEvent0; event0.connect(anon_cb); classInheritsDelegate.FireEvent0(10); eq(anon_cb_called, true); } builtins(); enums(); overloads(); classes(); delegates(); delegates2(); function printChain(obj) { console.log("\nprototypes:") let proto = obj.__proto__ if (proto == null) { console.log("invalid proto") return } while (proto != null) { console.log(proto.constructor.name) proto = proto.__proto__ } console.log("") }