faastjs
Version:
Serverless batch computing made simple.
102 lines • 15.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const ava_1 = tslib_1.__importDefault(require("ava"));
const child_process_1 = tslib_1.__importDefault(require("child_process"));
const fs_extra_1 = require("fs-extra");
const path_1 = tslib_1.__importDefault(require("path"));
const path_2 = require("path");
const index_1 = require("../index");
const aws_faast_1 = require("../src/aws/aws-faast");
const local_faast_1 = require("../src/local/local-faast");
const packer_1 = require("../src/packer");
const kb = 1024;
function exec(cmd) {
const result = child_process_1.default.execSync(cmd).toString();
index_1.log.info(result);
return result;
}
const testPacker = ava_1.default.macro({
exec: async (t, provider, pack, config, size) => {
const identifier = `${provider}-${config.name}`;
const tmpDir = path_1.default.join("tmp", identifier);
exec(`mkdir -p ${tmpDir}`);
process.env["FAAST_PACKAGE_DIR"] = "tmp";
const { archive } = await pack(require.resolve("./fixtures/functions"), config, {}, identifier);
await (0, fs_extra_1.remove)(tmpDir);
const writePromise = new Promise(resolve => archive.on("end", resolve));
const unzipPromise = (0, packer_1.unzipInDir)(tmpDir, archive);
await Promise.all([writePromise, unzipPromise]);
const zipFile = path_1.default.join("tmp", identifier + ".zip");
const bytes = (await (0, fs_extra_1.stat)(zipFile)).size;
t.true(bytes < size, `package size ${bytes} exceeded maximum ${size}`);
t.is(exec(`cd ${tmpDir} && node index.js`), "faast: successful cold start.\n");
config.check && (await config.check(t, tmpDir));
},
title: (_title = "", provider, _packer, options) => `packer ${provider}-${options.name}`
});
function added(dir) {
return async (t, root) => {
const filePath = (0, path_2.join)(root, dir, "file.txt");
t.true(await (0, fs_extra_1.pathExists)(filePath), `file ${filePath} does not exist in package`);
const { mode } = await (0, fs_extra_1.stat)((0, path_2.join)(root, dir, "script"));
const { mode: origMode } = await (0, fs_extra_1.stat)("test/fixtures/dir/script");
t.is(mode, origMode, "file modes are preserved");
t.is(mode & 0o700, 0o700, "executable mode is preserved in added files");
};
}
function excluded(file) {
return async (t, root) => {
const filePath = (0, path_2.join)(root, file);
t.false(await (0, fs_extra_1.pathExists)(filePath), `file ${file} exists but it should be excluded`);
};
}
const configs = [
{ name: "https", mode: "https" },
{ name: "queue", mode: "queue" },
{ name: "https-package", mode: "https", packageJson: "test/fixtures/package.json" },
{ name: "queue-package", mode: "queue", packageJson: "test/fixtures/package.json" },
{
name: "include",
include: ["test/fixtures/dir/**/*"],
check: added("test/fixtures/dir")
},
{
name: "include-cwd",
include: [{ path: "dir/**/*", cwd: "test/fixtures" }],
check: added("dir")
},
{
name: "include-dir",
include: ["test/fixtures/dir"],
check: added("test/fixtures/dir")
},
{
name: "include-dir-cwd",
include: [{ path: "dir", cwd: "test/fixtures" }],
check: added("dir")
},
{
name: "exclude",
include: ["test/fixtures/dir/**/*"],
exclude: ["**/*.exc"],
check: excluded("test/fixtures/dir/excluded.exc")
},
{
name: "exclude-file",
include: ["test/fixtures/dir/**/*"],
exclude: ["test/fixtures/dir/excluded.exc"],
check: excluded("test/fixtures/dir/excluded.exc")
}
];
const packers = {
aws: aws_faast_1.awsPacker,
local: local_faast_1.localPacker
};
for (const name of index_1.providers) {
for (const config of configs) {
let size = 130 * kb;
(0, ava_1.default)(testPacker, name, packers[name], config, size);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unit-packer.test.js","sourceRoot":"","sources":["../../test/unit-packer.test.ts"],"names":[],"mappings":"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","sourcesContent":["import test, { ExecutionContext } from \"ava\";\nimport sys from \"child_process\";\nimport { pathExists, remove, stat } from \"fs-extra\";\nimport path from \"path\";\nimport { join } from \"path\";\nimport { CommonOptions, log, Provider, providers } from \"../index\";\nimport { awsPacker } from \"../src/aws/aws-faast\";\nimport { localPacker } from \"../src/local/local-faast\";\nimport { PackerResult, unzipInDir } from \"../src/packer\";\nimport { WrapperOptions } from \"../src/wrapper\";\n\nconst kb = 1024;\n\ninterface PackageConfiguration extends CommonOptions {\n    name: string;\n    check?: (t: ExecutionContext, root: string) => Promise<void>;\n}\n\nfunction exec(cmd: string) {\n    const result = sys.execSync(cmd).toString();\n    log.info(result);\n    return result;\n}\n\ntype Packer = (\n    functionModule: string,\n    options: CommonOptions,\n    wrapperOptions: WrapperOptions,\n    FunctionName: string\n) => Promise<PackerResult>;\n\nconst testPacker = test.macro({\n    exec: async (\n        t: ExecutionContext,\n        provider: Provider,\n        pack: Packer,\n        config: PackageConfiguration,\n        size: number\n    ) => {\n        const identifier = `${provider}-${config.name}`;\n        const tmpDir = path.join(\"tmp\", identifier);\n        exec(`mkdir -p ${tmpDir}`);\n\n        process.env[\"FAAST_PACKAGE_DIR\"] = \"tmp\";\n\n        const { archive } = await pack(\n            require.resolve(\"./fixtures/functions\"),\n            config,\n            {},\n            identifier\n        );\n\n        await remove(tmpDir);\n        const writePromise = new Promise(resolve => archive.on(\"end\", resolve));\n        const unzipPromise = unzipInDir(tmpDir, archive);\n\n        await Promise.all([writePromise, unzipPromise]);\n        const zipFile = path.join(\"tmp\", identifier + \".zip\");\n        const bytes = (await stat(zipFile)).size;\n        t.true(bytes < size, `package size ${bytes} exceeded maximum ${size}`);\n        t.is(exec(`cd ${tmpDir} && node index.js`), \"faast: successful cold start.\\n\");\n        config.check && (await config.check(t, tmpDir));\n    },\n    title: (_title = \"\", provider, _packer, options) =>\n        `packer ${provider}-${options.name}`\n});\n\nfunction added(dir: string) {\n    return async (t: ExecutionContext, root: string) => {\n        const filePath = join(root, dir, \"file.txt\");\n        t.true(await pathExists(filePath), `file ${filePath} does not exist in package`);\n        const { mode } = await stat(join(root, dir, \"script\"));\n        const { mode: origMode } = await stat(\"test/fixtures/dir/script\");\n        t.is(mode, origMode, \"file modes are preserved\");\n        t.is(mode & 0o700, 0o700, \"executable mode is preserved in added files\");\n    };\n}\n\nfunction excluded(file: string) {\n    return async (t: ExecutionContext, root: string) => {\n        const filePath = join(root, file);\n        t.false(\n            await pathExists(filePath),\n            `file ${file} exists but it should be excluded`\n        );\n    };\n}\n\nconst configs: PackageConfiguration[] = [\n    { name: \"https\", mode: \"https\" },\n    { name: \"queue\", mode: \"queue\" },\n    { name: \"https-package\", mode: \"https\", packageJson: \"test/fixtures/package.json\" },\n    { name: \"queue-package\", mode: \"queue\", packageJson: \"test/fixtures/package.json\" },\n    {\n        name: \"include\",\n        include: [\"test/fixtures/dir/**/*\"],\n        check: added(\"test/fixtures/dir\")\n    },\n    {\n        name: \"include-cwd\",\n        include: [{ path: \"dir/**/*\", cwd: \"test/fixtures\" }],\n        check: added(\"dir\")\n    },\n    {\n        name: \"include-dir\",\n        include: [\"test/fixtures/dir\"],\n        check: added(\"test/fixtures/dir\")\n    },\n    {\n        name: \"include-dir-cwd\",\n        include: [{ path: \"dir\", cwd: \"test/fixtures\" }],\n        check: added(\"dir\")\n    },\n    {\n        name: \"exclude\",\n        include: [\"test/fixtures/dir/**/*\"],\n        exclude: [\"**/*.exc\"],\n        check: excluded(\"test/fixtures/dir/excluded.exc\")\n    },\n    {\n        name: \"exclude-file\",\n        include: [\"test/fixtures/dir/**/*\"],\n        exclude: [\"test/fixtures/dir/excluded.exc\"],\n        check: excluded(\"test/fixtures/dir/excluded.exc\")\n    }\n];\n\nconst packers: { [provider in Provider]: Packer } = {\n    aws: awsPacker,\n    local: localPacker\n};\n\nfor (const name of providers) {\n    for (const config of configs) {\n        let size = 130 * kb;\n        test(testPacker, name, packers[name], config, size);\n    }\n}\n"]}