@nlabs/lex 1.46.2 → 1.47.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/__mocks__/LexConfig.js +20 -0
  2. package/__mocks__/boxen.js +7 -0
  3. package/__mocks__/build.js +16 -0
  4. package/__mocks__/chalk.js +23 -0
  5. package/__mocks__/compile.js +8 -0
  6. package/__mocks__/execa.js +21 -0
  7. package/__mocks__/ora.js +17 -0
  8. package/__mocks__/versions.js +12 -0
  9. package/dist/LexConfig.js +72 -14
  10. package/dist/commands/ai/ai.js +303 -0
  11. package/dist/commands/ai/index.js +7 -0
  12. package/dist/commands/build/build.js +350 -0
  13. package/dist/commands/clean/clean.js +31 -0
  14. package/dist/commands/compile/compile.js +195 -0
  15. package/dist/commands/config/config.js +43 -0
  16. package/dist/commands/copy/copy.js +38 -0
  17. package/dist/commands/create/create.js +124 -0
  18. package/dist/commands/dev/dev.js +70 -0
  19. package/dist/commands/init/init.js +93 -0
  20. package/dist/commands/link/link.js +15 -0
  21. package/dist/commands/lint/lint.js +656 -0
  22. package/dist/commands/migrate/migrate.js +37 -0
  23. package/dist/commands/publish/publish.js +104 -0
  24. package/dist/commands/test/test.js +327 -0
  25. package/dist/commands/update/update.js +62 -0
  26. package/dist/commands/upgrade/upgrade.js +47 -0
  27. package/dist/commands/versions/versions.js +41 -0
  28. package/dist/create/changelog.js +3 -3
  29. package/dist/index.js +35 -0
  30. package/dist/jest.config.lex.d.ts +2 -0
  31. package/dist/lex.js +25 -22
  32. package/dist/types.js +1 -0
  33. package/dist/utils/aiService.js +290 -0
  34. package/dist/utils/app.js +3 -3
  35. package/dist/utils/file.js +1 -1
  36. package/dist/utils/log.js +2 -1
  37. package/dist/utils/reactShim.js +3 -3
  38. package/dist/webpack.config.d.ts +2 -0
  39. package/eslint.config.js +10 -0
  40. package/index.cjs +20 -0
  41. package/jest.config.cjs +31 -27
  42. package/jest.config.lex.js +90 -38
  43. package/jest.setup.js +5 -0
  44. package/lex.config.js +50 -0
  45. package/package.json +69 -52
  46. package/{.postcssrc.js → postcss.config.js} +21 -9
  47. package/tsconfig.json +2 -1
  48. package/webpack.config.js +27 -11
  49. package/dist/commands/build.js +0 -265
  50. package/dist/commands/bulid.test.js +0 -317
  51. package/dist/commands/clean.js +0 -31
  52. package/dist/commands/clean.test.js +0 -63
  53. package/dist/commands/compile.js +0 -195
  54. package/dist/commands/compile.test.js +0 -93
  55. package/dist/commands/config.js +0 -43
  56. package/dist/commands/copy.js +0 -38
  57. package/dist/commands/create.js +0 -120
  58. package/dist/commands/dev.js +0 -70
  59. package/dist/commands/init.js +0 -93
  60. package/dist/commands/link.js +0 -15
  61. package/dist/commands/lint.js +0 -179
  62. package/dist/commands/migrate.js +0 -37
  63. package/dist/commands/publish.js +0 -104
  64. package/dist/commands/test.js +0 -190
  65. package/dist/commands/update.js +0 -64
  66. package/dist/commands/upgrade.js +0 -47
  67. package/dist/commands/versions.js +0 -41
  68. package/dist/commands/versions.test.js +0 -49
  69. package/dist/lint.js +0 -11
  70. package/jest.setup.ts +0 -3
