diff --git a/README.md b/README.md index 718d387..eaf6b61 100644 --- a/README.md +++ b/README.md @@ -50,8 +50,9 @@ If you have multiple meta files, you can specify them like this `"dist/meta1.jso | Name | Default | Description | |---------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------| | `metafiles` | - | A required comma-separated list of paths to [esbuild's meta file]([https://esbuild.github.io/api/#metafile]). | -| `name` | ${{ github.event.
repository.name }} | The name of your project. This will be used in the comment header. | +| `name` | ${{ github.event.
repository.name }} | The name of your project. This will be used in the comment header. | | `analyze_directory` | `.analyzer` | A path to working directory where bundle analysis are stored. | +| `include_extensions` | `.js,.cjs,.mjs` | A comma-separated list of file extension to be included in the analysis table. | | `percent_extra_attention` | `20` | If an out file size has increased more than this percent, display a "‼️" to draw extra attention to the change. | | `show_details` | `true` | If `true`, a collapsed "details" section is rendered. It explains the details of the numbers provided and icons. | diff --git a/__tests__/__fixtures__/examples-with-base/multi-output/.analyzer/base/bundle/bundle_analysis.json b/__tests__/__fixtures__/examples-with-base/multi-output/.analyzer/base/bundle/bundle_analysis.json index f271bbf..54837c6 100644 --- a/__tests__/__fixtures__/examples-with-base/multi-output/.analyzer/base/bundle/bundle_analysis.json +++ b/__tests__/__fixtures__/examples-with-base/multi-output/.analyzer/base/bundle/bundle_analysis.json @@ -2,7 +2,7 @@ "out/meta.json -> out/no-change.js": { "metafile": "out/meta.json", "outfile": "out/no-change.js", - "bytes": 733152 + "bytes": 733190 }, "out/meta.json -> out/decreased.js": { "metafile": "out/meta.json", diff --git a/__tests__/__fixtures__/examples-with-base/multi-output/esbuild.mjs b/__tests__/__fixtures__/examples-with-base/multi-output/esbuild.mjs index ae16f9f..51befc2 100644 --- a/__tests__/__fixtures__/examples-with-base/multi-output/esbuild.mjs +++ b/__tests__/__fixtures__/examples-with-base/multi-output/esbuild.mjs @@ -1,5 +1,6 @@ import { writeFileSync } from "node:fs"; import { build } from "esbuild"; +import metaUrlPlugin from '@chialab/esbuild-plugin-meta-url'; const result = await build({ entryPoints: [ @@ -8,6 +9,7 @@ const result = await build({ `./src/much-increased.ts`, `./src/decreased.ts`, `./src/new-outfile.ts`, + `./src/file-imported.ts`, ], outdir: `out`, format: "esm", @@ -16,7 +18,10 @@ const result = await build({ platform: "node", target: "node20.9", bundle: true, - plugins: [], + plugins: [ + metaUrlPlugin(), + ], + sourcemap: true, }); writeFileSync(`out/meta.json`, JSON.stringify(result.metafile, null, 2)); diff --git a/__tests__/__fixtures__/examples-with-base/multi-output/package-lock.json b/__tests__/__fixtures__/examples-with-base/multi-output/package-lock.json index af6c3da..ccf8e89 100644 --- a/__tests__/__fixtures__/examples-with-base/multi-output/package-lock.json +++ b/__tests__/__fixtures__/examples-with-base/multi-output/package-lock.json @@ -9,9 +9,12 @@ "version": "1.0.0", "dependencies": { "@aws-sdk/client-s3": "3.556.0", - "hono": "4.2.7" + "@jitl/quickjs-wasmfile-release-sync": "^0.29.1", + "hono": "4.2.7", + "quickjs-emscripten-core": "^0.29.1" }, "devDependencies": { + "@chialab/esbuild-plugin-meta-url": "^0.18.2", "esbuild": "0.20.2", "typescript": "^5.4.5" } @@ -815,6 +818,54 @@ "node": ">=14.0.0" } }, + "node_modules/@chialab/esbuild-plugin-meta-url": { + "version": "0.18.2", + "resolved": "https://registry.npmjs.org/@chialab/esbuild-plugin-meta-url/-/esbuild-plugin-meta-url-0.18.2.tgz", + "integrity": "sha512-uIRIdLvYnw5mLrTRXY0BTgeZx6ANL2/OHkWFl8FaiTYNb7cyXmwEDRE1mh6kBXPRPtGuqv6XSpNX+koEkElu4g==", + "dev": true, + "dependencies": { + "@chialab/esbuild-rna": "^0.18.1", + "@chialab/estransform": "^0.18.1", + "mime-types": "^2.1.35" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@chialab/esbuild-rna": { + "version": "0.18.2", + "resolved": "https://registry.npmjs.org/@chialab/esbuild-rna/-/esbuild-rna-0.18.2.tgz", + "integrity": "sha512-ckzskez7bxstVQ4c5cxbx0DRP2teldzrcSGQl2KPh1VJGdO2ZmRrb6vNkBBD5K3dx9tgTyvskWp4dV+Fbg07Ag==", + "dev": true, + "dependencies": { + "@chialab/estransform": "^0.18.0", + "@chialab/node-resolve": "^0.18.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@chialab/estransform": { + "version": "0.18.1", + "resolved": "https://registry.npmjs.org/@chialab/estransform/-/estransform-0.18.1.tgz", + "integrity": "sha512-W/WmjpQL2hndD0/XfR0FcPBAUj+aLNeoAVehOjV/Q9bSnioz0GVSAXXhzp59S33ZynxJBBfn8DNiMTVNJmk4Aw==", + "dev": true, + "dependencies": { + "@parcel/source-map": "^2.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@chialab/node-resolve": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/@chialab/node-resolve/-/node-resolve-0.18.0.tgz", + "integrity": "sha512-eV1m70Qn9pLY9xwFmZ2FlcOzwiaUywsJ7NB/ud8VB7DouvCQtIHkQ3Om7uPX0ojXGEG1LCyO96kZkvbNTxNu0Q==", + "dev": true, + "engines": { + "node": ">=18" + } + }, "node_modules/@esbuild/aix-ppc64": { "version": "0.20.2", "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.20.2.tgz", @@ -1183,6 +1234,31 @@ "node": ">=12" } }, + "node_modules/@jitl/quickjs-ffi-types": { + "version": "0.29.1", + "resolved": "https://registry.npmjs.org/@jitl/quickjs-ffi-types/-/quickjs-ffi-types-0.29.1.tgz", + "integrity": "sha512-dVt//PvFmwNJIwfyfPx7vR6cg7mLnAq6/THbhIeZ3NqXb66qXQATnW2gNqAnOcTh1D/f6HyrHFwRf3GdKUN3nw==" + }, + "node_modules/@jitl/quickjs-wasmfile-release-sync": { + "version": "0.29.1", + "resolved": "https://registry.npmjs.org/@jitl/quickjs-wasmfile-release-sync/-/quickjs-wasmfile-release-sync-0.29.1.tgz", + "integrity": "sha512-iVeMmZXIDg3gD0elfj5FscwrqGLmcglvpvWDIzs5tmzJ4AKiDAHXunGwd8X4gifeW6S+f0j681M8+tZuUIqnJA==", + "dependencies": { + "@jitl/quickjs-ffi-types": "0.29.1" + } + }, + "node_modules/@parcel/source-map": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/@parcel/source-map/-/source-map-2.1.1.tgz", + "integrity": "sha512-Ejx1P/mj+kMjQb8/y5XxDUn4reGdr+WyKYloBljpppUy8gs42T+BNoEOuRYqDVdgPc6NxduzIDoJS9pOFfV5Ew==", + "dev": true, + "dependencies": { + "detect-libc": "^1.0.3" + }, + "engines": { + "node": "^12.18.3 || >=14" + } + }, "node_modules/@smithy/abort-controller": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/@smithy/abort-controller/-/abort-controller-2.2.0.tgz", @@ -1825,6 +1901,18 @@ "resolved": "https://registry.npmjs.org/bowser/-/bowser-2.11.0.tgz", "integrity": "sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA==" }, + "node_modules/detect-libc": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", + "integrity": "sha512-pGjwhsmsp4kL2RTz08wcOlGN83otlqHeD/Z5T8GXZB+/YcpQ/dgo+lbU8ZsGxV0HIvqqxo9l7mqYwyYMD9bKDg==", + "dev": true, + "bin": { + "detect-libc": "bin/detect-libc.js" + }, + "engines": { + "node": ">=0.10" + } + }, "node_modules/esbuild": { "version": "0.20.2", "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.20.2.tgz", @@ -1892,6 +1980,35 @@ "node": ">=16.0.0" } }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "dev": true, + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/quickjs-emscripten-core": { + "version": "0.29.1", + "resolved": "https://registry.npmjs.org/quickjs-emscripten-core/-/quickjs-emscripten-core-0.29.1.tgz", + "integrity": "sha512-urFIWrPgKfzLFe/IwE8px3Oznb7UGsXpMjHLe15PTPbWongXmy6KAyxRpYFW8K/dDELilg0H/voysHbWHKj6uA==", + "dependencies": { + "@jitl/quickjs-ffi-types": "0.29.1" + } + }, "node_modules/strnum": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/strnum/-/strnum-1.0.5.tgz", diff --git a/__tests__/__fixtures__/examples-with-base/multi-output/package.json b/__tests__/__fixtures__/examples-with-base/multi-output/package.json index bdd5cf1..13038ee 100644 --- a/__tests__/__fixtures__/examples-with-base/multi-output/package.json +++ b/__tests__/__fixtures__/examples-with-base/multi-output/package.json @@ -3,10 +3,13 @@ "version": "1.0.0", "description": "test", "dependencies": { + "@jitl/quickjs-wasmfile-release-sync": "^0.29.1", + "quickjs-emscripten-core": "^0.29.1", "hono": "4.2.7", "@aws-sdk/client-s3": "3.556.0" }, "devDependencies": { + "@chialab/esbuild-plugin-meta-url": "^0.18.2", "esbuild": "0.20.2", "typescript": "^5.4.5" }, diff --git a/__tests__/__fixtures__/examples-with-base/multi-output/src/file-imported.ts b/__tests__/__fixtures__/examples-with-base/multi-output/src/file-imported.ts new file mode 100644 index 0000000..0b8abcf --- /dev/null +++ b/__tests__/__fixtures__/examples-with-base/multi-output/src/file-imported.ts @@ -0,0 +1,3 @@ +import { newQuickJSWASMModuleFromVariant } from "quickjs-emscripten-core" +import releaseVariant from "@jitl/quickjs-wasmfile-release-sync" +export const QuickJS = await newQuickJSWASMModuleFromVariant(releaseVariant) diff --git a/__tests__/no-base.test.ts b/__tests__/no-base.test.ts index 6deb090..93eb0c6 100644 --- a/__tests__/no-base.test.ts +++ b/__tests__/no-base.test.ts @@ -17,6 +17,7 @@ describe("examples w/o base analysis", () => { const input: Options = { analyzerDirectory: ".analyzer", budgetPercentIncreaseRed: 20, + includeExtensions: [".js", ".mjs", ".cjs"], metafiles: ["out/meta.json"], name: "test", showDetails: false, diff --git a/__tests__/with-base.test.ts b/__tests__/with-base.test.ts index 17a2f4f..980c801 100644 --- a/__tests__/with-base.test.ts +++ b/__tests__/with-base.test.ts @@ -26,6 +26,7 @@ describe("examples w/ base analysis", () => { const input: Options = { analyzerDirectory: ".analyzer", budgetPercentIncreaseRed: 20, + includeExtensions: [".js", ".mjs", ".cjs"], metafiles, name: "test", showDetails: false, @@ -45,6 +46,9 @@ describe("examples w/ base analysis", () => { const comment = readAnalysisComment(input.analyzerDirectory); expect(comment).not.toMatch(/no changes to the esbuild bundle/i); + expect(comment).not.include(".js.map"); + expect(comment).not.include(".wasm"); + expect(comment).toMatch(/\.[cm]?js /i); expect(comment).toMatch(/‼️ \+\d+/); expect(comment).toMatch(/⚠️ \+\d+/); expect(comment).toMatch(/✅ {2}-\d+/); diff --git a/action.yaml b/action.yaml index 3f47c92..877123c 100644 --- a/action.yaml +++ b/action.yaml @@ -36,6 +36,11 @@ inputs: default: ".analyzer" description: | A path to working directory where bundle analysis are stored. + include_extensions: + required: false + default: ".js,.cjs,.mjs" + description: | + A comma-separated list of file extension to be included in the analysis table. percent_extra_attention: required: false default: "20" @@ -67,6 +72,7 @@ runs: INPUT_METAFILES: ${{ inputs.metafiles }} INPUT_NAME: ${{ inputs.name }} INPUT_ANALYZE_DIRECTORY: ${{ inputs.analyze_directory }} + INPUT_INCLUDE_EXTENSIONS: ${{ inputs.include_extensions }} INPUT_PERCENT_EXTRA_ATTENTION: ${{ inputs.percent_extra_attention }} INPUT_SHOW_DETAILS: ${{ inputs.show_details }} run: | diff --git a/dist/index.mjs b/dist/index.mjs index fd188ce..fa38ee2 100644 --- a/dist/index.mjs +++ b/dist/index.mjs @@ -332,6 +332,11 @@ function getAllPageSizes(input) { const metaFileJson = loadMetaFile(metaFilePath); Object.entries(metaFileJson.outputs).reduce((acc3, output) => { const [outfile, buildMeta] = output; + if (!input.includeExtensions.some( + (ext) => outfile.toLowerCase().endsWith(ext) + )) { + return acc3; + } acc3[`${metafile} -> ${outfile}`] = { bytes: buildMeta.bytes, metafile, @@ -361,6 +366,7 @@ function getOptions() { showDetails: ["true", "True", "TRUE"].includes( getInput("show_details") || "true" ), + includeExtensions: (getInput("include_extensions") || ".js,.mjs,.cjs").split(","), name, analyzerDirectory: getInput("analyze_directory") || ".analyzer", metafiles: rawMetafiles.split(",") @@ -387,4 +393,4 @@ filesize/dist/filesize.esm.js: * @version 10.1.1 *) */ -//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/compare.ts", "../src/utils.ts", "../src/report.ts"],
  "sourcesContent": ["import { pathToFileURL } from \"node:url\";\nimport { compare } from \"./compare\";\nimport { report } from \"./report\";\nimport type { Options } from \"./types\";\nimport { getInput } from \"./utils\";\n\nfunction getOptions(): Options {\n\tconst rawMetafiles = getInput(\"metafiles\");\n\tif (!rawMetafiles) {\n\t\tthrow new Error(\"metafiles is not specified\");\n\t}\n\tconst name = getInput(\"name\");\n\tif (!name) {\n\t\tthrow new Error(\"name is not specified\");\n\t}\n\treturn {\n\t\tbudgetPercentIncreaseRed: Number.parseInt(\n\t\t\tgetInput(\"percent_extra_attention\") || \"20\",\n\t\t\t10,\n\t\t),\n\t\tshowDetails: [\"true\", \"True\", \"TRUE\"].includes(\n\t\t\tgetInput(\"show_details\") || \"true\",\n\t\t),\n\t\tname,\n\t\tanalyzerDirectory: getInput(\"analyze_directory\") || \".analyzer\",\n\t\tmetafiles: rawMetafiles.split(\",\"),\n\t};\n}\n\nexport function run(options: Options = getOptions()): void {\n\treport(options);\n\tcompare(options);\n}\n\nif (import.meta.url === pathToFileURL(process.argv[1]).href) {\n\trun();\n}\n", "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { filesize as originalFilesize } from \"filesize\";\nimport type { CompareResult, Options, Report } from \"./types\";\nimport { loadAnalysisJson } from \"./utils\";\n\nexport function compare(input: Options): void {\n\tlet hasAnyChange = false;\n\tlet output = `## \uD83D\uDCE6 esbuild Bundle Analysis for ${input.name}\n\nThis analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoego/esbuild-bundle-analyzer). \uD83E\uDD16\n`;\n\n\tconst current = loadAnalysisJson(\n\t\tpath.join(process.cwd(), input.analyzerDirectory, \"bundle_analysis.json\"),\n\t);\n\tlet base: Report;\n\ttry {\n\t\tbase = loadAnalysisJson(\n\t\t\tpath.join(\n\t\t\t\tprocess.cwd(),\n\t\t\t\tinput.analyzerDirectory,\n\t\t\t\t\"base/bundle/bundle_analysis.json\",\n\t\t\t),\n\t\t);\n\t} catch (e) {\n\t\tbase = {};\n\t}\n\n\tconst allOutFiles: string[] = [\n\t\t...new Set([...Object.keys(current), ...Object.keys(base)]),\n\t].sort();\n\tconst comparison: Array<CompareResult> = allOutFiles.map((outfile) => {\n\t\tconst currentStats = current[outfile];\n\t\tconst baseStats = base[outfile];\n\n\t\tif (!currentStats) {\n\t\t\thasAnyChange = true;\n\t\t\t// deleted out file\n\t\t\treturn { ...baseStats, diff: -1, remark: \"deleted\" };\n\t\t}\n\t\tif (!baseStats) {\n\t\t\thasAnyChange = true;\n\t\t\t// new out file\n\t\t\treturn { ...currentStats, diff: -1, remark: \"added\" };\n\t\t}\n\t\tconst diff = currentStats.bytes - baseStats.bytes;\n\t\tconst increase = !!Math.sign(diff);\n\t\tif (diff !== 0) {\n\t\t\thasAnyChange = true;\n\t\t}\n\t\treturn {\n\t\t\t...currentStats,\n\t\t\tdiff,\n\t\t\tremark: increase ? \"increased\" : \"decreased\",\n\t\t};\n\t});\n\n\tif (hasAnyChange) {\n\t\toutput += markdownTable(comparison, input.budgetPercentIncreaseRed);\n\n\t\tif (input.showDetails) {\n\t\t\toutput += `\\n<details>\n<summary>Details</summary>\n<p>Next to the size is how much the size has increased or decreased compared with the base branch of this PR.</p>\n<ul>\n<li>\u203C\uFE0F: Size increased by ${input.budgetPercentIncreaseRed}% or more. Special attention should be given to this.</li>\n<li>\u26A0\uFE0F: Size increased in acceptable range (lower than ${input.budgetPercentIncreaseRed}%).</li>\n<li>\u2705: No change or even downsized.</li>\n<li>\uD83D\uDDD1\uFE0F: The out file is deleted: not found in base branch.</li>\n<li>\uD83C\uDD95: The out file is newly found: will be added to base branch.</li>\n</ul>\n</details>\\n`;\n\t\t}\n\t} else {\n\t\toutput += \"This PR introduced no changes to the esbuild bundle! \uD83D\uDE4C\";\n\t}\n\n\t// we add this tag so that our action can be able to easily and\n\t// consistently find the right comment to edit as more commits are pushed.\n\toutput += `<!-- __ESBUILD_BUNDLE_${input.name} -->`;\n\n\t// Log mostly for testing and debugging.\n\t// This will show up in the github actions console.\n\tconsole.dir({\n\t\tinput,\n\t\thasAnyChange,\n\t\toutput,\n\t});\n\n\t// Write the output to a file which is later read in\n\t// as comment contents by the actions workflow.\n\tfs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), {\n\t\trecursive: true,\n\t});\n\tfs.writeFileSync(\n\t\tpath.join(\n\t\t\tprocess.cwd(),\n\t\t\tinput.analyzerDirectory,\n\t\t\t\"bundle_analysis_comment.txt\",\n\t\t),\n\t\toutput.trim(),\n\t);\n}\n\nfunction filesize(bytes: number): string {\n\treturn originalFilesize(bytes, {\n\t\tspacer: \"\u00A0\",\n\t});\n}\n\nfunction markdownTable(\n\tdata: Array<CompareResult>,\n\tredThreshold: number,\n): string {\n\tconst rows = data\n\t\t.map((d) => {\n\t\t\treturn `${d.metafile} | ${d.outfile} | ${renderSize(d)} | ${renderNote(\n\t\t\t\td,\n\t\t\t\tredThreshold,\n\t\t\t)}\\n`;\n\t\t})\n\t\t.join(\"\");\n\n\treturn `\nMeta File | Out File  | Size (raw) | Note \n----------|----------|-----------:|------\n${rows}`;\n}\n\nfunction renderSize(d: CompareResult): string {\n\treturn filesize(d.bytes);\n}\n\nfunction renderNote(d: CompareResult, redThreshold: number): string {\n\tif (d.remark === \"deleted\") {\n\t\treturn \"\uD83D\uDDD1\uFE0F Deleted\";\n\t}\n\tif (d.remark === \"added\") {\n\t\treturn \"\uD83C\uDD95 Added\";\n\t}\n\tif (d.diff) {\n\t\tconst percentChange = (d.diff / d.bytes) * 100;\n\t\treturn `${renderStatusIndicator(percentChange, redThreshold)}${filesize(\n\t\t\td.diff,\n\t\t)} (${sign(percentChange)}${percentChange.toFixed(1)}%)`;\n\t}\n\treturn \"\u2705  No change\";\n}\n\nfunction sign(num: number): string {\n\treturn num < 0 ? \"\" : \"+\";\n}\n\nfunction renderStatusIndicator(\n\tpercentChange: number,\n\tredThreshold: number,\n): string {\n\tlet res: string;\n\tif (percentChange > 0 && percentChange < redThreshold) {\n\t\tres = \"\u26A0\uFE0F\";\n\t} else if (percentChange >= redThreshold) {\n\t\tres = \"\u203C\uFE0F\";\n\t} else {\n\t\tres = \"\u2705 \";\n\t}\n\treturn `${res} ${sign(percentChange)}`;\n}\n", "import fs from \"node:fs\";\n\nimport type { Metafile } from \"esbuild\";\nimport type { Report } from \"./types\";\n\nfunction loadJsonFile(path: string) {\n\treturn JSON.parse(fs.readFileSync(path).toString(\"utf-8\"));\n}\n\nexport function loadMetaFile(path: string): Metafile {\n\treturn loadJsonFile(path) as Metafile;\n}\n\nexport function loadAnalysisJson(path: string): Report {\n\treturn loadJsonFile(path) as Report;\n}\n\n// https://github.com/actions/toolkit/blob/81a73aba8bedd532f6eddcc41ed3a0fad8b1cfeb/packages/core/src/core.ts#L126\nexport function getInput(name: string): string {\n\tconst val = process.env[`INPUT_${name.toUpperCase()}`] || \"\";\n\treturn val.trim();\n}\n", "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport process from \"node:process\";\n\nimport type { Options, Report } from \"./types\";\nimport { loadMetaFile } from \"./utils\";\n\nexport function report(input: Options): void {\n\tconst allPageSizes = getAllPageSizes(input);\n\tfs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), {\n\t\trecursive: true,\n\t});\n\tconst resultJsonPath = path.join(\n\t\tprocess.cwd(),\n\t\tinput.analyzerDirectory,\n\t\t\"bundle_analysis.json\",\n\t);\n\tfs.writeFileSync(resultJsonPath, JSON.stringify(allPageSizes, null, 2));\n\tconsole.log(`Wrote ${resultJsonPath}`);\n}\n\nfunction getAllPageSizes(input: Options): Report {\n\tconst acc: Report = {};\n\treturn input.metafiles.reduce((acc, metafile) => {\n\t\tconst metaFilePath = path.join(process.cwd(), metafile);\n\t\ttry {\n\t\t\tfs.accessSync(metaFilePath, fs.constants.R_OK);\n\t\t} catch (err) {\n\t\t\tconsole.error(\n\t\t\t\t`No meta file found at \"${metaFilePath}\" - a path to meta file may be wrong, or esbuild is not executed.`,\n\t\t\t);\n\t\t\tprocess.exit(1);\n\t\t}\n\n\t\tconst metaFileJson = loadMetaFile(metaFilePath);\n\t\tObject.entries(metaFileJson.outputs).reduce((acc, output) => {\n\t\t\tconst [outfile, buildMeta] = output;\n\t\t\tacc[`${metafile} -> ${outfile}`] = {\n\t\t\t\tbytes: buildMeta.bytes,\n\t\t\t\tmetafile,\n\t\t\t\toutfile,\n\t\t\t};\n\t\t\treturn acc;\n\t\t}, acc);\n\t\treturn acc;\n\t}, acc);\n}\n"],
  "mappings": ";AAAA,SAAS,qBAAqB;;;ACA9B,OAAOA,SAAQ;AACf,OAAO,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACDjB,OAAO,QAAQ;AAKf,SAAS,aAAaC,OAAc;AACnC,SAAO,KAAK,MAAM,GAAG,aAAaA,KAAI,EAAE,SAAS,OAAO,CAAC;AAC1D;AAEO,SAAS,aAAaA,OAAwB;AACpD,SAAO,aAAaA,KAAI;AACzB;AAEO,SAAS,iBAAiBA,OAAsB;AACtD,SAAO,aAAaA,KAAI;AACzB;AAGO,SAAS,SAAS,MAAsB;AAC9C,QAAM,MAAM,QAAQ,IAAI,SAAS,KAAK,YAAY,CAAC,EAAE,KAAK;AAC1D,SAAO,IAAI,KAAK;AACjB;;;ADfO,SAAS,QAAQ,OAAsB;AAC7C,MAAI,eAAe;AACnB,MAAI,SAAS,4CAAqC,MAAM,IAAI;AAAA;AAAA;AAAA;AAK5D,QAAM,UAAU;AAAA,IACf,KAAK,KAAK,QAAQ,IAAI,GAAG,MAAM,mBAAmB,sBAAsB;AAAA,EACzE;AACA,MAAI;AACJ,MAAI;AACH,WAAO;AAAA,MACN,KAAK;AAAA,QACJ,QAAQ,IAAI;AAAA,QACZ,MAAM;AAAA,QACN;AAAA,MACD;AAAA,IACD;AAAA,EACD,SAAS,GAAG;AACX,WAAO,CAAC;AAAA,EACT;AAEA,QAAM,cAAwB;AAAA,IAC7B,GAAG,oBAAI,IAAI,CAAC,GAAG,OAAO,KAAK,OAAO,GAAG,GAAG,OAAO,KAAK,IAAI,CAAC,CAAC;AAAA,EAC3D,EAAE,KAAK;AACP,QAAM,aAAmC,YAAY,IAAI,CAAC,YAAY;AACrE,UAAM,eAAe,QAAQ,OAAO;AACpC,UAAM,YAAY,KAAK,OAAO;AAE9B,QAAI,CAAC,cAAc;AAClB,qBAAe;AAEf,aAAO,EAAE,GAAG,WAAW,MAAM,IAAI,QAAQ,UAAU;AAAA,IACpD;AACA,QAAI,CAAC,WAAW;AACf,qBAAe;AAEf,aAAO,EAAE,GAAG,cAAc,MAAM,IAAI,QAAQ,QAAQ;AAAA,IACrD;AACA,UAAM,OAAO,aAAa,QAAQ,UAAU;AAC5C,UAAM,WAAW,CAAC,CAAC,KAAK,KAAK,IAAI;AACjC,QAAI,SAAS,GAAG;AACf,qBAAe;AAAA,IAChB;AACA,WAAO;AAAA,MACN,GAAG;AAAA,MACH;AAAA,MACA,QAAQ,WAAW,cAAc;AAAA,IAClC;AAAA,EACD,CAAC;AAED,MAAI,cAAc;AACjB,cAAU,cAAc,YAAY,MAAM,wBAAwB;AAElE,QAAI,MAAM,aAAa;AACtB,gBAAU;AAAA;AAAA;AAAA;AAAA;AAAA,sCAIe,MAAM,wBAAwB;AAAA,mEACD,MAAM,wBAAwB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMrF;AAAA,EACD,OAAO;AACN,cAAU;AAAA,EACX;AAIA,YAAU,yBAAyB,MAAM,IAAI;AAI7C,UAAQ,IAAI;AAAA,IACX;AAAA,IACA;AAAA,IACA;AAAA,EACD,CAAC;AAID,EAAAC,IAAG,UAAU,KAAK,KAAK,QAAQ,IAAI,GAAG,MAAM,iBAAiB,GAAG;AAAA,IAC/D,WAAW;AAAA,EACZ,CAAC;AACD,EAAAA,IAAG;AAAA,IACF,KAAK;AAAA,MACJ,QAAQ,IAAI;AAAA,MACZ,MAAM;AAAA,MACN;AAAA,IACD;AAAA,IACA,OAAO,KAAK;AAAA,EACb;AACD;AAEA,SAASC,UAAS,OAAuB;AACxC,SAAO,SAAiB,OAAO;AAAA,IAC9B,QAAQ;AAAA,EACT,CAAC;AACF;AAEA,SAAS,cACR,MACA,cACS;AACT,QAAM,OAAO,KACX,IAAI,CAAC,MAAM;AACX,WAAO,GAAG,EAAE,QAAQ,MAAM,EAAE,OAAO,MAAM,WAAW,CAAC,CAAC,MAAM;AAAA,MAC3D;AAAA,MACA;AAAA,IACD,CAAC;AAAA;AAAA,EACF,CAAC,EACA,KAAK,EAAE;AAET,SAAO;AAAA;AAAA;AAAA,EAGN,IAAI;AACN;AAEA,SAAS,WAAW,GAA0B;AAC7C,SAAOA,UAAS,EAAE,KAAK;AACxB;AAEA,SAAS,WAAW,GAAkB,cAA8B;AACnE,MAAI,EAAE,WAAW,WAAW;AAC3B,WAAO;AAAA,EACR;AACA,MAAI,EAAE,WAAW,SAAS;AACzB,WAAO;AAAA,EACR;AACA,MAAI,EAAE,MAAM;AACX,UAAM,gBAAiB,EAAE,OAAO,EAAE,QAAS;AAC3C,WAAO,GAAG,sBAAsB,eAAe,YAAY,CAAC,GAAGA;AAAA,MAC9D,EAAE;AAAA,IACH,CAAC,KAAK,KAAK,aAAa,CAAC,GAAG,cAAc,QAAQ,CAAC,CAAC;AAAA,EACrD;AACA,SAAO;AACR;AAEA,SAAS,KAAK,KAAqB;AAClC,SAAO,MAAM,IAAI,KAAK;AACvB;AAEA,SAAS,sBACR,eACA,cACS;AACT,MAAI;AACJ,MAAI,gBAAgB,KAAK,gBAAgB,cAAc;AACtD,UAAM;AAAA,EACP,WAAW,iBAAiB,cAAc;AACzC,UAAM;AAAA,EACP,OAAO;AACN,UAAM;AAAA,EACP;AACA,SAAO,GAAG,GAAG,IAAI,KAAK,aAAa,CAAC;AACrC;;;AEvKA,OAAOC,SAAQ;AACf,OAAOC,WAAU;AACjB,OAAOC,cAAa;AAKb,SAAS,OAAO,OAAsB;AAC5C,QAAM,eAAe,gBAAgB,KAAK;AAC1C,EAAAC,IAAG,UAAUC,MAAK,KAAKC,SAAQ,IAAI,GAAG,MAAM,iBAAiB,GAAG;AAAA,IAC/D,WAAW;AAAA,EACZ,CAAC;AACD,QAAM,iBAAiBD,MAAK;AAAA,IAC3BC,SAAQ,IAAI;AAAA,IACZ,MAAM;AAAA,IACN;AAAA,EACD;AACA,EAAAF,IAAG,cAAc,gBAAgB,KAAK,UAAU,cAAc,MAAM,CAAC,CAAC;AACtE,UAAQ,IAAI,SAAS,cAAc,EAAE;AACtC;AAEA,SAAS,gBAAgB,OAAwB;AAChD,QAAM,MAAc,CAAC;AACrB,SAAO,MAAM,UAAU,OAAO,CAACG,MAAK,aAAa;AAChD,UAAM,eAAeF,MAAK,KAAKC,SAAQ,IAAI,GAAG,QAAQ;AACtD,QAAI;AACH,MAAAF,IAAG,WAAW,cAAcA,IAAG,UAAU,IAAI;AAAA,IAC9C,SAAS,KAAK;AACb,cAAQ;AAAA,QACP,0BAA0B,YAAY;AAAA,MACvC;AACA,MAAAE,SAAQ,KAAK,CAAC;AAAA,IACf;AAEA,UAAM,eAAe,aAAa,YAAY;AAC9C,WAAO,QAAQ,aAAa,OAAO,EAAE,OAAO,CAACC,MAAK,WAAW;AAC5D,YAAM,CAAC,SAAS,SAAS,IAAI;AAC7B,MAAAA,KAAI,GAAG,QAAQ,OAAO,OAAO,EAAE,IAAI;AAAA,QAClC,OAAO,UAAU;AAAA,QACjB;AAAA,QACA;AAAA,MACD;AACA,aAAOA;AAAA,IACR,GAAGA,IAAG;AACN,WAAOA;AAAA,EACR,GAAG,GAAG;AACP;;;AHxCA,SAAS,aAAsB;AAC9B,QAAM,eAAe,SAAS,WAAW;AACzC,MAAI,CAAC,cAAc;AAClB,UAAM,IAAI,MAAM,4BAA4B;AAAA,EAC7C;AACA,QAAM,OAAO,SAAS,MAAM;AAC5B,MAAI,CAAC,MAAM;AACV,UAAM,IAAI,MAAM,uBAAuB;AAAA,EACxC;AACA,SAAO;AAAA,IACN,0BAA0B,OAAO;AAAA,MAChC,SAAS,yBAAyB,KAAK;AAAA,MACvC;AAAA,IACD;AAAA,IACA,aAAa,CAAC,QAAQ,QAAQ,MAAM,EAAE;AAAA,MACrC,SAAS,cAAc,KAAK;AAAA,IAC7B;AAAA,IACA;AAAA,IACA,mBAAmB,SAAS,mBAAmB,KAAK;AAAA,IACpD,WAAW,aAAa,MAAM,GAAG;AAAA,EAClC;AACD;AAEO,SAAS,IAAI,UAAmB,WAAW,GAAS;AAC1D,SAAO,OAAO;AACd,UAAQ,OAAO;AAChB;AAEA,IAAI,YAAY,QAAQ,cAAc,QAAQ,KAAK,CAAC,CAAC,EAAE,MAAM;AAC5D,MAAI;AACL;",
  "names": ["fs", "path", "fs", "filesize", "fs", "path", "process", "fs", "path", "process", "acc"]
}
 +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/compare.ts", "../src/utils.ts", "../src/report.ts"],
  "sourcesContent": ["import { pathToFileURL } from \"node:url\";\nimport { compare } from \"./compare\";\nimport { report } from \"./report\";\nimport type { Options } from \"./types\";\nimport { getInput } from \"./utils\";\n\nfunction getOptions(): Options {\n\tconst rawMetafiles = getInput(\"metafiles\");\n\tif (!rawMetafiles) {\n\t\tthrow new Error(\"metafiles is not specified\");\n\t}\n\tconst name = getInput(\"name\");\n\tif (!name) {\n\t\tthrow new Error(\"name is not specified\");\n\t}\n\treturn {\n\t\tbudgetPercentIncreaseRed: Number.parseInt(\n\t\t\tgetInput(\"percent_extra_attention\") || \"20\",\n\t\t\t10,\n\t\t),\n\t\tshowDetails: [\"true\", \"True\", \"TRUE\"].includes(\n\t\t\tgetInput(\"show_details\") || \"true\",\n\t\t),\n\t\tincludeExtensions: (\n\t\t\tgetInput(\"include_extensions\") || \".js,.mjs,.cjs\"\n\t\t).split(\",\"),\n\t\tname,\n\t\tanalyzerDirectory: getInput(\"analyze_directory\") || \".analyzer\",\n\t\tmetafiles: rawMetafiles.split(\",\"),\n\t};\n}\n\nexport function run(options: Options = getOptions()): void {\n\treport(options);\n\tcompare(options);\n}\n\nif (import.meta.url === pathToFileURL(process.argv[1]).href) {\n\trun();\n}\n", "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { filesize as originalFilesize } from \"filesize\";\nimport type { CompareResult, Options, Report } from \"./types\";\nimport { loadAnalysisJson } from \"./utils\";\n\nexport function compare(input: Options): void {\n\tlet hasAnyChange = false;\n\tlet output = `## \uD83D\uDCE6 esbuild Bundle Analysis for ${input.name}\n\nThis analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoego/esbuild-bundle-analyzer). \uD83E\uDD16\n`;\n\n\tconst current = loadAnalysisJson(\n\t\tpath.join(process.cwd(), input.analyzerDirectory, \"bundle_analysis.json\"),\n\t);\n\tlet base: Report;\n\ttry {\n\t\tbase = loadAnalysisJson(\n\t\t\tpath.join(\n\t\t\t\tprocess.cwd(),\n\t\t\t\tinput.analyzerDirectory,\n\t\t\t\t\"base/bundle/bundle_analysis.json\",\n\t\t\t),\n\t\t);\n\t} catch (e) {\n\t\tbase = {};\n\t}\n\n\tconst allOutFiles: string[] = [\n\t\t...new Set([...Object.keys(current), ...Object.keys(base)]),\n\t].sort();\n\tconst comparison: Array<CompareResult> = allOutFiles.map((outfile) => {\n\t\tconst currentStats = current[outfile];\n\t\tconst baseStats = base[outfile];\n\n\t\tif (!currentStats) {\n\t\t\thasAnyChange = true;\n\t\t\t// deleted out file\n\t\t\treturn { ...baseStats, diff: -1, remark: \"deleted\" };\n\t\t}\n\t\tif (!baseStats) {\n\t\t\thasAnyChange = true;\n\t\t\t// new out file\n\t\t\treturn { ...currentStats, diff: -1, remark: \"added\" };\n\t\t}\n\t\tconst diff = currentStats.bytes - baseStats.bytes;\n\t\tconst increase = !!Math.sign(diff);\n\t\tif (diff !== 0) {\n\t\t\thasAnyChange = true;\n\t\t}\n\t\treturn {\n\t\t\t...currentStats,\n\t\t\tdiff,\n\t\t\tremark: increase ? \"increased\" : \"decreased\",\n\t\t};\n\t});\n\n\tif (hasAnyChange) {\n\t\toutput += markdownTable(comparison, input.budgetPercentIncreaseRed);\n\n\t\tif (input.showDetails) {\n\t\t\toutput += `\\n<details>\n<summary>Details</summary>\n<p>Next to the size is how much the size has increased or decreased compared with the base branch of this PR.</p>\n<ul>\n<li>\u203C\uFE0F: Size increased by ${input.budgetPercentIncreaseRed}% or more. Special attention should be given to this.</li>\n<li>\u26A0\uFE0F: Size increased in acceptable range (lower than ${input.budgetPercentIncreaseRed}%).</li>\n<li>\u2705: No change or even downsized.</li>\n<li>\uD83D\uDDD1\uFE0F: The out file is deleted: not found in base branch.</li>\n<li>\uD83C\uDD95: The out file is newly found: will be added to base branch.</li>\n</ul>\n</details>\\n`;\n\t\t}\n\t} else {\n\t\toutput += \"This PR introduced no changes to the esbuild bundle! \uD83D\uDE4C\";\n\t}\n\n\t// we add this tag so that our action can be able to easily and\n\t// consistently find the right comment to edit as more commits are pushed.\n\toutput += `<!-- __ESBUILD_BUNDLE_${input.name} -->`;\n\n\t// Log mostly for testing and debugging.\n\t// This will show up in the github actions console.\n\tconsole.dir({\n\t\tinput,\n\t\thasAnyChange,\n\t\toutput,\n\t});\n\n\t// Write the output to a file which is later read in\n\t// as comment contents by the actions workflow.\n\tfs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), {\n\t\trecursive: true,\n\t});\n\tfs.writeFileSync(\n\t\tpath.join(\n\t\t\tprocess.cwd(),\n\t\t\tinput.analyzerDirectory,\n\t\t\t\"bundle_analysis_comment.txt\",\n\t\t),\n\t\toutput.trim(),\n\t);\n}\n\nfunction filesize(bytes: number): string {\n\treturn originalFilesize(bytes, {\n\t\tspacer: \"\u00A0\",\n\t});\n}\n\nfunction markdownTable(\n\tdata: Array<CompareResult>,\n\tredThreshold: number,\n): string {\n\tconst rows = data\n\t\t.map((d) => {\n\t\t\treturn `${d.metafile} | ${d.outfile} | ${renderSize(d)} | ${renderNote(\n\t\t\t\td,\n\t\t\t\tredThreshold,\n\t\t\t)}\\n`;\n\t\t})\n\t\t.join(\"\");\n\n\treturn `\nMeta File | Out File  | Size (raw) | Note \n----------|----------|-----------:|------\n${rows}`;\n}\n\nfunction renderSize(d: CompareResult): string {\n\treturn filesize(d.bytes);\n}\n\nfunction renderNote(d: CompareResult, redThreshold: number): string {\n\tif (d.remark === \"deleted\") {\n\t\treturn \"\uD83D\uDDD1\uFE0F Deleted\";\n\t}\n\tif (d.remark === \"added\") {\n\t\treturn \"\uD83C\uDD95 Added\";\n\t}\n\tif (d.diff) {\n\t\tconst percentChange = (d.diff / d.bytes) * 100;\n\t\treturn `${renderStatusIndicator(percentChange, redThreshold)}${filesize(\n\t\t\td.diff,\n\t\t)} (${sign(percentChange)}${percentChange.toFixed(1)}%)`;\n\t}\n\treturn \"\u2705  No change\";\n}\n\nfunction sign(num: number): string {\n\treturn num < 0 ? \"\" : \"+\";\n}\n\nfunction renderStatusIndicator(\n\tpercentChange: number,\n\tredThreshold: number,\n): string {\n\tlet res: string;\n\tif (percentChange > 0 && percentChange < redThreshold) {\n\t\tres = \"\u26A0\uFE0F\";\n\t} else if (percentChange >= redThreshold) {\n\t\tres = \"\u203C\uFE0F\";\n\t} else {\n\t\tres = \"\u2705 \";\n\t}\n\treturn `${res} ${sign(percentChange)}`;\n}\n", "import fs from \"node:fs\";\n\nimport type { Metafile } from \"esbuild\";\nimport type { Report } from \"./types\";\n\nfunction loadJsonFile(path: string) {\n\treturn JSON.parse(fs.readFileSync(path).toString(\"utf-8\"));\n}\n\nexport function loadMetaFile(path: string): Metafile {\n\treturn loadJsonFile(path) as Metafile;\n}\n\nexport function loadAnalysisJson(path: string): Report {\n\treturn loadJsonFile(path) as Report;\n}\n\n// https://github.com/actions/toolkit/blob/81a73aba8bedd532f6eddcc41ed3a0fad8b1cfeb/packages/core/src/core.ts#L126\nexport function getInput(name: string): string {\n\tconst val = process.env[`INPUT_${name.toUpperCase()}`] || \"\";\n\treturn val.trim();\n}\n", "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport process from \"node:process\";\n\nimport type { Options, Report } from \"./types\";\nimport { loadMetaFile } from \"./utils\";\n\nexport function report(input: Options): void {\n\tconst allPageSizes = getAllPageSizes(input);\n\tfs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), {\n\t\trecursive: true,\n\t});\n\tconst resultJsonPath = path.join(\n\t\tprocess.cwd(),\n\t\tinput.analyzerDirectory,\n\t\t\"bundle_analysis.json\",\n\t);\n\tfs.writeFileSync(resultJsonPath, JSON.stringify(allPageSizes, null, 2));\n\tconsole.log(`Wrote ${resultJsonPath}`);\n}\n\nfunction getAllPageSizes(input: Options): Report {\n\tconst acc: Report = {};\n\treturn input.metafiles.reduce((acc, metafile) => {\n\t\tconst metaFilePath = path.join(process.cwd(), metafile);\n\t\ttry {\n\t\t\tfs.accessSync(metaFilePath, fs.constants.R_OK);\n\t\t} catch (err) {\n\t\t\tconsole.error(\n\t\t\t\t`No meta file found at \"${metaFilePath}\" - a path to meta file may be wrong, or esbuild is not executed.`,\n\t\t\t);\n\t\t\tprocess.exit(1);\n\t\t}\n\n\t\tconst metaFileJson = loadMetaFile(metaFilePath);\n\t\tObject.entries(metaFileJson.outputs).reduce((acc, output) => {\n\t\t\tconst [outfile, buildMeta] = output;\n\t\t\tif (\n\t\t\t\t!input.includeExtensions.some((ext) =>\n\t\t\t\t\toutfile.toLowerCase().endsWith(ext),\n\t\t\t\t)\n\t\t\t) {\n\t\t\t\treturn acc;\n\t\t\t}\n\t\t\tacc[`${metafile} -> ${outfile}`] = {\n\t\t\t\tbytes: buildMeta.bytes,\n\t\t\t\tmetafile,\n\t\t\t\toutfile,\n\t\t\t};\n\t\t\treturn acc;\n\t\t}, acc);\n\t\treturn acc;\n\t}, acc);\n}\n"],
  "mappings": "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",
  "names": ["fs", "path", "fs", "filesize", "fs", "path", "process", "fs", "path", "process", "acc"]
}
 diff --git a/src/index.ts b/src/index.ts index 0c5da57..95d94a2 100644 --- a/src/index.ts +++ b/src/index.ts @@ -21,6 +21,9 @@ function getOptions(): Options { showDetails: ["true", "True", "TRUE"].includes( getInput("show_details") || "true", ), + includeExtensions: ( + getInput("include_extensions") || ".js,.mjs,.cjs" + ).split(","), name, analyzerDirectory: getInput("analyze_directory") || ".analyzer", metafiles: rawMetafiles.split(","), diff --git a/src/report.ts b/src/report.ts index 5e51672..ab99d80 100644 --- a/src/report.ts +++ b/src/report.ts @@ -35,6 +35,13 @@ function getAllPageSizes(input: Options): Report { const metaFileJson = loadMetaFile(metaFilePath); Object.entries(metaFileJson.outputs).reduce((acc, output) => { const [outfile, buildMeta] = output; + if ( + !input.includeExtensions.some((ext) => + outfile.toLowerCase().endsWith(ext), + ) + ) { + return acc; + } acc[`${metafile} -> ${outfile}`] = { bytes: buildMeta.bytes, metafile, diff --git a/src/types.ts b/src/types.ts index 3731377..200cd5b 100644 --- a/src/types.ts +++ b/src/types.ts @@ -16,6 +16,7 @@ export interface CompareResult { export interface Options { name: string; metafiles: Array; + includeExtensions: Array; analyzerDirectory: string; budgetPercentIncreaseRed: number; showDetails: boolean;