faastjs
Version:
Serverless batch computing made simple.
78 lines • 11.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const ava_1 = tslib_1.__importDefault(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, cause, ...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, cause, ...rest } = error;
const _exhaustiveCheck = {};
t.is(name, error_1.FaastErrorNames.EGENERIC);
t.regex(stack, /unit-error.test/);
t.regex(index_1.FaastError.fullStack(error), /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, cause, ...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 c = error.cause();
t.is(c.message, logUrlString);
t.is(info.functionName, "functionName");
t.deepEqual(info.args, ["arg"]);
t.true(c.stack.indexOf("faast.js cloud function invocation") >= 0);
t.is(index_1.FaastError.fullStack(c), c.stack ?? "");
t.true(index_1.FaastError.fullStack(c).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, cause, ...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":"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","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, cause, ...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, cause, ...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), /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, cause, ...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 c = error.cause()!;\n    t.is(c.message, logUrlString);\n    t.is(info.functionName, \"functionName\");\n    t.deepEqual(info.args, [\"arg\"]);\n    t.true(c.stack!.indexOf(\"faast.js cloud function invocation\") >= 0);\n    t.is(FaastError.fullStack(c), c.stack ?? \"\");\n    t.true(FaastError.fullStack(c).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, cause, ...rest } = error;\n    const _exhaustiveCheck: Required<typeof rest> = {};\n    t.is(name, FaastErrorNames.ETIMEOUT);\n});\n"]}