@@ -1,265 +0,0 @@
1
- import GraphqlLoaderPlugin from "@luckycatfactory/esbuild-graphql-loader";
2
- import { execa } from "execa";
3
- import { readFileSync } from "fs";
4
- import { sync as globSync } from "glob";
5
- import { resolve as pathResolve } from "path";
6
- import { URL } from "url";
7
- import { LexConfig } from "../LexConfig.js";
8
- import { checkLinkedModules, createSpinner, removeFiles } from "../utils/app.js";
9
- import { relativeNodePath } from "../utils/file.js";
10
- import { log } from "../utils/log.js";
11
- const buildWithEsBuild = async (spinner, commandOptions, callback) => {
12
- const {
13
- cliName = "Lex",
14
- format = "cjs",
15
- outputPath,
16
- quiet,
17
- sourcePath,
18
- watch
19
- } = commandOptions;
20
- const {
21
- outputFullPath,
22
- sourceFullPath,
23
- targetEnvironment,
24
- useGraphQl,
25
- useTypescript
26
- } = LexConfig.config;
27
- const sourceDir = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath;
28
- const loader = {
29
- ".js": "js"
30
- };
31
- if (useTypescript) {
32
- loader[".ts"] = "ts";
33
- loader[".tsx"] = "tsx";
34
- }
35
- const plugins = [];
36
- if (useGraphQl) {
37
- plugins.push(GraphqlLoaderPlugin());
38
- }
39
- const globOptions = {
40
- cwd: sourceDir,
41
- dot: false,
42
- nodir: true,
43
- nosort: true
44
- };
45
- const tsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);
46
- const jsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);
47
- const sourceFiles = [...tsFiles, ...jsFiles];
48
- const packageJsonData = readFileSync(pathResolve(process.cwd(), "./package.json"));
49
- const packageJson = JSON.parse(packageJsonData.toString());
50
- const external = [
51
- ...Object.keys(packageJson.dependencies || {}),
52
- ...Object.keys(packageJson.peerDependencies || {})
53
- ];
54
- const dirName = new URL(".", import.meta.url).pathname;
55
- const dirPath = pathResolve(dirName, "../..");
56
- const outputDir = outputPath || outputFullPath;
57
- const esbuildPath = relativeNodePath("esbuild/bin/esbuild", dirPath);
58
- const esbuildOptions = [
59
- ...sourceFiles,
60
- "--bundle",
61
- "--color=true",
62
- `--format=${format}`,
63
- `--outdir=${outputDir}`,
64
- "--platform=node",
65
- "--format=cjs",
66
- "--sourcemap=inline",
67
- `--target=${targetEnvironment === "node" ? "node20" : "es2018"}`
68
- ];
69
- if (external.length) {
70
- esbuildOptions.push(`--external:${external.join(",")}`);
71
- }
72
- if (plugins.length) {
73
- esbuildOptions.push(`--plugins=${plugins.join(",")}`);
74
- }
75
- if (watch) {
76
- esbuildOptions.push("--watch");
77
- }
78
- try {
79
- await execa(esbuildPath, esbuildOptions, { encoding: "utf8" });
80
- spinner.succeed("Build completed successfully!");
81
- } catch (error) {
82
- log(`
83
- ${cliName} Error: ${error.message}`, "error", quiet);
84
- if (!quiet) {
85
- console.error(error);
86
- }
87
- spinner.fail("Code build failed.");
88
- callback(1);
89
- return 1;
90
- }
91
- callback(0);
92
- return 0;
93
- };
94
- const buildWithWebpack = async (spinner, cmd, callback) => {
95
- const {
96
- analyze,
97
- cliName = "Lex",
98
- config,
99
- configName,
100
- defineProcessEnvNodeEnv,
101
- devtool,
102
- disableInterpret,
103
- entry,
104
- env,
105
- failOnWarnings,
106
- json,
107
- merge,
108
- mode,
109
- name,
110
- nodeEnv,
111
- noDevtool,
112
- noStats,
113
- noTarget,
114
- noWatch,
115
- noWatchOptionsStdin,
116
- outputPath,
117
- quiet = false,
118
- stats,
119
- target,
120
- watch,
121
- watchOptionsStdin
122
- } = cmd;
123
- let webpackConfig;
124
- const dirName = new URL(".", import.meta.url).pathname;
125
- if (config) {
126
- const isRelativeConfig = config.substr(0, 2) === "./";
127
- webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
128
- } else {
129
- webpackConfig = pathResolve(dirName, "../../webpack.config.js");
130
- }
131
- const webpackOptions = [
132
- "--color",
133
- "--progress",
134
- "--config",
135
- webpackConfig
136
- ];
137
- if (analyze) {
138
- webpackOptions.push("--analyze");
139
- }
140
- if (configName) {
141
- webpackOptions.push("--configName", configName);
142
- }
143
- if (defineProcessEnvNodeEnv) {
144
- webpackOptions.push("--defineProcessEnvNodeEnv", defineProcessEnvNodeEnv);
145
- }
146
- if (devtool) {
147
- webpackOptions.push("--devtool", devtool);
148
- }
149
- if (disableInterpret) {
150
- webpackOptions.push("--disableInterpret");
151
- }
152
- if (entry) {
153
- webpackOptions.push("--entry", entry);
154
- }
155
- if (env) {
156
- webpackOptions.push("--env", env);
157
- }
158
- if (failOnWarnings) {
159
- webpackOptions.push("--failOnWarnings");
160
- }
161
- if (json) {
162
- webpackOptions.push("--json", json);
163
- }
164
- if (mode) {
165
- webpackOptions.push("--mode", mode);
166
- }
167
- if (merge) {
168
- webpackOptions.push("--merge");
169
- }
170
- if (name) {
171
- webpackOptions.push("--name", name);
172
- }
173
- if (noDevtool) {
174
- webpackOptions.push("--noDevtool");
175
- }
176
- if (noStats) {
177
- webpackOptions.push("--noStats");
178
- }
179
- if (noTarget) {
180
- webpackOptions.push("--noTarget");
181
- }
182
- if (noWatch) {
183
- webpackOptions.push("--noWatch");
184
- }
185
- if (noWatchOptionsStdin) {
186
- webpackOptions.push("--noWatchOptionsStdin");
187
- }
188
- if (nodeEnv) {
189
- webpackOptions.push("--nodeEnv", nodeEnv);
190
- }
191
- if (outputPath) {
192
- webpackOptions.push("--outputPath", outputPath);
193
- }
194
- if (stats) {
195
- webpackOptions.push("--stats", stats);
196
- }
197
- if (target) {
198
- webpackOptions.push("--target", target);
199
- }
200
- if (watch) {
201
- webpackOptions.push("--watch");
202
- }
203
- if (watchOptionsStdin) {
204
- webpackOptions.push("--watchOptionsStdin");
205
- }
206
- const dirPath = pathResolve(dirName, "../..");
207
- try {
208
- const webpackPath = relativeNodePath("webpack-cli/bin/cli.js", dirPath);
209
- await execa(webpackPath, webpackOptions, { encoding: "utf8", stdio: "inherit" });
210
- spinner.succeed("Build completed successfully!");
211
- callback(0);
212
- return 0;
213
- } catch (error) {
214
- log(`
215
- ${cliName} Error: ${error.message}`, "error", quiet);
216
- spinner.fail("Build failed.");
217
- callback(1);
218
- return 1;
219
- }
220
- };
221
- const build = async (cmd, callback = () => ({})) => {
222
- const {
223
- bundler = "webpack",
224
- cliName = "Lex",
225
- quiet = false,
226
- remove = false,
227
- variables = "{}"
228
- } = cmd;
229
- const spinner = createSpinner(quiet);
230
- log(`${cliName} building...`, "info", quiet);
231
- await LexConfig.parseConfig(cmd);
232
- const { outputFullPath, useTypescript } = LexConfig.config;
233
- checkLinkedModules();
234
- let variablesObj = { NODE_ENV: "production" };
235
- if (variables) {
236
- try {
237
- variablesObj = JSON.parse(variables);
238
- } catch (error) {
239
- log(`
240
- ${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
241
- callback(1);
242
- return 1;
243
- }
244
- }
245
- process.env = { ...process.env, ...variablesObj };
246
- spinner.start("Building code...");
247
- if (remove) {
248
- await removeFiles(outputFullPath);
249
- }
250
- if (useTypescript) {
251
- LexConfig.checkTypescriptConfig();
252
- }
253
- if (bundler === "esbuild") {
254
- return buildWithEsBuild(spinner, cmd, callback);
255
- }
256
- return buildWithWebpack(spinner, cmd, callback);
257
- };
258
- var build_default = build;
259
- export {
260
- build,
261
- buildWithEsBuild,
262
- buildWithWebpack,
263
- build_default as default
264
- };
265
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1aWxkLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IEdyYXBocWxMb2FkZXJQbHVnaW4gZnJvbSAnQGx1Y2t5Y2F0ZmFjdG9yeS9lc2J1aWxkLWdyYXBocWwtbG9hZGVyJztcbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcbmltcG9ydCB7cmVhZEZpbGVTeW5jfSBmcm9tICdmcyc7XG5pbXBvcnQge3N5bmMgYXMgZ2xvYlN5bmN9IGZyb20gJ2dsb2InO1xuaW1wb3J0IHtyZXNvbHZlIGFzIHBhdGhSZXNvbHZlfSBmcm9tICdwYXRoJztcbmltcG9ydCB7VVJMfSBmcm9tICd1cmwnO1xuXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y2hlY2tMaW5rZWRNb2R1bGVzLCBjcmVhdGVTcGlubmVyLCByZW1vdmVGaWxlc30gZnJvbSAnLi4vdXRpbHMvYXBwLmpzJztcbmltcG9ydCB7cmVsYXRpdmVOb2RlUGF0aH0gZnJvbSAnLi4vdXRpbHMvZmlsZS5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGludGVyZmFjZSBCdWlsZE9wdGlvbnMge1xuICByZWFkb25seSBidW5kbGVyPzogJ3dlYnBhY2snIHwgJ2VzYnVpbGQnO1xuICByZWFkb25seSBjbGlOYW1lPzogc3RyaW5nO1xuICByZWFkb25seSBmb3JtYXQ/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IG91dHB1dFBhdGg/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHF1aWV0PzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgcmVtb3ZlPzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgc291cmNlUGF0aD86IHN0cmluZztcbiAgcmVhZG9ubHkgdmFyaWFibGVzPzogc3RyaW5nO1xuICByZWFkb25seSB3YXRjaD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIEJ1aWxkQ2FsbGJhY2sgPSAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQ7XG5cbmV4cG9ydCBjb25zdCBidWlsZFdpdGhFc0J1aWxkID0gYXN5bmMgKHNwaW5uZXIsIGNvbW1hbmRPcHRpb25zOiBCdWlsZE9wdGlvbnMsIGNhbGxiYWNrOiBCdWlsZENhbGxiYWNrKSA9PiB7XG4gIGNvbnN0IHtcbiAgICBjbGlOYW1lID0gJ0xleCcsXG4gICAgZm9ybWF0ID0gJ2NqcycsXG4gICAgb3V0cHV0UGF0aCxcbiAgICBxdWlldCxcbiAgICBzb3VyY2VQYXRoLFxuICAgIHdhdGNoXG4gIH0gPSBjb21tYW5kT3B0aW9ucztcbiAgY29uc3Qge1xuICAgIG91dHB1dEZ1bGxQYXRoLFxuICAgIHNvdXJjZUZ1bGxQYXRoLFxuICAgIHRhcmdldEVudmlyb25tZW50LFxuICAgIHVzZUdyYXBoUWwsXG4gICAgdXNlVHlwZXNjcmlwdFxuICB9ID0gTGV4Q29uZmlnLmNvbmZpZztcbiAgY29uc3Qgc291cmNlRGlyOiBzdHJpbmcgPSBzb3VyY2VQYXRoID8gcGF0aFJlc29sdmUocHJvY2Vzcy5jd2QoKSwgYC4vJHtzb3VyY2VQYXRofWApIDogc291cmNlRnVsbFBhdGg7XG4gIGNvbnN0IGxvYWRlciA9IHtcbiAgICAnLmpzJzogJ2pzJ1xuICB9O1xuXG4gIGlmKHVzZVR5cGVzY3JpcHQpIHtcbiAgICBsb2FkZXJbJy50cyddID0gJ3RzJztcbiAgICBsb2FkZXJbJy50c3gnXSA9ICd0c3gnO1xuICB9XG5cbiAgY29uc3QgcGx1Z2lucyA9IFtdO1xuXG4gIGlmKHVzZUdyYXBoUWwpIHtcbiAgICBwbHVnaW5zLnB1c2goKEdyYXBocWxMb2FkZXJQbHVnaW4gYXMgdW5rbm93biBhcyAoKSA9PiB2b2lkKSgpKTtcbiAgfVxuXG4gIC8vIFNvdXJjZSBmaWxlc1xuICBjb25zdCBnbG9iT3B0aW9ucyA9IHtcbiAgICBjd2Q6IHNvdXJjZURpcixcbiAgICBkb3Q6IGZhbHNlLFxuICAgIG5vZGlyOiB0cnVlLFxuICAgIG5vc29ydDogdHJ1ZVxuICB9O1xuICBjb25zdCB0c0ZpbGVzOiBzdHJpbmdbXSA9IGdsb2JTeW5jKGAke3NvdXJjZURpcn0vKiovISgqLnNwZWN8Ki50ZXN0KS50cypgLCBnbG9iT3B0aW9ucyk7XG4gIGNvbnN0IGpzRmlsZXM6IHN0cmluZ1tdID0gZ2xvYlN5bmMoYCR7c291cmNlRGlyfS8qKi8hKCouc3BlY3wqLnRlc3QpLmpzYCwgZ2xvYk9wdGlvbnMpO1xuICBjb25zdCBzb3VyY2VGaWxlczogc3RyaW5nW10gPSBbLi4udHNGaWxlcywgLi4uanNGaWxlc107XG5cbiAgLy8gTlBNIFBhY2thZ2VzXG4gIGNvbnN0IHBhY2thZ2VKc29uRGF0YSA9IHJlYWRGaWxlU3luYyhwYXRoUmVzb2x2ZShwcm9jZXNzLmN3ZCgpLCAnLi9wYWNrYWdlLmpzb24nKSk7XG4gIGNvbnN0IHBhY2thZ2VKc29uID0gSlNPTi5wYXJzZShwYWNrYWdlSnNvbkRhdGEudG9TdHJpbmcoKSk7XG4gIGNvbnN0IGV4dGVybmFsID0gW1xuICAgIC4uLk9iamVjdC5rZXlzKHBhY2thZ2VKc29uLmRlcGVuZGVuY2llcyB8fCB7fSksXG4gICAgLi4uT2JqZWN0LmtleXMocGFja2FnZUpzb24ucGVlckRlcGVuZGVuY2llcyB8fCB7fSlcbiAgXTtcblxuICAvLyBFU0J1aWxkIG9wdGlvbnNcbiAgY29uc3QgZGlyTmFtZSA9IG5ldyBVUkwoJy4nLCBpbXBvcnQubWV0YS51cmwpLnBhdGhuYW1lO1xuICBjb25zdCBkaXJQYXRoOiBzdHJpbmcgPSBwYXRoUmVzb2x2ZShkaXJOYW1lLCAnLi4vLi4nKTtcbiAgY29uc3Qgb3V0cHV0RGlyOiBzdHJpbmcgPSBvdXRwdXRQYXRoIHx8IG91dHB1dEZ1bGxQYXRoO1xuICBjb25zdCBlc2J1aWxkUGF0aDogc3RyaW5nID0gcmVsYXRpdmVOb2RlUGF0aCgnZXNidWlsZC9iaW4vZXNidWlsZCcsIGRpclBhdGgpO1xuICBjb25zdCBlc2J1aWxkT3B0aW9uczogc3RyaW5nW10gPSBbXG4gICAgLi4uc291cmNlRmlsZXMsXG4gICAgJy0tYnVuZGxlJyxcbiAgICAnLS1jb2xvcj10cnVlJyxcbiAgICBgLS1mb3JtYXQ9JHtmb3JtYXR9YCxcbiAgICBgLS1vdXRkaXI9JHtvdXRwdXREaXJ9YCxcbiAgICAnLS1wbGF0Zm9ybT1ub2RlJyxcbiAgICAnLS1mb3JtYXQ9Y2pzJyxcbiAgICAnLS1zb3VyY2VtYXA9aW5saW5lJyxcbiAgICBgLS10YXJnZXQ9JHt0YXJnZXRFbnZpcm9ubWVudCA9PT0gJ25vZGUnID8gJ25vZGUyMCcgOiAnZXMyMDE4J31gXG4gIF07XG5cbiAgaWYoZXh0ZXJuYWwubGVuZ3RoKSB7XG4gICAgZXNidWlsZE9wdGlvbnMucHVzaChgLS1leHRlcm5hbDoke2V4dGVybmFsLmpvaW4oJywnKX1gKTtcbiAgfVxuXG4gIGlmKHBsdWdpbnMubGVuZ3RoKSB7XG4gICAgZXNidWlsZE9wdGlvbnMucHVzaChgLS1wbHVnaW5zPSR7cGx1Z2lucy5qb2luKCcsJyl9YCk7XG4gIH1cbiAgaWYod2F0Y2gpIHtcbiAgICBlc2J1aWxkT3B0aW9ucy5wdXNoKCctLXdhdGNoJyk7XG4gIH1cblxuICB0cnkge1xuICAgIGF3YWl0IGV4ZWNhKGVzYnVpbGRQYXRoLCBlc2J1aWxkT3B0aW9ucywge2VuY29kaW5nOiAndXRmOCd9KTtcblxuICAgIHNwaW5uZXIuc3VjY2VlZCgnQnVpbGQgY29tcGxldGVkIHN1Y2Nlc3NmdWxseSEnKTtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIGlmKCFxdWlldCkge1xuICAgICAgY29uc29sZS5lcnJvcihlcnJvcik7XG4gICAgfVxuXG4gICAgc3Bpbm5lci5mYWlsKCdDb2RlIGJ1aWxkIGZhaWxlZC4nKTtcblxuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG5cbiAgY2FsbGJhY2soMCk7XG4gIHJldHVybiAwO1xufTtcblxuZXhwb3J0IGNvbnN0IGJ1aWxkV2l0aFdlYnBhY2sgPSBhc3luYyAoc3Bpbm5lciwgY21kLCBjYWxsYmFjaykgPT4ge1xuICBjb25zdCB7XG4gICAgYW5hbHl6ZSxcbiAgICBjbGlOYW1lID0gJ0xleCcsXG4gICAgY29uZmlnLFxuICAgIGNvbmZpZ05hbWUsXG4gICAgZGVmaW5lUHJvY2Vzc0Vudk5vZGVFbnYsXG4gICAgZGV2dG9vbCxcbiAgICBkaXNhYmxlSW50ZXJwcmV0LFxuICAgIGVudHJ5LFxuICAgIGVudixcbiAgICBmYWlsT25XYXJuaW5ncyxcbiAgICBqc29uLFxuICAgIG1lcmdlLFxuICAgIG1vZGUsXG4gICAgbmFtZSxcbiAgICBub2RlRW52LFxuICAgIG5vRGV2dG9vbCxcbiAgICBub1N0YXRzLFxuICAgIG5vVGFyZ2V0LFxuICAgIG5vV2F0Y2gsXG4gICAgbm9XYXRjaE9wdGlvbnNTdGRpbixcbiAgICBvdXRwdXRQYXRoLFxuICAgIHF1aWV0ID0gZmFsc2UsXG4gICAgc3RhdHMsXG4gICAgdGFyZ2V0LFxuICAgIHdhdGNoLFxuICAgIHdhdGNoT3B0aW9uc1N0ZGluXG4gIH0gPSBjbWQ7XG5cbiAgLy8gR2V0IGN1c3RvbSB3ZWJwYWNrIGNvbmZpZ3VyYXRpb25cbiAgbGV0IHdlYnBhY2tDb25maWc6IHN0cmluZztcbiAgY29uc3QgZGlyTmFtZSA9IG5ldyBVUkwoJy4nLCBpbXBvcnQubWV0YS51cmwpLnBhdGhuYW1lO1xuXG4gIGlmKGNvbmZpZykge1xuICAgIGNvbnN0IGlzUmVsYXRpdmVDb25maWc6IGJvb2xlYW4gPSBjb25maWcuc3Vic3RyKDAsIDIpID09PSAnLi8nO1xuICAgIHdlYnBhY2tDb25maWcgPSBpc1JlbGF0aXZlQ29uZmlnID8gcGF0aFJlc29sdmUocHJvY2Vzcy5jd2QoKSwgY29uZmlnKSA6IGNvbmZpZztcbiAgfSBlbHNlIHtcbiAgICB3ZWJwYWNrQ29uZmlnID0gcGF0aFJlc29sdmUoZGlyTmFtZSwgJy4uLy4uL3dlYnBhY2suY29uZmlnLmpzJyk7XG4gIH1cblxuICBjb25zdCB3ZWJwYWNrT3B0aW9uczogc3RyaW5nW10gPSBbXG4gICAgJy0tY29sb3InLFxuICAgICctLXByb2dyZXNzJyxcbiAgICAnLS1jb25maWcnLCB3ZWJwYWNrQ29uZmlnXG4gIF07XG5cbiAgaWYoYW5hbHl6ZSkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tYW5hbHl6ZScpO1xuICB9XG5cbiAgaWYoY29uZmlnTmFtZSkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tY29uZmlnTmFtZScsIGNvbmZpZ05hbWUpO1xuICB9XG5cbiAgaWYoZGVmaW5lUHJvY2Vzc0Vudk5vZGVFbnYpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWRlZmluZVByb2Nlc3NFbnZOb2RlRW52JywgZGVmaW5lUHJvY2Vzc0Vudk5vZGVFbnYpO1xuICB9XG5cbiAgaWYoZGV2dG9vbCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tZGV2dG9vbCcsIGRldnRvb2wpO1xuICB9XG5cbiAgaWYoZGlzYWJsZUludGVycHJldCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tZGlzYWJsZUludGVycHJldCcpO1xuICB9XG5cbiAgaWYoZW50cnkpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWVudHJ5JywgZW50cnkpO1xuICB9XG5cbiAgaWYoZW52KSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1lbnYnLCBlbnYpO1xuICB9XG5cbiAgaWYoZmFpbE9uV2FybmluZ3MpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWZhaWxPbldhcm5pbmdzJyk7XG4gIH1cblxuICBpZihqc29uKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1qc29uJywganNvbik7XG4gIH1cblxuICBpZihtb2RlKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1tb2RlJywgbW9kZSk7XG4gIH1cblxuICBpZihtZXJnZSkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tbWVyZ2UnKTtcbiAgfVxuXG4gIGlmKG5hbWUpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5hbWUnLCBuYW1lKTtcbiAgfVxuXG4gIGlmKG5vRGV2dG9vbCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tbm9EZXZ0b29sJyk7XG4gIH1cblxuICBpZihub1N0YXRzKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1ub1N0YXRzJyk7XG4gIH1cblxuICBpZihub1RhcmdldCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tbm9UYXJnZXQnKTtcbiAgfVxuXG4gIGlmKG5vV2F0Y2gpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5vV2F0Y2gnKTtcbiAgfVxuXG4gIGlmKG5vV2F0Y2hPcHRpb25zU3RkaW4pIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5vV2F0Y2hPcHRpb25zU3RkaW4nKTtcbiAgfVxuXG4gIGlmKG5vZGVFbnYpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5vZGVFbnYnLCBub2RlRW52KTtcbiAgfVxuXG4gIGlmKG91dHB1dFBhdGgpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW91dHB1dFBhdGgnLCBvdXRwdXRQYXRoKTtcbiAgfVxuXG4gIGlmKHN0YXRzKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1zdGF0cycsIHN0YXRzKTtcbiAgfVxuXG4gIGlmKHRhcmdldCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tdGFyZ2V0JywgdGFyZ2V0KTtcbiAgfVxuXG4gIGlmKHdhdGNoKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS13YXRjaCcpO1xuICB9XG5cbiAgaWYod2F0Y2hPcHRpb25zU3RkaW4pIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLXdhdGNoT3B0aW9uc1N0ZGluJyk7XG4gIH1cblxuICAvLyBDb21waWxlIHVzaW5nIHdlYnBhY2tcbiAgY29uc3QgZGlyUGF0aDogc3RyaW5nID0gcGF0aFJlc29sdmUoZGlyTmFtZSwgJy4uLy4uJyk7XG5cbiAgdHJ5IHtcbiAgICBjb25zdCB3ZWJwYWNrUGF0aDogc3RyaW5nID0gcmVsYXRpdmVOb2RlUGF0aCgnd2VicGFjay1jbGkvYmluL2NsaS5qcycsIGRpclBhdGgpO1xuICAgIGF3YWl0IGV4ZWNhKHdlYnBhY2tQYXRoLCB3ZWJwYWNrT3B0aW9ucywge2VuY29kaW5nOiAndXRmOCcsIHN0ZGlvOiAnaW5oZXJpdCd9KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnQnVpbGQgY29tcGxldGVkIHN1Y2Nlc3NmdWxseSEnKTtcblxuICAgIC8vIFN0b3AgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5mYWlsKCdCdWlsZCBmYWlsZWQuJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gMTtcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IGJ1aWxkID0gYXN5bmMgKGNtZDogQnVpbGRPcHRpb25zLCBjYWxsYmFjazogQnVpbGRDYWxsYmFjayA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7XG4gICAgYnVuZGxlciA9ICd3ZWJwYWNrJyxcbiAgICBjbGlOYW1lID0gJ0xleCcsXG4gICAgcXVpZXQgPSBmYWxzZSxcbiAgICByZW1vdmUgPSBmYWxzZSxcbiAgICB2YXJpYWJsZXMgPSAne30nXG4gIH0gPSBjbWQ7XG5cbiAgLy8gU3Bpbm5lclxuICBjb25zdCBzcGlubmVyID0gY3JlYXRlU3Bpbm5lcihxdWlldCk7XG5cbiAgLy8gRGlzcGxheSBzdGF0dXNcbiAgbG9nKGAke2NsaU5hbWV9IGJ1aWxkaW5nLi4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIGF3YWl0IExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIGNvbnN0IHtvdXRwdXRGdWxsUGF0aCwgdXNlVHlwZXNjcmlwdH0gPSBMZXhDb25maWcuY29uZmlnO1xuXG4gIC8vIENoZWNrIGZvciBsaW5rZWQgbW9kdWxlc1xuICBjaGVja0xpbmtlZE1vZHVsZXMoKTtcblxuICAvLyBTZXQgbm9kZSBlbnZpcm9ubWVudCB2YXJpYWJsZXNcbiAgbGV0IHZhcmlhYmxlc09iajogb2JqZWN0ID0ge05PREVfRU5WOiAncHJvZHVjdGlvbid9O1xuXG4gIGlmKHZhcmlhYmxlcykge1xuICAgIHRyeSB7XG4gICAgICB2YXJpYWJsZXNPYmogPSBKU09OLnBhcnNlKHZhcmlhYmxlcyk7XG4gICAgfSBjYXRjaChlcnJvcikge1xuICAgICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiBFbnZpcm9ubWVudCB2YXJpYWJsZXMgb3B0aW9uIGlzIG5vdCBhIHZhbGlkIEpTT04gb2JqZWN0LmAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiAxO1xuICAgIH1cbiAgfVxuXG4gIHByb2Nlc3MuZW52ID0gey4uLnByb2Nlc3MuZW52LCAuLi52YXJpYWJsZXNPYmp9O1xuXG4gIC8vIFN0YXJ0IGJ1aWxkIHNwaW5uZXJcbiAgc3Bpbm5lci5zdGFydCgnQnVpbGRpbmcgY29kZS4uLicpO1xuXG4gIC8vIENsZWFuIG91dHB1dCBkaXJlY3RvcnkgYmVmb3JlIHdlIHN0YXJ0IGFkZGluZyBpbiBuZXcgZmlsZXNcbiAgaWYocmVtb3ZlKSB7XG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMob3V0cHV0RnVsbFBhdGgpO1xuICB9XG5cbiAgLy8gQWRkIHRzY29uZmlnIGZpbGUgaWYgbm9uZSBleGlzdHNcbiAgaWYodXNlVHlwZXNjcmlwdCkge1xuICAgIC8vIE1ha2Ugc3VyZSB0c2NvbmZpZy5qc29uIGV4aXN0c1xuICAgIExleENvbmZpZy5jaGVja1R5cGVzY3JpcHRDb25maWcoKTtcbiAgfVxuXG4gIGlmKGJ1bmRsZXIgPT09ICdlc2J1aWxkJykge1xuICAgIHJldHVybiBidWlsZFdpdGhFc0J1aWxkKHNwaW5uZXIsIGNtZCwgY2FsbGJhY2spO1xuICB9XG5cbiAgcmV0dXJuIGJ1aWxkV2l0aFdlYnBhY2soc3Bpbm5lciwgY21kLCBjYWxsYmFjayk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBidWlsZDtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUlBLE9BQU8seUJBQXlCO0FBQ2hDLFNBQVEsYUFBWTtBQUNwQixTQUFRLG9CQUFtQjtBQUMzQixTQUFRLFFBQVEsZ0JBQWU7QUFDL0IsU0FBUSxXQUFXLG1CQUFrQjtBQUNyQyxTQUFRLFdBQVU7QUFFbEIsU0FBUSxpQkFBZ0I7QUFDeEIsU0FBUSxvQkFBb0IsZUFBZSxtQkFBa0I7QUFDN0QsU0FBUSx3QkFBdUI7QUFDL0IsU0FBUSxXQUFVO0FBZ0JYLE1BQU0sbUJBQW1CLE9BQU8sU0FBUyxnQkFBOEIsYUFBNEI7QUFDeEcsUUFBTTtBQUFBLElBQ0osVUFBVTtBQUFBLElBQ1YsU0FBUztBQUFBLElBQ1Q7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxFQUNGLElBQUk7QUFDSixRQUFNO0FBQUEsSUFDSjtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxFQUNGLElBQUksVUFBVTtBQUNkLFFBQU0sWUFBb0IsYUFBYSxZQUFZLFFB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
@@ -1,317 +0,0 @@
1
- import { build as esBuild } from "esbuild";
2
- import { execa } from "execa";
3
- import { build, buildWithEsBuild, buildWithWebpack } from "./build.js";
4
- import { LexConfig, defaultConfigValues } from "../LexConfig.js";
5
- import { checkLinkedModules, removeFiles } from "../utils/app.js";
6
- jest.mock("esbuild", () => ({
7
- ...jest.requireActual("esbuild"),
8
- build: jest.fn(() => Promise.resolve({}))
9
- }));
10
- jest.mock("execa", () => ({
11
- ...jest.requireActual("execa"),
12
- execa: jest.fn(() => Promise.resolve({}))
13
- }));
14
- jest.mock("@luckycatfactory/esbuild-graphql-loader", () => ({
15
- ...jest.requireActual("@luckycatfactory/esbuild-graphql-loader"),
16
- __esModule: true,
17
- default: jest.fn(() => "esbuildGraphqlLoader")
18
- }));
19
- jest.mock("../utils/app", () => ({
20
- ...jest.requireActual("../utils/app"),
21
- checkLinkedModules: jest.fn(),
22
- removeFiles: jest.fn(() => Promise.resolve())
23
- }));
24
- jest.mock("../LexConfig", () => ({
25
- LexConfig: {
26
- config: {},
27
- checkTypescriptConfig: jest.fn(),
28
- parseConfig: jest.fn()
29
- }
30
- }));
31
- describe("build", () => {
32
- let callback;
33
- let spinner;
34
- let oldConsole;
35
- beforeAll(() => {
36
- oldConsole = { ...console };
37
- console = {
38
- ...oldConsole,
39
- debug: jest.fn(),
40
- error: jest.fn(),
41
- warn: jest.fn()
42
- };
43
- });
44
- beforeEach(() => {
45
- LexConfig.config = {
46
- ...defaultConfigValues
47
- };
48
- callback = jest.fn();
49
- spinner = {
50
- succeed: jest.fn(),
51
- fail: jest.fn()
52
- };
53
- });
54
- afterAll(() => {
55
- console = { ...oldConsole };
56
- jest.resetAllMocks();
57
- });
58
- describe("buildWithEsBuild", () => {
59
- beforeEach(() => {
60
- esBuild.mockImplementation(() => Promise.resolve({}));
61
- });
62
- it("should build using default config", async () => {
63
- const status = await buildWithEsBuild(spinner, {}, callback);
64
- expect(esBuild).toHaveBeenCalledWith({
65
- bundle: true,
66
- color: true,
67
- entryPoints: [void 0],
68
- loader: {
69
- ".js": "js"
70
- },
71
- outdir: void 0,
72
- platform: "node",
73
- plugins: [],
74
- sourcemap: "inline",
75
- target: "es2016",
76
- watch: false
77
- });
78
- expect(spinner.succeed).toHaveBeenCalled();
79
- expect(spinner.fail).not.toHaveBeenCalled();
80
- expect(callback).toHaveBeenCalledWith(0);
81
- expect(status).toBe(0);
82
- });
83
- it("should build for node", async () => {
84
- LexConfig.config = {
85
- ...defaultConfigValues,
86
- targetEnvironment: "node"
87
- };
88
- const status = await buildWithEsBuild(spinner, {}, callback);
89
- expect(esBuild).toHaveBeenCalledWith({
90
- bundle: true,
91
- color: true,
92
- entryPoints: [void 0],
93
- loader: {
94
- ".js": "js"
95
- },
96
- outdir: void 0,
97
- platform: "node",
98
- plugins: [],
99
- sourcemap: "inline",
100
- target: "node18",
101
- watch: false
102
- });
103
- expect(spinner.succeed).toHaveBeenCalled();
104
- expect(spinner.fail).not.toHaveBeenCalled();
105
- expect(callback).toHaveBeenCalledWith(0);
106
- expect(status).toBe(0);
107
- });
108
- it("should build using typescript", async () => {
109
- LexConfig.config = {
110
- ...defaultConfigValues,
111
- useTypescript: true
112
- };
113
- const callback2 = jest.fn();
114
- const status = await buildWithEsBuild(spinner, { cliName: "Test" }, callback2);
115
- expect(esBuild).toHaveBeenCalledWith({
116
- bundle: true,
117
- color: true,
118
- entryPoints: [void 0],
119
- loader: {
120
- ".js": "js",
121
- ".ts": "ts",
122
- ".tsx": "tsx"
123
- },
124
- outdir: void 0,
125
- platform: "node",
126
- plugins: [],
127
- sourcemap: "inline",
128
- target: "es2016",
129
- watch: false
130
- });
131
- expect(spinner.succeed).toHaveBeenCalled();
132
- expect(spinner.fail).not.toHaveBeenCalled();
133
- expect(callback2).toHaveBeenCalledWith(0);
134
- expect(status).toBe(0);
135
- });
136
- it("should build using graphql", async () => {
137
- LexConfig.config = {
138
- ...defaultConfigValues,
139
- useGraphQl: true
140
- };
141
- const status = await buildWithEsBuild(spinner, { cliName: "Test" }, callback);
142
- expect(esBuild).toHaveBeenCalledWith({
143
- bundle: true,
144
- color: true,
145
- entryPoints: [void 0],
146
- loader: {
147
- ".js": "js"
148
- },
149
- outdir: void 0,
150
- platform: "node",
151
- plugins: ["esbuildGraphqlLoader"],
152
- sourcemap: "inline",
153
- target: "es2016",
154
- watch: false
155
- });
156
- expect(spinner.succeed).toHaveBeenCalled();
157
- expect(spinner.fail).not.toHaveBeenCalled();
158
- expect(callback).toHaveBeenCalledWith(0);
159
- expect(status).toBe(0);
160
- });
161
- it("should handle errors", async () => {
162
- esBuild.mockImplementation(() => Promise.reject(new Error("Mock Error")));
163
- const status = await buildWithEsBuild(spinner, { cliName: "Test" }, callback);
164
- expect(spinner.succeed).not.toHaveBeenCalled();
165
- expect(spinner.fail).toHaveBeenCalled();
166
- expect(callback).toHaveBeenCalledWith(1);
167
- expect(status).toBe(1);
168
- });
169
- });
170
- describe("buildWithWebpack", () => {
171
- beforeEach(() => {
172
- execa.mockImplementation(() => Promise.resolve({}));
173
- });
174
- it("should build using default config", async () => {
175
- const status = await buildWithWebpack(spinner, {}, callback);
176
- expect(execa).toHaveBeenCalledWith(
177
- expect.stringContaining("/node_modules/webpack-cli/bin/cli.js"),
178
- [
179
- "--color",
180
- "--progress",
181
- "--config",
182
- expect.stringContaining("/webpack.config.js")
183
- ],
184
- { encoding: "utf8", stdio: "inherit" }
185
- );
186
- expect(spinner.succeed).toHaveBeenCalled();
187
- expect(spinner.fail).not.toHaveBeenCalled();
188
- expect(callback).toHaveBeenCalledWith(0);
189
- expect(status).toBe(0);
190
- });
191
- it("should build using custom options", async () => {
192
- LexConfig.config = {
193
- ...defaultConfigValues,
194
- useTypescript: true
195
- };
196
- const callback2 = jest.fn();
197
- const cmd = {
198
- analyze: true,
199
- cliName: "Lex",
200
- config: "config.js",
201
- configName: "configName",
202
- defineProcessEnvNodeEnv: "development",
203
- devtool: "devtool",
204
- disableInterpret: true,
205
- entry: "entry",
206
- env: "env",
207
- failOnWarnings: true,
208
- json: "json",
209
- merge: "merge",
210
- mode: "mode",
211
- name: "name",
212
- nodeEnv: "nodeEnv",
213
- noDevtool: true,
214
- noStats: true,
215
- noTarget: true,
216
- noWatch: true,
217
- noWatchOptionsStdin: true,
218
- outputPath: "outputPath",
219
- quiet: false,
220
- stats: "stats",
221
- target: "target",
222
- watch: true,
223
- watchOptionsStdin: true
224
- };
225
- const status = await buildWithWebpack(spinner, cmd, callback2);
226
- expect(execa).toHaveBeenLastCalledWith(
227
- expect.stringContaining("/node_modules/webpack-cli/bin/cli.js"),
228
- [
229
- "--color",
230
- "--progress",
231
- "--config",
232
- "config.js",
233
- "--analyze",
234
- "--configName",
235
- "configName",
236
- "--defineProcessEnvNodeEnv",
237
- "development",
238
- "--devtool",
239
- "devtool",
240
- "--disableInterpret",
241
- "--entry",
242
- "entry",
243
- "--env",
244
- "env",
245
- "--failOnWarnings",
246
- "--json",
247
- "json",
248
- "--mode",
249
- "mode",
250
- "--merge",
251
- "--name",
252
- "name",
253
- "--noDevtool",
254
- "--noStats",
255
- "--noTarget",
256
- "--noWatch",
257
- "--noWatchOptionsStdin",
258
- "--nodeEnv",
259
- "nodeEnv",
260
- "--outputPath",
261
- "outputPath",
262
- "--stats",
263
- "stats",
264
- "--target",
265
- "target",
266
- "--watch",
267
- "--watchOptionsStdin"
268
- ],
269
- { encoding: "utf8", stdio: "inherit" }
270
- );
271
- expect(spinner.succeed).toHaveBeenCalled();
272
- expect(spinner.fail).not.toHaveBeenCalled();
273
- expect(callback2).toHaveBeenCalledWith(0);
274
- expect(status).toBe(0);
275
- });
276
- it("should handle errors", async () => {
277
- execa.mockImplementation(() => Promise.reject(new Error("Mock Error")));
278
- const status = await buildWithWebpack(spinner, { cliName: "Test" }, callback);
279
- expect(spinner.succeed).not.toHaveBeenCalled();
280
- expect(spinner.fail).toHaveBeenCalled();
281
- expect(callback).toHaveBeenCalledWith(1);
282
- expect(status).toBe(1);
283
- });
284
- });
285
- describe("build", () => {
286
- it("should build with defaults", async () => {
287
- const status = await build({}, callback);
288
- expect(checkLinkedModules).toHaveBeenCalled();
289
- expect(callback).toHaveBeenCalledWith(1);
290
- expect(status).toBe(1);
291
- });
292
- it("should build with defined props", async () => {
293
- LexConfig.config = {
294
- ...defaultConfigValues,
295
- useTypescript: true
296
- };
297
- const status = await build({
298
- bundler: "esbuild",
299
- remove: true
300
- }, callback);
301
- expect(checkLinkedModules).toHaveBeenCalled();
302
- expect(removeFiles).toHaveBeenCalled();
303
- expect(LexConfig.checkTypescriptConfig).toHaveBeenCalled();
304
- expect(callback).toHaveBeenCalledWith(1);
305
- expect(status).toBe(1);
306
- });
307
- it("should error on bad variables value", async () => {
308
- const status = await build({
309
- bundler: "esbuild",
310
- variables: "test"
311
- }, callback);
312
- expect(callback).toHaveBeenCalledWith(1);
313
- expect(status).toBe(1);
314
- });
315
- });
316
- });
317
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1bGlkLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7YnVpbGQgYXMgZXNCdWlsZH0gZnJvbSAnZXNidWlsZCc7XG5pbXBvcnQge2V4ZWNhfSBmcm9tICdleGVjYSc7XG5cbmltcG9ydCB7YnVpbGQsIGJ1aWxkV2l0aEVzQnVpbGQsIGJ1aWxkV2l0aFdlYnBhY2t9IGZyb20gJy4vYnVpbGQuanMnO1xuaW1wb3J0IHtMZXhDb25maWcsIGRlZmF1bHRDb25maWdWYWx1ZXN9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NoZWNrTGlua2VkTW9kdWxlcywgcmVtb3ZlRmlsZXN9IGZyb20gJy4uL3V0aWxzL2FwcC5qcyc7XG5cbmplc3QubW9jaygnZXNidWlsZCcsICgpID0+ICh7XG4gIC4uLmplc3QucmVxdWlyZUFjdHVhbCgnZXNidWlsZCcpLFxuICBidWlsZDogamVzdC5mbigoKSA9PiBQcm9taXNlLnJlc29sdmUoe30pKVxufSkpO1xuXG5qZXN0Lm1vY2soJ2V4ZWNhJywgKCkgPT4gKHtcbiAgLi4uamVzdC5yZXF1aXJlQWN0dWFsKCdleGVjYScpLFxuICBleGVjYTogamVzdC5mbigoKSA9PiBQcm9taXNlLnJlc29sdmUoe30pKVxufSkpO1xuXG5qZXN0Lm1vY2soJ0BsdWNreWNhdGZhY3RvcnkvZXNidWlsZC1ncmFwaHFsLWxvYWRlcicsICgpID0+ICh7XG4gIC4uLmplc3QucmVxdWlyZUFjdHVhbCgnQGx1Y2t5Y2F0ZmFjdG9yeS9lc2J1aWxkLWdyYXBocWwtbG9hZGVyJyksXG4gIF9fZXNNb2R1bGU6IHRydWUsXG4gIGRlZmF1bHQ6IGplc3QuZm4oKCkgPT4gJ2VzYnVpbGRHcmFwaHFsTG9hZGVyJylcbn0pKTtcblxuamVzdC5tb2NrKCcuLi91dGlscy9hcHAnLCAoKSA9PiAoe1xuICAuLi5qZXN0LnJlcXVpcmVBY3R1YWwoJy4uL3V0aWxzL2FwcCcpLFxuICBjaGVja0xpbmtlZE1vZHVsZXM6IGplc3QuZm4oKSxcbiAgcmVtb3ZlRmlsZXM6IGplc3QuZm4oKCkgPT4gUHJvbWlzZS5yZXNvbHZlKCkpXG59KSk7XG5cbmplc3QubW9jaygnLi4vTGV4Q29uZmlnJywgKCkgPT4gKHtcbiAgTGV4Q29uZmlnOiB7XG4gICAgY29uZmlnOiB7fSxcbiAgICBjaGVja1R5cGVzY3JpcHRDb25maWc6IGplc3QuZm4oKSxcbiAgICBwYXJzZUNvbmZpZzogamVzdC5mbigpXG4gIH1cbn0pKTtcblxuZGVzY3JpYmUoJ2J1aWxkJywgKCkgPT4ge1xuICBsZXQgY2FsbGJhY2s6IGplc3QuTW9jaztcbiAgbGV0IHNwaW5uZXI7XG4gIGxldCBvbGRDb25zb2xlO1xuXG4gIGJlZm9yZUFsbCgoKSA9PiB7XG4gICAgb2xkQ29uc29sZSA9IHsuLi5jb25zb2xlfTtcbiAgICBjb25zb2xlID0ge1xuICAgICAgLi4ub2xkQ29uc29sZSxcbiAgICAgIGRlYnVnOiBqZXN0LmZuKCksXG4gICAgICBlcnJvcjogamVzdC5mbigpLFxuICAgICAgd2FybjogamVzdC5mbigpXG4gICAgfTtcbiAgfSk7XG5cbiAgYmVmb3JlRWFjaCgoKSA9PiB7XG4gICAgTGV4Q29uZmlnLmNvbmZpZyA9IHtcbiAgICAgIC4uLmRlZmF1bHRDb25maWdWYWx1ZXNcbiAgICB9O1xuXG4gICAgY2FsbGJhY2sgPSBqZXN0LmZuKCk7XG4gICAgc3Bpbm5lciA9IHtcbiAgICAgIHN1Y2NlZWQ6IGplc3QuZm4oKSxcbiAgICAgIGZhaWw6IGplc3QuZm4oKVxuICAgIH07XG4gIH0pO1xuXG4gIGFmdGVyQWxsKCgpID0+IHtcbiAgICBjb25zb2xlID0gey4uLm9sZENvbnNvbGV9O1xuICAgIGplc3QucmVzZXRBbGxNb2NrcygpO1xuICB9KTtcblxuICBkZXNjcmliZSgnYnVpbGRXaXRoRXNCdWlsZCcsICgpID0+IHtcbiAgICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICAgIChlc0J1aWxkIGFzIGplc3QuTW9jaykubW9ja0ltcGxlbWVudGF0aW9uKCgpID0+IFByb21pc2UucmVzb2x2ZSh7fSkpO1xuICAgIH0pO1xuXG4gICAgaXQoJ3Nob3VsZCBidWlsZCB1c2luZyBkZWZhdWx0IGNvbmZpZycsIGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGRXaXRoRXNCdWlsZChzcGlubmVyLCB7fSwgY2FsbGJhY2spO1xuICAgICAgZXhwZWN0KGVzQnVpbGQpLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKHtcbiAgICAgICAgYnVuZGxlOiB0cnVlLFxuICAgICAgICBjb2xvcjogdHJ1ZSxcbiAgICAgICAgZW50cnlQb2ludHM6IFt1bmRlZmluZWRdLFxuICAgICAgICBsb2FkZXI6IHtcbiAgICAgICAgICAnLmpzJzogJ2pzJ1xuICAgICAgICB9LFxuICAgICAgICBvdXRkaXI6IHVuZGVmaW5lZCxcbiAgICAgICAgcGxhdGZvcm06ICdub2RlJyxcbiAgICAgICAgcGx1Z2luczogW10sXG4gICAgICAgIHNvdXJjZW1hcDogJ2lubGluZScsXG4gICAgICAgIHRhcmdldDogJ2VzMjAxNicsXG4gICAgICAgIHdhdGNoOiBmYWxzZVxuICAgICAgfSk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5zdWNjZWVkKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5mYWlsKS5ub3QudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgwKTtcbiAgICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMCk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIGJ1aWxkIGZvciBub2RlJywgYXN5bmMgKCkgPT4ge1xuICAgICAgTGV4Q29uZmlnLmNvbmZpZyA9IHtcbiAgICAgICAgLi4uZGVmYXVsdENvbmZpZ1ZhbHVlcyxcbiAgICAgICAgdGFyZ2V0RW52aXJvbm1lbnQ6ICdub2RlJ1xuICAgICAgfTtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGRXaXRoRXNCdWlsZChzcGlubmVyLCB7fSwgY2FsbGJhY2spO1xuICAgICAgZXhwZWN0KGVzQnVpbGQpLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKHtcbiAgICAgICAgYnVuZGxlOiB0cnVlLFxuICAgICAgICBjb2xvcjogdHJ1ZSxcbiAgICAgICAgZW50cnlQb2ludHM6IFt1bmRlZmluZWRdLFxuICAgICAgICBsb2FkZXI6IHtcbiAgICAgICAgICAnLmpzJzogJ2pzJ1xuICAgICAgICB9LFxuICAgICAgICBvdXRkaXI6IHVuZGVmaW5lZCxcbiAgICAgICAgcGxhdGZvcm06ICdub2RlJyxcbiAgICAgICAgcGx1Z2luczogW10sXG4gICAgICAgIHNvdXJjZW1hcDogJ2lubGluZScsXG4gICAgICAgIHRhcmdldDogJ25vZGUxOCcsXG4gICAgICAgIHdhdGNoOiBmYWxzZVxuICAgICAgfSk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5zdWNjZWVkKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5mYWlsKS5ub3QudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgwKTtcbiAgICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMCk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIGJ1aWxkIHVzaW5nIHR5cGVzY3JpcHQnLCBhc3luYyAoKSA9PiB7XG4gICAgICBMZXhDb25maWcuY29uZmlnID0ge1xuICAgICAgICAuLi5kZWZhdWx0Q29uZmlnVmFsdWVzLFxuICAgICAgICB1c2VUeXBlc2NyaXB0OiB0cnVlXG4gICAgICB9O1xuICAgICAgY29uc3QgY2FsbGJhY2sgPSBqZXN0LmZuKCk7XG4gICAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IGJ1aWxkV2l0aEVzQnVpbGQoc3Bpbm5lciwge2NsaU5hbWU6ICdUZXN0J30sIGNhbGxiYWNrKTtcbiAgICAgIGV4cGVjdChlc0J1aWxkKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCh7XG4gICAgICAgIGJ1bmRsZTogdHJ1ZSxcbiAgICAgICAgY29sb3I6IHRydWUsXG4gICAgICAgIGVudHJ5UG9pbnRzOiBbdW5kZWZpbmVkXSxcbiAgICAgICAgbG9hZGVyOiB7XG4gICAgICAgICAgJy5qcyc6ICdqcycsXG4gICAgICAgICAgJy50cyc6ICd0cycsXG4gICAgICAgICAgJy50c3gnOiAndHN4J1xuICAgICAgICB9LFxuICAgICAgICBvdXRkaXI6IHVuZGVmaW5lZCxcbiAgICAgICAgcGxhdGZvcm06ICdub2RlJyxcbiAgICAgICAgcGx1Z2luczogW10sXG4gICAgICAgIHNvdXJjZW1hcDogJ2lubGluZScsXG4gICAgICAgIHRhcmdldDogJ2VzMjAxNicsXG4gICAgICAgIHdhdGNoOiBmYWxzZVxuICAgICAgfSk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5zdWNjZWVkKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5mYWlsKS5ub3QudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgwKTtcbiAgICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMCk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIGJ1aWxkIHVzaW5nIGdyYXBocWwnLCBhc3luYyAoKSA9PiB7XG4gICAgICBMZXhDb25maWcuY29uZmlnID0ge1xuICAgICAgICAuLi5kZWZhdWx0Q29uZmlnVmFsdWVzLFxuICAgICAgICB1c2VHcmFwaFFsOiB0cnVlXG4gICAgICB9O1xuICAgICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZFdpdGhFc0J1aWxkKHNwaW5uZXIsIHtjbGlOYW1lOiAnVGVzdCd9LCBjYWxsYmFjayk7XG5cbiAgICAgIGV4cGVjdChlc0J1aWxkKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCh7XG4gICAgICAgIGJ1bmRsZTogdHJ1ZSxcbiAgICAgICAgY29sb3I6IHRydWUsXG4gICAgICAgIGVudHJ5UG9pbnRzOiBbdW5kZWZpbmVkXSxcbiAgICAgICAgbG9hZGVyOiB7XG4gICAgICAgICAgJy5qcyc6ICdqcydcbiAgICAgICAgfSxcbiAgICAgICAgb3V0ZGlyOiB1bmRlZmluZWQsXG4gICAgICAgIHBsYXRmb3JtOiAnbm9kZScsXG4gICAgICAgIHBsdWdpbnM6IFsnZXNidWlsZEdyYXBocWxMb2FkZXInXSxcbiAgICAgICAgc291cmNlbWFwOiAnaW5saW5lJyxcbiAgICAgICAgdGFyZ2V0OiAnZXMyMDE2JyxcbiAgICAgICAgd2F0Y2g6IGZhbHNlXG4gICAgICB9KTtcbiAgICAgIGV4cGVjdChzcGlubmVyLnN1Y2NlZWQpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLmZhaWwpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDApO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgwKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgaGFuZGxlIGVycm9ycycsIGFzeW5jICgpID0+IHtcbiAgICAgIChlc0J1aWxkIGFzIGplc3QuTW9jaykubW9ja0ltcGxlbWVudGF0aW9uKCgpID0+IFByb21pc2UucmVqZWN0KG5ldyBFcnJvcignTW9jayBFcnJvcicpKSk7XG4gICAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IGJ1aWxkV2l0aEVzQnVpbGQoc3Bpbm5lciwge2NsaU5hbWU6ICdUZXN0J30sIGNhbGxiYWNrKTtcblxuICAgICAgZXhwZWN0KHNwaW5uZXIuc3VjY2VlZCkubm90LnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLmZhaWwpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChjYWxsYmFjaykudG9IYXZlQmVlbkNhbGxlZFdpdGgoMSk7XG4gICAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDEpO1xuICAgIH0pO1xuICB9KTtcblxuICBkZXNjcmliZSgnYnVpbGRXaXRoV2VicGFjaycsICgpID0+IHtcbiAgICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICAgIChleGVjYSBhcyBqZXN0Lk1vY2spLm1vY2tJbXBsZW1lbnRhdGlvbigoKSA9PiBQcm9taXNlLnJlc29sdmUoe30pKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgYnVpbGQgdXNpbmcgZGVmYXVsdCBjb25maWcnLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IGJ1aWxkV2l0aFdlYnBhY2soc3Bpbm5lciwge30sIGNhbGxiYWNrKTtcbiAgICAgIGV4cGVjdChleGVjYSkudG9IYXZlQmVlbkNhbGxlZFdpdGgoXG4gICAgICAgIGV4cGVjdC5zdHJpbmdDb250YWluaW5nKCcvbm9kZV9tb2R1bGVzL3dlYnBhY2stY2xpL2Jpbi9jbGkuanMnKSxcbiAgICAgICAgW1xuICAgICAgICAgICctLWNvbG9yJyxcbiAgICAgICAgICAnLS1wcm9ncmVzcycsXG4gICAgICAgICAgJy0tY29uZmlnJywgZXhwZWN0LnN0cmluZ0NvbnRhaW5pbmcoJy93ZWJwYWNrLmNvbmZpZy5qcycpXG4gICAgICAgIF0sXG4gICAgICAgIHtlbmNvZGluZzogJ3V0ZjgnLCBzdGRpbzogJ2luaGVyaXQnfVxuICAgICAgKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLnN1Y2NlZWQpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICAgIGV4cGVjdChzcGlubmVyLmZhaWwpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDApO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgwKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgYnVpbGQgdXNpbmcgY3VzdG9tIG9wdGlvbnMnLCBhc3luYyAoKSA9PiB7XG4gICAgICBMZXhDb25maWcuY29uZmlnID0ge1xuICAgICAgICAuLi5kZWZhdWx0Q29uZmlnVmFsdWVzLFxuICAgICAgICB1c2VUeXBlc2NyaXB0OiB0cnVlXG4gICAgICB9O1xuICAgICAgY29uc3QgY2FsbGJhY2sgPSBqZXN0LmZuKCk7XG4gICAgICBjb25zdCBjbWQgPSB7XG4gICAgICAgIGFuYWx5emU6IHRydWUsXG4gICAgICAgIGNsaU5hbWU6ICdMZXgnLFxuICAgICAgICBjb25maWc6ICdjb25maWcuanMnLFxuICAgICAgICBjb25maWdOYW1lOiAnY29uZmlnTmFtZScsXG4gICAgICAgIGRlZmluZVByb2Nlc3NFbnZOb2RlRW52OiAnZGV2ZWxvcG1lbnQnLFxuICAgICAgICBkZXZ0b29sOiAnZGV2dG9vbCcsXG4gICAgICAgIGRpc2FibGVJbnRlcnByZXQ6IHRydWUsXG4gICAgICAgIGVudHJ5OiAnZW50cnknLFxuICAgICAgICBlbnY6ICdlbnYnLFxuICAgICAgICBmYWlsT25XYXJuaW5nczogdHJ1ZSxcbiAgICAgICAganNvbjogJ2pzb24nLFxuICAgICAgICBtZXJnZTogJ21lcmdlJyxcbiAgICAgICAgbW9kZTogJ21vZGUnLFxuICAgICAgICBuYW1lOiAnbmFtZScsXG4gICAgICAgIG5vZGVFbnY6ICdub2RlRW52JyxcbiAgICAgICAgbm9EZXZ0b29sOiB0cnVlLFxuICAgICAgICBub1N0YXRzOiB0cnVlLFxuICAgICAgICBub1RhcmdldDogdHJ1ZSxcbiAgICAgICAgbm9XYXRjaDogdHJ1ZSxcbiAgICAgICAgbm9XYXRjaE9wdGlvbnNTdGRpbjogdHJ1ZSxcbiAgICAgICAgb3V0cHV0UGF0aDogJ291dHB1dFBhdGgnLFxuICAgICAgICBxdWlldDogZmFsc2UsXG4gICAgICAgIHN0YXRzOiAnc3RhdHMnLFxuICAgICAgICB0YXJnZXQ6ICd0YXJnZXQnLFxuICAgICAgICB3YXRjaDogdHJ1ZSxcbiAgICAgICAgd2F0Y2hPcHRpb25zU3RkaW46IHRydWVcbiAgICAgIH07XG4gICAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IGJ1aWxkV2l0aFdlYnBhY2soc3Bpbm5lciwgY21kLCBjYWxsYmFjayk7XG4gICAgICBleHBlY3QoZXhlY2EpLnRvSGF2ZUJlZW5MYXN0Q2FsbGVkV2l0aChcbiAgICAgICAgZXhwZWN0LnN0cmluZ0NvbnRhaW5pbmcoJy9ub2RlX21vZHVsZXMvd2VicGFjay1jbGkvYmluL2NsaS5qcycpLFxuICAgICAgICBbXG4gICAgICAgICAgJy0tY29sb3InLFxuICAgICAgICAgICctLXByb2dyZXNzJyxcbiAgICAgICAgICAnLS1jb25maWcnLCAnY29uZmlnLmpzJyxcbiAgICAgICAgICAnLS1hbmFseXplJyxcbiAgICAgICAgICAnLS1jb25maWdOYW1lJywgJ2NvbmZpZ05hbWUnLFxuICAgICAgICAgICctLWRlZmluZVByb2Nlc3NFbnZOb2RlRW52JywgJ2RldmVsb3BtZW50JyxcbiAgICAgICAgICAnLS1kZXZ0b29sJywgJ2RldnRvb2wnLFxuICAgICAgICAgICctLWRpc2FibGVJbnRlcnByZXQnLFxuICAgICAgICAgICctLWVudHJ5JywgJ2VudHJ5JyxcbiAgICAgICAgICAnLS1lbnYnLCAnZW52JyxcbiAgICAgICAgICAnLS1mYWlsT25XYXJuaW5ncycsXG4gICAgICAgICAgJy0tanNvbicsICdqc29uJyxcbiAgICAgICAgICAnLS1tb2RlJywgJ21vZGUnLFxuICAgICAgICAgICctLW1lcmdlJyxcbiAgICAgICAgICAnLS1uYW1lJywgJ25hbWUnLFxuICAgICAgICAgICctLW5vRGV2dG9vbCcsXG4gICAgICAgICAgJy0tbm9TdGF0cycsXG4gICAgICAgICAgJy0tbm9UYXJnZXQnLFxuICAgICAgICAgICctLW5vV2F0Y2gnLFxuICAgICAgICAgICctLW5vV2F0Y2hPcHRpb25zU3RkaW4nLFxuICAgICAgICAgICctLW5vZGVFbnYnLCAnbm9kZUVudicsXG4gICAgICAgICAgJy0tb3V0cHV0UGF0aCcsICdvdXRwdXRQYXRoJyxcbiAgICAgICAgICAnLS1zdGF0cycsICdzdGF0cycsXG4gICAgICAgICAgJy0tdGFyZ2V0JywgJ3RhcmdldCcsXG4gICAgICAgICAgJy0td2F0Y2gnLFxuICAgICAgICAgICctLXdhdGNoT3B0aW9uc1N0ZGluJ1xuICAgICAgICBdLFxuICAgICAgICB7ZW5jb2Rpbmc6ICd1dGY4Jywgc3RkaW86ICdpbmhlcml0J31cbiAgICAgICk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5zdWNjZWVkKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3Qoc3Bpbm5lci5mYWlsKS5ub3QudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgwKTtcbiAgICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMCk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIGhhbmRsZSBlcnJvcnMnLCBhc3luYyAoKSA9PiB7XG4gICAgICAoZXhlY2EgYXMgamVzdC5Nb2NrKS5tb2NrSW1wbGVtZW50YXRpb24oKCkgPT4gUHJvbWlzZS5yZWplY3QobmV3IEVycm9yKCdNb2NrIEVycm9yJykpKTtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGRXaXRoV2VicGFjayhzcGlubmVyLCB7Y2xpTmFtZTogJ1Rlc3QnfSwgY2FsbGJhY2spO1xuXG4gICAgICBleHBlY3Qoc3Bpbm5lci5zdWNjZWVkKS5ub3QudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KHNwaW5uZXIuZmFpbCkudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgxKTtcbiAgICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMSk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdidWlsZCcsICgpID0+IHtcbiAgICBpdCgnc2hvdWxkIGJ1aWxkIHdpdGggZGVmYXVsdHMnLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IGJ1aWxkKHt9LCBjYWxsYmFjayk7XG4gICAgICBleHBlY3QoY2hlY2tMaW5rZWRNb2R1bGVzKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoY2FsbGJhY2spLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKDEpO1xuICAgICAgZXhwZWN0KHN0YXR1cykudG9CZSgxKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgYnVpbGQgd2l0aCBkZWZpbmVkIHByb3BzJywgYXN5bmMgKCkgPT4ge1xuICAgICAgTGV4Q29uZmlnLmNvbmZpZyA9IHtcbiAgICAgICAgLi4uZGVmYXVsdENvbmZpZ1ZhbHVlcyxcbiAgICAgICAgdXNlVHlwZXNjcmlwdDogdHJ1ZVxuICAgICAgfTtcbiAgICAgIGNvbnN0IHN0YXR1czogbnVtYmVyID0gYXdhaXQgYnVpbGQoe1xuICAgICAgICBidW5kbGVyOiAnZXNidWlsZCcsXG4gICAgICAgIHJlbW92ZTogdHJ1ZVxuICAgICAgfSwgY2FsbGJhY2spO1xuICAgICAgZXhwZWN0KGNoZWNrTGlua2VkTW9kdWxlcykudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KHJlbW92ZUZpbGVzKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgICBleHBlY3QoTGV4Q29uZmlnLmNoZWNrVHlwZXNjcmlwdENvbmZpZykudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgxKTtcbiAgICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMSk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIGVycm9yIG9uIGJhZCB2YXJpYWJsZXMgdmFsdWUnLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IGJ1aWxkKHtcbiAgICAgICAgYnVuZGxlcjogJ2VzYnVpbGQnLFxuICAgICAgICB2YXJpYWJsZXM6ICd0ZXN0J1xuICAgICAgfSwgY2FsbGJhY2spO1xuICAgICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgxKTtcbiAgICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMSk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXSwKICAibWFwcGluZ3MiOiAiQUFBQSxTQUFRLFNBQVMsZUFBYztBQUMvQixTQUFRLGFBQVk7QUFFcEIsU0FBUSxPQUFPLGtCQUFrQix3QkFBdUI7QUFDeEQsU0FBUSxXQUFXLDJCQUEwQjtBQUM3QyxTQUFRLG9CQUFvQixtQkFBa0I7QUFFOUMsS0FBSyxLQUFLLFdBQVcsT0FBTztBQUFBLEVBQzFCLEdBQUcsS0FBSyxjQUFjLFNBQVM7QUFBQSxFQUMvQixPQUFPLEtBQUssR0FBRyxNQUFNLFFBQVEsUUFBUSxDQUFDLENBQUMsQ0FBQztBQUMxQyxFQUFFO0FBRUYsS0FBSyxLQUFLLFNBQVMsT0FBTztBQUFBLEVBQ3hCLEdBQUcsS0FBSyxjQUFjLE9BQU87QUFBQSxFQUM3QixPQUFPLEtBQUssR0FBRyxNQUFNLFFBQVEsUUFBUSxDQUFDLENBQUMsQ0FBQztBQUMxQyxFQUFFO0FBRUYsS0FBSyxLQUFLLDJDQUEyQyxPQUFPO0FBQUEsRUFDMUQsR0FBRyxLQUFLLGNBQWMseUNBQXlDO0FBQUEsRUFDL0QsWUFBWTtBQUFBLEVBQ1osU0FBUyxLQUFLLEdBQUcsTUFBTSxzQkFBc0I7QUFDL0MsRUFBRTtBQUVGLEtBQUssS0FBSyxnQkFBZ0IsT0FBTztBQUFBLEVBQy9CLEdBQUcsS0FBSyxjQUFjLGNBQWM7QUFBQSxFQUNwQyxvQkFBb0IsS0FBSyxHQUFHO0FBQUEsRUFDNUIsYUFBYSxLQUFLLEdBQUcsTUFBTSxRQUFRLFFBQVEsQ0FBQztBQUM5QyxFQUFFO0FBRUYsS0FBSyxLQUFLLGdCQUFnQixPQUFPO0FBQUEsRUFDL0IsV0FBVztBQUFBLElBQ1QsUUFBUSxDQUFDO0FBQUEsSUFDVCx1QkFBdUIsS0FBSyxHQUFHO0FBQUEsSUFDL0IsYUFBYSxLQUFLLEdBQUc7QUFBQSxFQUN2QjtBQUNGLEVBQUU7QUFFRixTQUFTLFNBQVMsTUFBTTtBQUN0QixNQUFJO0FBQ0osTUFBSTtBQUNKLE1BQUk7QUFF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QUNyQztBQUNBLGFBQU8sUUFBUSxPQUFPLEVBQUUsaUJBQWlCO0FBQ3pDLGFBQU8sUUFBUSxJQUFJLEVBQUUsSUFBSSxpQkFBaUI7QUFDMUMsYUFBT0EsU0FBUSxFQUFFLHFCQUFxQixDQUFDO0FBQ3ZDLGFBQU8sTUFBTSxFQUFFLEtBQUssQ0FBQztBQUFBLElBQ3ZCLENBQUM7QUFFRCxPQUFHLHdCQUF3QixZQUFZO0FBQ3JDLE1BQUMsTUFBb0IsbUJBQW1CLE1BQU0sUUFBUSxPQUFPLElBQUksTUFBTSxZQUFZLENBQUMsQ0FBQztBQUNyRixZQUFNLFNBQWlCLE1BQU0saUJBQWlCLFNBQVMsRUFBQyxTQUFTLE9BQU0sR0FBRyxRQUFRO0FBRWxGLGFBQU8sUUFBUSxPQUFPLEVBQUUsSUFBSSxpQkFBaUI7QUFDN0MsYUFBTyxRQUFRLElBQUksRUFBRSxpQkFBaUI7QUFDdEMsYUFBTyxRQUFRLEVBQUUscUJBQXFCLENBQUM7QUFDdkMsYUFBTyxNQUFNLEVBQUUsS0FBSyxDQUFDO0FBQUEsSUFDdkIsQ0FBQztBQUFBLEVBQ0gsQ0FBQztBQUVELFdBQVMsU0FBUyxNQUFNO0FBQ3RCLE9BQUcsOEJBQThCLFlBQVk7QUFDM0MsWUFBTSxTQUFpQixNQUFNLE1BQU0sQ0FBQyxHQUFHLFFBQVE7QUFDL0MsYUFBTyxrQkFBa0IsRUFBRSxpQkFBaUI7QUFDNUMsYUFBTyxRQUFRLEVBQUUscUJBQXFCLENBQUM7QUFDdkMsYUFBTyxNQUFNLEVBQUUsS0FBSyxDQUFDO0FBQUEsSUFDdkIsQ0FBQztBQUVELE9BQUcsbUNBQW1DLFlBQVk7QUFDaEQsZ0JBQVUsU0FBUztBQUFBLFFBQ2pCLEdBQUc7QUFBQSxRQUNILGVBQWU7QUFBQSxNQUNqQjtBQUNBLFlBQU0sU0FBaUIsTUFBTSxNQUFNO0FBQUEsUUFDakMsU0FBUztBQUFBLFFBQ1QsUUFBUTtBQUFBLE1BQ1YsR0FBRyxRQUFRO0FBQ1gsYUFBTyxrQkFBa0IsRUFBRSxpQkFBaUI7QUFDNUMsYUFBTyxXQUFXLEVBQUUsaUJBQWlCO0FBQ3JDLGFBQU8sVUFBVSxxQkFBcUIsRUFBRSxpQkFBaUI7QUFDekQsYUFBTyxRQUFRLEVBQUUscUJBQXFCLENBQUM7QUFDdkMsYUFBTyxNQUFNLEVBQUUsS0FBSyxDQUFDO0FBQUEsSUFDdkIsQ0FBQztBQUVELE9BQUcsdUNBQXVDLFlBQVk7QUFDcEQsWUFBTSxTQUFpQixNQUFNLE1BQU07QUFBQSxRQUNqQyxTQUFTO0FBQUEsUUFDVCxXQUFXO0FBQUEsTUFDYixHQUFHLFFBQVE7QUFDWCxhQUFPLFFBQVEsRUFBRSxxQkFBcUIsQ0FBQztBQUN2QyxhQUFPLE1BQU0sRUFBRSxLQUFLLENBQUM7QUFBQSxJQUN2QixDQUFDO0FBQUEsRUFDSCxDQUFDO0FBQ0gsQ0FBQzsiLAogICJuYW1lcyI6IFsiY2FsbGJhY2siXQp9Cg==