UNPKG

faastjs

Version:

Serverless batch computing made simple.

104 lines 15.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const ava_1 = require("ava"); const sys = require("child_process"); const fs_extra_1 = require("fs-extra"); const path = require("path"); const path_1 = require("path"); const index_1 = require("../index"); const aws_faast_1 = require("../src/aws/aws-faast"); const google_faast_1 = require("../src/google/google-faast"); const local_faast_1 = require("../src/local/local-faast"); const packer_1 = require("../src/packer"); const kb = 1024; function exec(cmd) { const result = sys.execSync(cmd).toString(); index_1.log.info(result); return result; } const testPacker = async (t, provider, pack, config, size) => { const identifier = `${provider}-${config.name}`; const tmpDir = path.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.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)); }; testPacker.title = (_title = "", provider, _packer, options) => `packer ${provider}-${options.name}`; function added(dir) { return async (t, root) => { const filePath = (0, path_1.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_1.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_1.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, google: google_faast_1.googlePacker, local: local_faast_1.localPacker }; for (const name of index_1.providers) { for (const config of configs) { let size = 130 * kb; if (name === "google" && !config.packageJson) { size = 1400 * 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, Macro } from \"ava\";\nimport * as sys from \"child_process\";\nimport { pathExists, remove, stat } from \"fs-extra\";\nimport * as path from \"path\";\nimport { join } from \"path\";\nimport { CommonOptions, log, Provider, providers } from \"../index\";\nimport { awsPacker } from \"../src/aws/aws-faast\";\nimport { googlePacker } from \"../src/google/google-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: Macro<[Provider, Packer, PackageConfiguration, number]> = 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\ntestPacker.title = (_title = \"\", provider, _packer, options) =>\n    `packer ${provider}-${options.name}`;\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    google: googlePacker,\n    local: localPacker\n};\n\nfor (const name of providers) {\n    for (const config of configs) {\n        let size = 130 * kb;\n        if (name === \"google\" && !config.packageJson) {\n            size = 1400 * kb;\n        }\n        test(testPacker, name, packers[name], config, size);\n    }\n}\n"]}