UNPKG

faastjs

Version:

Serverless batch computing made simple.

77 lines 11.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const ava_1 = require("ava"); const index_1 = require("../index"); const error_1 = require("../src/error"); (0, ava_1.default)("FaastError basic error", t => { const error = new index_1.FaastError("bad error"); const { name, stack, message, ...rest } = error; const _exhaustiveCheck = {}; t.is(name, error_1.FaastErrorNames.EGENERIC); t.regex(stack, /unit-error.test/); t.is(index_1.FaastError.fullStack(error), stack); t.deepEqual(index_1.FaastError.info(error), {}); t.is(message, "bad error"); t.is(error.cause(), undefined); }); function foo() { throw new Error("underlying error"); } (0, ava_1.default)("FaastError nested error", t => { let nested; try { foo(); } catch (err) { nested = err; } const error = new index_1.FaastError(nested, "bad error"); const { name, stack, message, ...rest } = error; const _exhaustiveCheck = {}; t.is(name, error_1.FaastErrorNames.EGENERIC); t.regex(stack, /unit-error.test/); t.regex(index_1.FaastError.fullStack(error), /at foo /); t.deepEqual(index_1.FaastError.info(error), {}); t.is(message, "bad error: underlying error"); t.is(error.cause(), nested); }); (0, ava_1.default)("FaastError synthesized error", t => { const errObj = { message: "remote message", stack: "remote stack trace", name: "RemoteErrorName", custom: "remote custom property" }; const logUrlString = "https://cloud.com/logs"; const error = (0, error_1.synthesizeFaastError)({ errObj, logUrl: logUrlString, functionName: "functionName", args: ["arg"] }); const { name, stack, message, ...rest } = error; const _exhaustiveCheck = {}; t.is(name, errObj.name); t.true(stack.indexOf(errObj.stack) >= 0); t.true(index_1.FaastError.fullStack(error).indexOf(errObj.stack) >= 0); const info = index_1.FaastError.info(error); for (const key of Object.keys(errObj)) { t.is(info[key], errObj[key]); } t.true(index_1.FaastError.info(error).logUrl.trim() === logUrlString); t.true(message.indexOf(errObj.message) >= 0); const cause = error.cause(); t.is(cause.message, logUrlString); t.is(info.functionName, "functionName"); t.deepEqual(info.args, ["arg"]); t.true(cause.stack.indexOf("faast.js cloud function invocation") >= 0); t.is(index_1.FaastError.fullStack(cause), cause.stack); t.true(index_1.FaastError.fullStack(cause).indexOf(logUrlString) >= 0); }); (0, ava_1.default)("FaastError using option constructor", t => { const error = new index_1.FaastError({ name: error_1.FaastErrorNames.ETIMEOUT }, "message"); const { name, stack, message, ...rest } = error; const _exhaustiveCheck = {}; t.is(name, error_1.FaastErrorNames.ETIMEOUT); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unit-error.test.js","sourceRoot":"","sources":["../../test/unit-error.test.ts"],"names":[],"mappings":";;AAAA,6BAAuB;AACvB,oCAAsC;AACtC,wCAAqE;AAErE,IAAA,aAAI,EAAC,wBAAwB,EAAE,CAAC,CAAC,EAAE;IAC/B,MAAM,KAAK,GAAG,IAAI,kBAAU,CAAC,WAAW,CAAC,CAAC;IAC1C,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAChD,MAAM,gBAAgB,GAA0B,EAAE,CAAC;IACnD,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,uBAAe,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC,CAAC,KAAK,CAAC,KAAM,EAAE,iBAAiB,CAAC,CAAC;IACnC,CAAC,CAAC,EAAE,CAAC,kBAAU,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,CAAC;IACzC,CAAC,CAAC,SAAS,CAAC,kBAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IACxC,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;IAC3B,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,SAAS,CAAC,CAAC;AACnC,CAAC,CAAC,CAAC;AAEH,SAAS,GAAG;IACR,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;AACxC,CAAC;AAED,IAAA,aAAI,EAAC,yBAAyB,EAAE,CAAC,CAAC,EAAE;IAChC,IAAI,MAAM,CAAC;IACX,IAAI;QACA,GAAG,EAAE,CAAC;KACT;IAAC,OAAO,GAAQ,EAAE;QACf,MAAM,GAAG,GAAG,CAAC;KAChB;IACD,MAAM,KAAK,GAAG,IAAI,kBAAU,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAClD,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAChD,MAAM,gBAAgB,GAA0B,EAAE,CAAC;IACnD,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,uBAAe,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC,CAAC,KAAK,CAAC,KAAM,EAAE,iBAAiB,CAAC,CAAC;IACnC,CAAC,CAAC,KAAK,CAAC,kBAAU,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,SAAS,CAAC,CAAC;IAChD,CAAC,CAAC,SAAS,CAAC,kBAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IACxC,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,6BAA6B,CAAC,CAAC;IAC7C,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,MAAM,CAAC,CAAC;AAChC,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,8BAA8B,EAAE,CAAC,CAAC,EAAE;IACrC,MAAM,MAAM,GAAG;QACX,OAAO,EAAE,gBAAgB;QACzB,KAAK,EAAE,oBAAoB;QAC3B,IAAI,EAAE,iBAAiB;QACvB,MAAM,EAAE,wBAAwB;KACnC,CAAC;IACF,MAAM,YAAY,GAAG,wBAAwB,CAAC;IAC9C,MAAM,KAAK,GAAG,IAAA,4BAAoB,EAAC;QAC/B,MAAM;QACN,MAAM,EAAE,YAAY;QACpB,YAAY,EAAE,cAAc;QAC5B,IAAI,EAAE,CAAC,KAAK,CAAC;KAChB,CAAC,CAAC;IACH,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAChD,MAAM,gBAAgB,GAA0B,EAAE,CAAC;IAEnD,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC,CAAC,IAAI,CAAC,KAAM,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,IAAI,CAAC,kBAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;IAC/D,MAAM,IAAI,GAAG,kBAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;QACnC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAG,MAAc,CAAC,GAAG,CAAC,CAAC,CAAC;KACzC;IACD,CAAC,CAAC,IAAI,CAAC,kBAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,YAAY,CAAC,CAAC;IAC9D,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IAC7C,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,EAAiB,CAAC;IAC3C,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;IAClC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC;IACxC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAChC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAM,CAAC,OAAO,CAAC,oCAAoC,CAAC,IAAI,CAAC,CAAC,CAAC;IACxE,CAAC,CAAC,EAAE,CAAC,kBAAU,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC,CAAC,IAAI,CAAC,kBAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC;AACnE,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,qCAAqC,EAAE,CAAC,CAAC,EAAE;IAC5C,MAAM,KAAK,GAAG,IAAI,kBAAU,CAAC,EAAE,IAAI,EAAE,uBAAe,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,CAAC;IAC5E,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAChD,MAAM,gBAAgB,GAA0B,EAAE,CAAC;IACnD,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,uBAAe,CAAC,QAAQ,CAAC,CAAC;AACzC,CAAC,CAAC,CAAC","sourcesContent":["import test from \"ava\";\nimport { FaastError } from \"../index\";\nimport { synthesizeFaastError, FaastErrorNames } from \"../src/error\";\n\ntest(\"FaastError basic error\", t => {\n    const error = new FaastError(\"bad error\");\n    const { name, stack, message, ...rest } = error;\n    const _exhaustiveCheck: Required<typeof rest> = {};\n    t.is(name, FaastErrorNames.EGENERIC);\n    t.regex(stack!, /unit-error.test/);\n    t.is(FaastError.fullStack(error), stack);\n    t.deepEqual(FaastError.info(error), {});\n    t.is(message, \"bad error\");\n    t.is(error.cause(), undefined);\n});\n\nfunction foo() {\n    throw new Error(\"underlying error\");\n}\n\ntest(\"FaastError nested error\", t => {\n    let nested;\n    try {\n        foo();\n    } catch (err: any) {\n        nested = err;\n    }\n    const error = new FaastError(nested, \"bad error\");\n    const { name, stack, message, ...rest } = error;\n    const _exhaustiveCheck: Required<typeof rest> = {};\n    t.is(name, FaastErrorNames.EGENERIC);\n    t.regex(stack!, /unit-error.test/);\n    t.regex(FaastError.fullStack(error), /at foo /);\n    t.deepEqual(FaastError.info(error), {});\n    t.is(message, \"bad error: underlying error\");\n    t.is(error.cause(), nested);\n});\n\ntest(\"FaastError synthesized error\", t => {\n    const errObj = {\n        message: \"remote message\",\n        stack: \"remote stack trace\",\n        name: \"RemoteErrorName\",\n        custom: \"remote custom property\"\n    };\n    const logUrlString = \"https://cloud.com/logs\";\n    const error = synthesizeFaastError({\n        errObj,\n        logUrl: logUrlString,\n        functionName: \"functionName\",\n        args: [\"arg\"]\n    });\n    const { name, stack, message, ...rest } = error;\n    const _exhaustiveCheck: Required<typeof rest> = {};\n\n    t.is(name, errObj.name);\n    t.true(stack!.indexOf(errObj.stack) >= 0);\n    t.true(FaastError.fullStack(error).indexOf(errObj.stack) >= 0);\n    const info = FaastError.info(error);\n    for (const key of Object.keys(errObj)) {\n        t.is(info[key], (errObj as any)[key]);\n    }\n    t.true(FaastError.info(error).logUrl.trim() === logUrlString);\n    t.true(message.indexOf(errObj.message) >= 0);\n    const cause = error.cause()! as FaastError;\n    t.is(cause.message, logUrlString);\n    t.is(info.functionName, \"functionName\");\n    t.deepEqual(info.args, [\"arg\"]);\n    t.true(cause.stack!.indexOf(\"faast.js cloud function invocation\") >= 0);\n    t.is(FaastError.fullStack(cause), cause.stack);\n    t.true(FaastError.fullStack(cause).indexOf(logUrlString) >= 0);\n});\n\ntest(\"FaastError using option constructor\", t => {\n    const error = new FaastError({ name: FaastErrorNames.ETIMEOUT }, \"message\");\n    const { name, stack, message, ...rest } = error;\n    const _exhaustiveCheck: Required<typeof rest> = {};\n    t.is(name, FaastErrorNames.ETIMEOUT);\n});\n"]}