UNPKG

15.8 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const ava_1 = require("ava");
4const sys = require("child_process");
5const fs_extra_1 = require("fs-extra");
6const path = require("path");
7const path_1 = require("path");
8const index_1 = require("../index");
9const aws_faast_1 = require("../src/aws/aws-faast");
10const google_faast_1 = require("../src/google/google-faast");
11const local_faast_1 = require("../src/local/local-faast");
12const packer_1 = require("../src/packer");
13const kb = 1024;
14function exec(cmd) {
15 const result = sys.execSync(cmd).toString();
16 index_1.log.info(result);
17 return result;
18}
19const testPacker = async (t, provider, pack, config, size) => {
20 const identifier = `${provider}-${config.name}`;
21 const tmpDir = path.join("tmp", identifier);
22 exec(`mkdir -p ${tmpDir}`);
23 process.env["FAAST_PACKAGE_DIR"] = "tmp";
24 const { archive } = await pack(require.resolve("./fixtures/functions"), config, {}, identifier);
25 await (0, fs_extra_1.remove)(tmpDir);
26 const writePromise = new Promise(resolve => archive.on("end", resolve));
27 const unzipPromise = (0, packer_1.unzipInDir)(tmpDir, archive);
28 await Promise.all([writePromise, unzipPromise]);
29 const zipFile = path.join("tmp", identifier + ".zip");
30 const bytes = (await (0, fs_extra_1.stat)(zipFile)).size;
31 t.true(bytes < size, `package size ${bytes} exceeded maximum ${size}`);
32 t.is(exec(`cd ${tmpDir} && node index.js`), "faast: successful cold start.\n");
33 config.check && (await config.check(t, tmpDir));
34};
35testPacker.title = (_title = "", provider, _packer, options) => `packer ${provider}-${options.name}`;
36function added(dir) {
37 return async (t, root) => {
38 const filePath = (0, path_1.join)(root, dir, "file.txt");
39 t.true(await (0, fs_extra_1.pathExists)(filePath), `file ${filePath} does not exist in package`);
40 const { mode } = await (0, fs_extra_1.stat)((0, path_1.join)(root, dir, "script"));
41 const { mode: origMode } = await (0, fs_extra_1.stat)("test/fixtures/dir/script");
42 t.is(mode, origMode, "file modes are preserved");
43 t.is(mode & 0o700, 0o700, "executable mode is preserved in added files");
44 };
45}
46function excluded(file) {
47 return async (t, root) => {
48 const filePath = (0, path_1.join)(root, file);
49 t.false(await (0, fs_extra_1.pathExists)(filePath), `file ${file} exists but it should be excluded`);
50 };
51}
52const configs = [
53 { name: "https", mode: "https" },
54 { name: "queue", mode: "queue" },
55 { name: "https-package", mode: "https", packageJson: "test/fixtures/package.json" },
56 { name: "queue-package", mode: "queue", packageJson: "test/fixtures/package.json" },
57 {
58 name: "include",
59 include: ["test/fixtures/dir/**/*"],
60 check: added("test/fixtures/dir")
61 },
62 {
63 name: "include-cwd",
64 include: [{ path: "dir/**/*", cwd: "test/fixtures" }],
65 check: added("dir")
66 },
67 {
68 name: "include-dir",
69 include: ["test/fixtures/dir"],
70 check: added("test/fixtures/dir")
71 },
72 {
73 name: "include-dir-cwd",
74 include: [{ path: "dir", cwd: "test/fixtures" }],
75 check: added("dir")
76 },
77 {
78 name: "exclude",
79 include: ["test/fixtures/dir/**/*"],
80 exclude: ["**/*.exc"],
81 check: excluded("test/fixtures/dir/excluded.exc")
82 },
83 {
84 name: "exclude-file",
85 include: ["test/fixtures/dir/**/*"],
86 exclude: ["test/fixtures/dir/excluded.exc"],
87 check: excluded("test/fixtures/dir/excluded.exc")
88 }
89];
90const packers = {
91 aws: aws_faast_1.awsPacker,
92 google: google_faast_1.googlePacker,
93 local: local_faast_1.localPacker
94};
95for (const name of index_1.providers) {
96 for (const config of configs) {
97 let size = 130 * kb;
98 if (name === "google" && !config.packageJson) {
99 size = 1400 * kb;
100 }
101 (0, ava_1.default)(testPacker, name, packers[name], config, size);
102 }
103}
104//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unit-packer.test.js","sourceRoot":"","sources":["../../test/unit-packer.test.ts"],"names":[],"mappings":";;AAAA,6BAAoD;AACpD,qCAAqC;AACrC,uCAAoD;AACpD,6BAA6B;AAC7B,+BAA4B;AAC5B,oCAAmE;AACnE,oDAAiD;AACjD,6DAA0D;AAC1D,0DAAuD;AACvD,0CAAyD;AAGzD,MAAM,EAAE,GAAG,IAAI,CAAC;AAOhB,SAAS,IAAI,CAAC,GAAW;IACrB,MAAM,MAAM,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC5C,WAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACjB,OAAO,MAAM,CAAC;AAClB,CAAC;AASD,MAAM,UAAU,GAA4D,KAAK,EAC7E,CAAmB,EACnB,QAAkB,EAClB,IAAY,EACZ,MAA4B,EAC5B,IAAY,EACd,EAAE;IACA,MAAM,UAAU,GAAG,GAAG,QAAQ,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC;IAChD,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;IAC5C,IAAI,CAAC,YAAY,MAAM,EAAE,CAAC,CAAC;IAE3B,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,GAAG,KAAK,CAAC;IAEzC,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAC1B,OAAO,CAAC,OAAO,CAAC,sBAAsB,CAAC,EACvC,MAAM,EACN,EAAE,EACF,UAAU,CACb,CAAC;IAEF,MAAM,IAAA,iBAAM,EAAC,MAAM,CAAC,CAAC;IACrB,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC;IACxE,MAAM,YAAY,GAAG,IAAA,mBAAU,EAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAEjD,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC;IAChD,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,UAAU,GAAG,MAAM,CAAC,CAAC;IACtD,MAAM,KAAK,GAAG,CAAC,MAAM,IAAA,eAAI,EAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;IACzC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,EAAE,gBAAgB,KAAK,qBAAqB,IAAI,EAAE,CAAC,CAAC;IACvE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,MAAM,mBAAmB,CAAC,EAAE,iCAAiC,CAAC,CAAC;IAC/E,MAAM,CAAC,KAAK,IAAI,CAAC,MAAM,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;AACpD,CAAC,CAAC;AAEF,UAAU,CAAC,KAAK,GAAG,CAAC,MAAM,GAAG,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,CAC3D,UAAU,QAAQ,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;AAEzC,SAAS,KAAK,CAAC,GAAW;IACtB,OAAO,KAAK,EAAE,CAAmB,EAAE,IAAY,EAAE,EAAE;QAC/C,MAAM,QAAQ,GAAG,IAAA,WAAI,EAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;QAC7C,CAAC,CAAC,IAAI,CAAC,MAAM,IAAA,qBAAU,EAAC,QAAQ,CAAC,EAAE,QAAQ,QAAQ,4BAA4B,CAAC,CAAC;QACjF,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAA,eAAI,EAAC,IAAA,WAAI,EAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC,CAAC;QACvD,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAA,eAAI,EAAC,0BAA0B,CAAC,CAAC;QAClE,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,0BAA0B,CAAC,CAAC;QACjD,CAAC,CAAC,EAAE,CAAC,IAAI,GAAG,KAAK,EAAE,KAAK,EAAE,6CAA6C,CAAC,CAAC;IAC7E,CAAC,CAAC;AACN,CAAC;AAED,SAAS,QAAQ,CAAC,IAAY;IAC1B,OAAO,KAAK,EAAE,CAAmB,EAAE,IAAY,EAAE,EAAE;QAC/C,MAAM,QAAQ,GAAG,IAAA,WAAI,EAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAClC,CAAC,CAAC,KAAK,CACH,MAAM,IAAA,qBAAU,EAAC,QAAQ,CAAC,EAC1B,QAAQ,IAAI,mCAAmC,CAClD,CAAC;IACN,CAAC,CAAC;AACN,CAAC;AAED,MAAM,OAAO,GAA2B;IACpC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE;IAChC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE;IAChC,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,4BAA4B,EAAE;IACnF,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,4BAA4B,EAAE;IACnF;QACI,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,CAAC,wBAAwB,CAAC;QACnC,KAAK,EAAE,KAAK,CAAC,mBAAmB,CAAC;KACpC;IACD;QACI,IAAI,EAAE,aAAa;QACnB,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,eAAe,EAAE,CAAC;QACrD,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC;KACtB;IACD;QACI,IAAI,EAAE,aAAa;QACnB,OAAO,EAAE,CAAC,mBAAmB,CAAC;QAC9B,KAAK,EAAE,KAAK,CAAC,mBAAmB,CAAC;KACpC;IACD;QACI,IAAI,EAAE,iBAAiB;QACvB,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,eAAe,EAAE,CAAC;QAChD,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC;KACtB;IACD;QACI,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,CAAC,wBAAwB,CAAC;QACnC,OAAO,EAAE,CAAC,UAAU,CAAC;QACrB,KAAK,EAAE,QAAQ,CAAC,gCAAgC,CAAC;KACpD;IACD;QACI,IAAI,EAAE,cAAc;QACpB,OAAO,EAAE,CAAC,wBAAwB,CAAC;QACnC,OAAO,EAAE,CAAC,gCAAgC,CAAC;QAC3C,KAAK,EAAE,QAAQ,CAAC,gCAAgC,CAAC;KACpD;CACJ,CAAC;AAEF,MAAM,OAAO,GAAuC;IAChD,GAAG,EAAE,qBAAS;IACd,MAAM,EAAE,2BAAY;IACpB,KAAK,EAAE,yBAAW;CACrB,CAAC;AAEF,KAAK,MAAM,IAAI,IAAI,iBAAS,EAAE;IAC1B,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;QAC1B,IAAI,IAAI,GAAG,GAAG,GAAG,EAAE,CAAC;QACpB,IAAI,IAAI,KAAK,QAAQ,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YAC1C,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC;SACpB;QACD,IAAA,aAAI,EAAC,UAAU,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;KACvD;CACJ","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"]}
\No newline at end of file