@nlabs/lex 1.39.0 → 1.41.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 (43) hide show
  1. package/.eslintrc +1 -0
  2. package/.vscode/settings.json +1 -1
  3. package/babel.config.json +13 -0
  4. package/dist/LexConfig.js +40 -36
  5. package/dist/commands/build.js +98 -52
  6. package/dist/commands/bulid.test.js +314 -5
  7. package/dist/commands/clean.js +4 -4
  8. package/dist/commands/clean.test.js +63 -0
  9. package/dist/commands/compile.js +32 -35
  10. package/dist/commands/compile.test.js +93 -0
  11. package/dist/commands/config.js +4 -4
  12. package/dist/commands/copy.js +1 -1
  13. package/dist/commands/create.js +10 -10
  14. package/dist/commands/dev.js +12 -12
  15. package/dist/commands/init.js +17 -17
  16. package/dist/commands/link.js +3 -3
  17. package/dist/commands/lint.js +53 -39
  18. package/dist/commands/migrate.js +4 -4
  19. package/dist/commands/publish.js +7 -7
  20. package/dist/commands/test.js +14 -14
  21. package/dist/commands/update.js +10 -10
  22. package/dist/commands/upgrade.js +7 -7
  23. package/dist/commands/versions.js +8 -9
  24. package/dist/commands/versions.test.js +49 -0
  25. package/dist/create/changelog.js +3 -3
  26. package/dist/lex.js +16 -16
  27. package/dist/lint.js +8 -0
  28. package/dist/utils/app.js +1 -1
  29. package/dist/utils/file.js +20 -10
  30. package/jest.config.cjs +55 -0
  31. package/jest.config.lex.js +27 -28
  32. package/jest.setup.ts +3 -0
  33. package/package.json +76 -71
  34. package/resolver.cjs +86 -0
  35. package/test/javascript.js +6 -0
  36. package/test/typescript.ts +6 -0
  37. package/tsconfig.build.json +1 -1
  38. package/tsconfig.json +1 -1
  39. package/tsconfig.template.json +5 -5
  40. package/webpack.config.js +78 -65
  41. package/dist/resolver.js +0 -70
  42. package/jest.config.js +0 -14
  43. package/jest.setup.js +0 -3
@@ -1,8 +1,317 @@
1
- import { build } from "./build.js";
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";
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
+ }));
2
31
  describe("build", () => {
3
- it("should", async () => {
4
- const status = await build({ cliName: "Test" }, Promise.resolve);
5
- expect(status).toBe(1);
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
+ "/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
+ "--config-name",
235
+ "configName",
236
+ "--define-process-env-node-env",
237
+ "development",
238
+ "--devtool",
239
+ "devtool",
240
+ "--disable-interpret",
241
+ "--entry",
242
+ "entry",
243
+ "--env",
244
+ "env",
245
+ "--fail-on-warnings",
246
+ "--json",
247
+ "json",
248
+ "--mode",
249
+ "mode",
250
+ "--merge",
251
+ "--name",
252
+ "name",
253
+ "--no-devtool",
254
+ "--no-stats",
255
+ "--no-target",
256
+ "--no-watch",
257
+ "--no-watch-options-stdin",
258
+ "--node-env",
259
+ "nodeEnv",
260
+ "--output-path",
261
+ "outputPath",
262
+ "--stats",
263
+ "stats",
264
+ "--target",
265
+ "target",
266
+ "--watch",
267
+ "--watch-options-stdin"
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
+ });
6
315
  });
7
316
  });
8
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1bGlkLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7YnVpbGR9IGZyb20gJy4vYnVpbGQuanMnO1xuXG5kZXNjcmliZSgnYnVpbGQnLCAoKSA9PiB7XG4gIGl0KCdzaG91bGQnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZCh7Y2xpTmFtZTogJ1Rlc3QnfSwgUHJvbWlzZS5yZXNvbHZlKTtcbiAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDEpO1xuICB9KTtcbn0pO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUEsU0FBUSxhQUFZO0FBRXBCLFNBQVMsU0FBUyxNQUFNO0FBQ3RCLEtBQUcsVUFBVSxZQUFZO0FBQ3ZCLFVBQU0sU0FBaUIsTUFBTSxNQUFNLEVBQUMsU0FBUyxPQUFNLEdBQUcsUUFBUSxPQUFPO0FBQ3JFLFdBQU8sTUFBTSxFQUFFLEtBQUssQ0FBQztBQUFBLEVBQ3ZCLENBQUM7QUFDSCxDQUFDOyIsCiAgIm5hbWVzIjogW10KfQo=
317
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/bulid.test.ts"],
  "sourcesContent": ["import {build as esBuild} from 'esbuild';\nimport {execa} from 'execa';\n\nimport {build, buildWithEsBuild, buildWithWebpack} from './build.js';\nimport {LexConfig, defaultConfigValues} from '../LexConfig.js';\nimport {checkLinkedModules, removeFiles} from '../utils/app';\n\njest.mock('esbuild', () => ({\n  ...jest.requireActual('esbuild'),\n  build: jest.fn(() => Promise.resolve({}))\n}));\n\njest.mock('execa', () => ({\n  ...jest.requireActual('execa'),\n  execa: jest.fn(() => Promise.resolve({}))\n}));\n\njest.mock('@luckycatfactory/esbuild-graphql-loader', () => ({\n  ...jest.requireActual('@luckycatfactory/esbuild-graphql-loader'),\n  __esModule: true,\n  default: jest.fn(() => 'esbuildGraphqlLoader')\n}));\n\njest.mock('../utils/app', () => ({\n  ...jest.requireActual('../utils/app'),\n  checkLinkedModules: jest.fn(),\n  removeFiles: jest.fn(() => Promise.resolve())\n}));\n\njest.mock('../LexConfig', () => ({\n  LexConfig: {\n    config: {},\n    checkTypescriptConfig: jest.fn(),\n    parseConfig: jest.fn()\n  }\n}));\n\ndescribe('build', () => {\n  let callback: jest.Mock;\n  let spinner: any;\n  let oldConsole;\n\n  beforeAll(() => {\n    oldConsole = {...console};\n    console = {\n      ...oldConsole,\n      debug: jest.fn(),\n      error: jest.fn(),\n      warn: jest.fn()\n    };\n  });\n\n  beforeEach(() => {\n    LexConfig.config = {\n      ...defaultConfigValues\n    };\n\n    callback = jest.fn();\n    spinner = {\n      succeed: jest.fn(),\n      fail: jest.fn()\n    };\n  });\n\n  afterAll(() => {\n    console = {...oldConsole};\n    jest.resetAllMocks();\n  });\n\n  describe('buildWithEsBuild', () => {\n    beforeEach(() => {\n      (esBuild as jest.Mock).mockImplementation(() => Promise.resolve({}));\n    });\n\n    it('should build using default config', async () => {\n      const status: number = await buildWithEsBuild(spinner, {}, callback);\n      expect(esBuild).toHaveBeenCalledWith({\n        bundle: true,\n        color: true,\n        entryPoints: [undefined],\n        loader: {\n          '.js': 'js'\n        },\n        outdir: undefined,\n        platform: 'node',\n        plugins: [],\n        sourcemap: 'inline',\n        target: 'es2016',\n        watch: false\n      });\n      expect(spinner.succeed).toHaveBeenCalled();\n      expect(spinner.fail).not.toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(0);\n      expect(status).toBe(0);\n    });\n\n    it('should build for node', async () => {\n      LexConfig.config = {\n        ...defaultConfigValues,\n        targetEnvironment: 'node'\n      };\n      const status: number = await buildWithEsBuild(spinner, {}, callback);\n      expect(esBuild).toHaveBeenCalledWith({\n        bundle: true,\n        color: true,\n        entryPoints: [undefined],\n        loader: {\n          '.js': 'js'\n        },\n        outdir: undefined,\n        platform: 'node',\n        plugins: [],\n        sourcemap: 'inline',\n        target: 'node18',\n        watch: false\n      });\n      expect(spinner.succeed).toHaveBeenCalled();\n      expect(spinner.fail).not.toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(0);\n      expect(status).toBe(0);\n    });\n\n    it('should build using typescript', async () => {\n      LexConfig.config = {\n        ...defaultConfigValues,\n        useTypescript: true\n      };\n      const callback = jest.fn();\n      const status: number = await buildWithEsBuild(spinner, {cliName: 'Test'}, callback);\n      expect(esBuild).toHaveBeenCalledWith({\n        bundle: true,\n        color: true,\n        entryPoints: [undefined],\n        loader: {\n          '.js': 'js',\n          '.ts': 'ts',\n          '.tsx': 'tsx'\n        },\n        outdir: undefined,\n        platform: 'node',\n        plugins: [],\n        sourcemap: 'inline',\n        target: 'es2016',\n        watch: false\n      });\n      expect(spinner.succeed).toHaveBeenCalled();\n      expect(spinner.fail).not.toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(0);\n      expect(status).toBe(0);\n    });\n\n    it('should build using graphql', async () => {\n      LexConfig.config = {\n        ...defaultConfigValues,\n        useGraphQl: true\n      };\n      const status: number = await buildWithEsBuild(spinner, {cliName: 'Test'}, callback);\n\n      expect(esBuild).toHaveBeenCalledWith({\n        bundle: true,\n        color: true,\n        entryPoints: [undefined],\n        loader: {\n          '.js': 'js'\n        },\n        outdir: undefined,\n        platform: 'node',\n        plugins: ['esbuildGraphqlLoader'],\n        sourcemap: 'inline',\n        target: 'es2016',\n        watch: false\n      });\n      expect(spinner.succeed).toHaveBeenCalled();\n      expect(spinner.fail).not.toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(0);\n      expect(status).toBe(0);\n    });\n\n    it('should handle errors', async () => {\n      (esBuild as jest.Mock).mockImplementation(() => Promise.reject(new Error('Mock Error')));\n      const status: number = await buildWithEsBuild(spinner, {cliName: 'Test'}, callback);\n\n      expect(spinner.succeed).not.toHaveBeenCalled();\n      expect(spinner.fail).toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(1);\n      expect(status).toBe(1);\n    });\n  });\n\n  describe('buildWithWebpack', () => {\n    beforeEach(() => {\n      (execa as jest.Mock).mockImplementation(() => Promise.resolve({}));\n    });\n\n    it('should build using default config', async () => {\n      const status: number = await buildWithWebpack(spinner, {}, callback);\n      expect(execa).toHaveBeenCalledWith(\n        expect.stringContaining('/node_modules/webpack-cli/bin/cli.js'),\n        [\n          '--color',\n          '--progress',\n          '--config', '/webpack.config.js'\n        ],\n        {encoding: 'utf8', stdio: 'inherit'}\n      );\n      expect(spinner.succeed).toHaveBeenCalled();\n      expect(spinner.fail).not.toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(0);\n      expect(status).toBe(0);\n    });\n\n    it('should build using custom options', async () => {\n      LexConfig.config = {\n        ...defaultConfigValues,\n        useTypescript: true\n      };\n      const callback = jest.fn();\n      const cmd = {\n        analyze: true,\n        cliName: 'Lex',\n        config: 'config.js',\n        configName: 'configName',\n        defineProcessEnvNodeEnv: 'development',\n        devtool: 'devtool',\n        disableInterpret: true,\n        entry: 'entry',\n        env: 'env',\n        failOnWarnings: true,\n        json: 'json',\n        merge: 'merge',\n        mode: 'mode',\n        name: 'name',\n        nodeEnv: 'nodeEnv',\n        noDevtool: true,\n        noStats: true,\n        noTarget: true,\n        noWatch: true,\n        noWatchOptionsStdin: true,\n        outputPath: 'outputPath',\n        quiet: false,\n        stats: 'stats',\n        target: 'target',\n        watch: true,\n        watchOptionsStdin: true\n      };\n      const status: number = await buildWithWebpack(spinner, cmd, callback);\n      expect(execa).toHaveBeenLastCalledWith(\n        expect.stringContaining('/node_modules/webpack-cli/bin/cli.js'),\n        [\n          '--color',\n          '--progress',\n          '--config', 'config.js',\n          '--analyze',\n          '--config-name', 'configName',\n          '--define-process-env-node-env', 'development',\n          '--devtool', 'devtool',\n          '--disable-interpret',\n          '--entry', 'entry',\n          '--env', 'env',\n          '--fail-on-warnings',\n          '--json', 'json',\n          '--mode', 'mode',\n          '--merge',\n          '--name', 'name',\n          '--no-devtool',\n          '--no-stats',\n          '--no-target',\n          '--no-watch',\n          '--no-watch-options-stdin',\n          '--node-env', 'nodeEnv',\n          '--output-path', 'outputPath',\n          '--stats', 'stats',\n          '--target', 'target',\n          '--watch',\n          '--watch-options-stdin'\n        ],\n        {encoding: 'utf8', stdio: 'inherit'}\n      );\n      expect(spinner.succeed).toHaveBeenCalled();\n      expect(spinner.fail).not.toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(0);\n      expect(status).toBe(0);\n    });\n\n    it('should handle errors', async () => {\n      (execa as jest.Mock).mockImplementation(() => Promise.reject(new Error('Mock Error')));\n      const status: number = await buildWithWebpack(spinner, {cliName: 'Test'}, callback);\n\n      expect(spinner.succeed).not.toHaveBeenCalled();\n      expect(spinner.fail).toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(1);\n      expect(status).toBe(1);\n    });\n  });\n\n  describe('build', () => {\n    it('should build with defaults', async () => {\n      const status: number = await build({}, callback);\n      expect(checkLinkedModules).toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(1);\n      expect(status).toBe(1);\n    });\n\n    it('should build with defined props', async () => {\n      LexConfig.config = {\n        ...defaultConfigValues,\n        useTypescript: true\n      };\n      const status: number = await build({\n        bundler: 'esbuild',\n        remove: true\n      }, callback);\n      expect(checkLinkedModules).toHaveBeenCalled();\n      expect(removeFiles).toHaveBeenCalled();\n      expect(LexConfig.checkTypescriptConfig).toHaveBeenCalled();\n      expect(callback).toHaveBeenCalledWith(1);\n      expect(status).toBe(1);\n    });\n\n    it('should error on bad variables value', async () => {\n      const status: number = await build({\n        bundler: 'esbuild',\n        variables: 'test'\n      }, callback);\n      expect(callback).toHaveBeenCalledWith(1);\n      expect(status).toBe(1);\n    });\n  });\n});\n"],
  "mappings": "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",
  "names": ["callback"]
}

@@ -5,7 +5,7 @@ const clean = async (cmd, callback = () => ({})) => {
5
5
  const { cliName = "Lex", quiet, snapshots } = cmd;
6
6
  const spinner = createSpinner(quiet);
7
7
  log(`${cliName} cleaning directory...`, "info", quiet);
8
- LexConfig.parseConfig(cmd);
8
+ await LexConfig.parseConfig(cmd);
9
9
  spinner.start("Cleaning files...");
10
10
  try {
11
11
  await removeModules();
@@ -21,11 +21,11 @@ const clean = async (cmd, callback = () => ({})) => {
21
21
  log(`
22
22
  ${cliName} Error: ${error.message}`, "error", quiet);
23
23
  spinner.fail("Failed to clean project.");
24
- callback(error.status);
25
- return error.status;
24
+ callback(1);
25
+ return 1;
26
26
  }
27
27
  };
28
28
  export {
29
29
  clean
30
30
  };
31
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NsZWFuLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBjbGVhbiA9IGFzeW5jIChjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBxdWlldCwgc25hcHNob3RzfSA9IGNtZDtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gY2xlYW5pbmcgZGlyZWN0b3J5Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIC8vIFN0YXJ0IGNsZWFuaW5nIHNwaW5uZXJcbiAgc3Bpbm5lci5zdGFydCgnQ2xlYW5pbmcgZmlsZXMuLi4nKTtcblxuICB0cnkge1xuICAgIC8vIFJlbW92ZSBub2RlX21vZHVsZXNcbiAgICBhd2FpdCByZW1vdmVNb2R1bGVzKCk7XG5cbiAgICAvLyBSZW1vdmUgdGVzdCBjb3ZlcmFnZSByZXBvcnRzXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vY292ZXJhZ2UnLCB0cnVlKTtcblxuICAgIC8vIFJlbW92ZSBucG0gbG9nc1xuICAgIGF3YWl0IHJlbW92ZUZpbGVzKCcuL25wbS1kZWJ1Zy5sb2cnLCB0cnVlKTtcblxuICAgIGlmKHNuYXBzaG90cykge1xuICAgICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vKiovX19zbmFwc2hvdHNfXycsIHRydWUpO1xuICAgIH1cblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnU3VjY2Vzc2Z1bGx5IGNsZWFuZWQhJyk7XG5cbiAgICAvLyBTdG9wIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIGNsZWFuIHByb2plY3QuJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjayhlcnJvci5zdGF0dXMpO1xuICAgIHJldHVybiBlcnJvci5zdGF0dXM7XG4gIH1cbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGlCQUFnQjtBQUN4QixTQUFRLGVBQWUsYUFBYSxxQkFBb0I7QUFDeEQsU0FBUSxXQUFVO0FBRVgsTUFBTSxRQUFRLE9BQU8sS0FBVSxXQUFnQixPQUFPLENBQUMsT0FBd0I7QUFDcEYsUUFBTSxFQUFDLFVBQVUsT0FBTyxPQUFPLFVBQVMsSUFBSTtBQUc1QyxRQUFNLFVBQVUsY0FBYyxLQUFLO0FBR25DLE1BQUksR0FBRyxpQ0FBaUMsUUFBUSxLQUFLO0FBR3JELFlBQVUsWUFBWSxHQUFHO0FBR3pCLFVBQVEsTUFBTSxtQkFBbUI7QUFFakMsTUFBSTtBQUVGLFVBQU0sY0FBYztBQUdwQixVQUFNLFlBQVksY0FBYyxJQUFJO0FBR3BDLFVBQU0sWUFBWSxtQkFBbUIsSUFBSTtBQUV6QyxRQUFHLFdBQVc7QUFDWixZQUFNLFlBQVksc0JBQXNCLElBQUk7QUFBQSxJQUM5QztBQUdBLFlBQVEsUUFBUSx1QkFBdUI7QUFHdkMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUSxPQUFOO0FBRUEsUUFBSTtBQUFBLEVBQUssa0JBQWtCLE1BQU0sV0FBVyxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDBCQUEwQjtBQUd2QyxhQUFTLE1BQU0sTUFBTTtBQUNyQixXQUFPLE1BQU07QUFBQSxFQUNmO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
31
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NsZWFuLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBjbGVhbiA9IGFzeW5jIChjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBxdWlldCwgc25hcHNob3RzfSA9IGNtZDtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gY2xlYW5pbmcgZGlyZWN0b3J5Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIGF3YWl0IExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIC8vIFN0YXJ0IGNsZWFuaW5nIHNwaW5uZXJcbiAgc3Bpbm5lci5zdGFydCgnQ2xlYW5pbmcgZmlsZXMuLi4nKTtcblxuICB0cnkge1xuICAgIC8vIFJlbW92ZSBub2RlX21vZHVsZXNcbiAgICBhd2FpdCByZW1vdmVNb2R1bGVzKCk7XG5cbiAgICAvLyBSZW1vdmUgdGVzdCBjb3ZlcmFnZSByZXBvcnRzXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vY292ZXJhZ2UnLCB0cnVlKTtcblxuICAgIC8vIFJlbW92ZSBucG0gbG9nc1xuICAgIGF3YWl0IHJlbW92ZUZpbGVzKCcuL25wbS1kZWJ1Zy5sb2cnLCB0cnVlKTtcblxuICAgIGlmKHNuYXBzaG90cykge1xuICAgICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vKiovX19zbmFwc2hvdHNfXycsIHRydWUpO1xuICAgIH1cblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnU3VjY2Vzc2Z1bGx5IGNsZWFuZWQhJyk7XG5cbiAgICAvLyBTdG9wIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIGNsZWFuIHByb2plY3QuJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gMTtcbiAgfVxufTtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsaUJBQWdCO0FBQ3hCLFNBQVEsZUFBZSxhQUFhLHFCQUFvQjtBQUN4RCxTQUFRLFdBQVU7QUFFWCxNQUFNLFFBQVEsT0FBTyxLQUFVLFdBQWdCLE9BQU8sQ0FBQyxPQUF3QjtBQUNwRixRQUFNLEVBQUMsVUFBVSxPQUFPLE9BQU8sVUFBUyxJQUFJO0FBRzVDLFFBQU0sVUFBVSxjQUFjLEtBQUs7QUFHbkMsTUFBSSxHQUFHLE9BQU8sMEJBQTBCLFFBQVEsS0FBSztBQUdyRCxRQUFNLFVBQVUsWUFBWSxHQUFHO0FBRy9CLFVBQVEsTUFBTSxtQkFBbUI7QUFFakMsTUFBSTtBQUVGLFVBQU0sY0FBYztBQUdwQixVQUFNLFlBQVksY0FBYyxJQUFJO0FBR3BDLFVBQU0sWUFBWSxtQkFBbUIsSUFBSTtBQUV6QyxRQUFHLFdBQVc7QUFDWixZQUFNLFlBQVksc0JBQXNCLElBQUk7QUFBQSxJQUM5QztBQUdBLFlBQVEsUUFBUSx1QkFBdUI7QUFHdkMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUSxPQUFPO0FBRWIsUUFBSTtBQUFBLEVBQUssT0FBTyxXQUFXLE1BQU0sT0FBTyxJQUFJLFNBQVMsS0FBSztBQUcxRCxZQUFRLEtBQUssMEJBQTBCO0FBR3ZDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNUO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -0,0 +1,63 @@
1
+ import { clean } from "./clean";
2
+ import { LexConfig, defaultConfigValues } from "../LexConfig.js";
3
+ import { removeFiles, removeModules } from "../utils/app.js";
4
+ jest.mock("../utils/app", () => ({
5
+ ...jest.requireActual("../utils/app"),
6
+ removeFiles: jest.fn(() => Promise.resolve()),
7
+ removeModules: jest.fn(() => Promise.resolve())
8
+ }));
9
+ jest.mock("../LexConfig", () => ({
10
+ LexConfig: {
11
+ config: {},
12
+ checkTypescriptConfig: jest.fn(),
13
+ parseConfig: jest.fn()
14
+ }
15
+ }));
16
+ describe("clean", () => {
17
+ let callback;
18
+ let oldConsole;
19
+ beforeAll(() => {
20
+ oldConsole = { ...console };
21
+ console = {
22
+ ...oldConsole,
23
+ debug: jest.fn(),
24
+ error: jest.fn(),
25
+ warn: jest.fn()
26
+ };
27
+ });
28
+ beforeEach(() => {
29
+ callback = jest.fn();
30
+ LexConfig.config = {
31
+ ...defaultConfigValues
32
+ };
33
+ });
34
+ afterAll(() => {
35
+ console = { ...oldConsole };
36
+ jest.resetAllMocks();
37
+ });
38
+ it("should clean using default config", async () => {
39
+ const status = await clean({}, callback);
40
+ expect(LexConfig.parseConfig).toHaveBeenCalled();
41
+ expect(removeFiles).toHaveBeenCalled();
42
+ expect(removeModules).toHaveBeenCalled();
43
+ expect(callback).toHaveBeenCalledWith(0);
44
+ expect(status).toBe(0);
45
+ });
46
+ it("should clean using config", async () => {
47
+ const status = await clean({
48
+ snapshots: true
49
+ }, callback);
50
+ expect(LexConfig.parseConfig).toHaveBeenCalled();
51
+ expect(removeFiles).toHaveBeenCalled();
52
+ expect(removeModules).toHaveBeenCalled();
53
+ expect(callback).toHaveBeenCalledWith(0);
54
+ expect(status).toBe(0);
55
+ });
56
+ it("should error on removing files", async () => {
57
+ removeFiles.mockImplementation(() => Promise.reject(new Error("Remove Error")));
58
+ const status = await clean({}, callback);
59
+ expect(callback).toHaveBeenCalledWith(1);
60
+ expect(status).toBe(1);
61
+ });
62
+ });
63
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NsZWFuLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7Y2xlYW59IGZyb20gJy4vY2xlYW4nO1xuaW1wb3J0IHtMZXhDb25maWcsIGRlZmF1bHRDb25maWdWYWx1ZXN9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge3JlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuXG5qZXN0Lm1vY2soJy4uL3V0aWxzL2FwcCcsICgpID0+ICh7XG4gIC4uLmplc3QucmVxdWlyZUFjdHVhbCgnLi4vdXRpbHMvYXBwJyksXG4gIHJlbW92ZUZpbGVzOiBqZXN0LmZuKCgpID0+IFByb21pc2UucmVzb2x2ZSgpKSxcbiAgcmVtb3ZlTW9kdWxlczogamVzdC5mbigoKSA9PiBQcm9taXNlLnJlc29sdmUoKSlcbn0pKTtcblxuamVzdC5tb2NrKCcuLi9MZXhDb25maWcnLCAoKSA9PiAoe1xuICBMZXhDb25maWc6IHtcbiAgICBjb25maWc6IHt9LFxuICAgIGNoZWNrVHlwZXNjcmlwdENvbmZpZzogamVzdC5mbigpLFxuICAgIHBhcnNlQ29uZmlnOiBqZXN0LmZuKClcbiAgfVxufSkpO1xuXG5kZXNjcmliZSgnY2xlYW4nLCAoKSA9PiB7XG4gIGxldCBjYWxsYmFjazogamVzdC5Nb2NrO1xuICBsZXQgb2xkQ29uc29sZTtcblxuICBiZWZvcmVBbGwoKCkgPT4ge1xuICAgIG9sZENvbnNvbGUgPSB7Li4uY29uc29sZX07XG4gICAgY29uc29sZSA9IHtcbiAgICAgIC4uLm9sZENvbnNvbGUsXG4gICAgICBkZWJ1ZzogamVzdC5mbigpLFxuICAgICAgZXJyb3I6IGplc3QuZm4oKSxcbiAgICAgIHdhcm46IGplc3QuZm4oKVxuICAgIH07XG4gIH0pO1xuXG4gIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgIGNhbGxiYWNrID0gamVzdC5mbigpO1xuICAgIExleENvbmZpZy5jb25maWcgPSB7XG4gICAgICAuLi5kZWZhdWx0Q29uZmlnVmFsdWVzXG4gICAgfTtcbiAgfSk7XG5cbiAgYWZ0ZXJBbGwoKCkgPT4ge1xuICAgIGNvbnNvbGUgPSB7Li4ub2xkQ29uc29sZX07XG4gICAgamVzdC5yZXNldEFsbE1vY2tzKCk7XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgY2xlYW4gdXNpbmcgZGVmYXVsdCBjb25maWcnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBjbGVhbih7fSwgY2FsbGJhY2spO1xuICAgIGV4cGVjdChMZXhDb25maWcucGFyc2VDb25maWcpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QocmVtb3ZlRmlsZXMpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QocmVtb3ZlTW9kdWxlcykudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgIGV4cGVjdChjYWxsYmFjaykudG9IYXZlQmVlbkNhbGxlZFdpdGgoMCk7XG4gICAgZXhwZWN0KHN0YXR1cykudG9CZSgwKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBjbGVhbiB1c2luZyBjb25maWcnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBjbGVhbih7XG4gICAgICBzbmFwc2hvdHM6IHRydWVcbiAgICB9LCBjYWxsYmFjayk7XG4gICAgZXhwZWN0KExleENvbmZpZy5wYXJzZUNvbmZpZykudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgIGV4cGVjdChyZW1vdmVGaWxlcykudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgIGV4cGVjdChyZW1vdmVNb2R1bGVzKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgwKTtcbiAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDApO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIGVycm9yIG9uIHJlbW92aW5nIGZpbGVzJywgYXN5bmMgKCkgPT4ge1xuICAgIChyZW1vdmVGaWxlcyBhcyBqZXN0Lk1vY2spLm1vY2tJbXBsZW1lbnRhdGlvbigoKSA9PiBQcm9taXNlLnJlamVjdChuZXcgRXJyb3IoJ1JlbW92ZSBFcnJvcicpKSk7XG4gICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBjbGVhbih7fSwgY2FsbGJhY2spO1xuICAgIGV4cGVjdChjYWxsYmFjaykudG9IYXZlQmVlbkNhbGxlZFdpdGgoMSk7XG4gICAgZXhwZWN0KHN0YXR1cykudG9CZSgxKTtcbiAgfSk7XG59KTtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUFBLFNBQVEsYUFBWTtBQUNwQixTQUFRLFdBQVcsMkJBQTBCO0FBQzdDLFNBQVEsYUFBYSxxQkFBb0I7QUFFekMsS0FBSyxLQUFLLGdCQUFnQixPQUFPO0FBQUEsRUFDL0IsR0FBRyxLQUFLLGNBQWMsY0FBYztBQUFBLEVBQ3BDLGFBQWEsS0FBSyxHQUFHLE1BQU0sUUFBUSxRQUFRLENBQUM7QUFBQSxFQUM1QyxlQUFlLEtBQUssR0FBRyxNQUFNLFFBQVEsUUFBUSxDQUFDO0FBQ2hELEVBQUU7QUFFRixLQUFLLEtBQUssZ0JBQWdCLE9BQU87QUFBQSxFQUMvQixXQUFXO0FBQUEsSUFDVCxRQUFRLENBQUM7QUFBQSxJQUNULHVCQUF1QixLQUFLLEdBQUc7QUFBQSxJQUMvQixhQUFhLEtBQUssR0FBRztBQUFBLEVBQ3ZCO0FBQ0YsRUFBRTtBQUVGLFNBQVMsU0FBUyxNQUFNO0FBQ3RCLE1BQUk7QUFDSixNQUFJO0FBRUosWUFBVSxNQUFNO0FBQ2QsaUJBQWEsRUFBQyxHQUFHLFFBQU87QUFDeEIsY0FBVTtBQUFBLE1BQ1IsR0FBRztBQUFBLE1BQ0gsT0FBTyxLQUFLLEdBQUc7QUFBQSxNQUNmLE9BQU8sS0FBSyxHQUFHO0FBQUEsTUFDZixNQUFNLEtBQUssR0FBRztBQUFBLElBQ2hCO0FBQUEsRUFDRixDQUFDO0FBRUQsYUFBVyxNQUFNO0FBQ2YsZUFBVyxLQUFLLEdBQUc7QUFDbkIsY0FBVSxTQUFTO0FBQUEsTUFDakIsR0FBRztBQUFBLElBQ0w7QUFBQSxFQUNGLENBQUM7QUFFRCxXQUFTLE1BQU07QUFDYixjQUFVLEVBQUMsR0FBRyxXQUFVO0FBQ3hCLFNBQUssY0FBYztBQUFBLEVBQ3JCLENBQUM7QUFFRCxLQUFHLHFDQUFxQyxZQUFZO0FBQ2xELFVBQU0sU0FBaUIsTUFBTSxNQUFNLENBQUMsR0FBRyxRQUFRO0FBQy9DLFdBQU8sVUFBVSxXQUFXLEVBQUUsaUJBQWlCO0FBQy9DLFdBQU8sV0FBVyxFQUFFLGlCQUFpQjtBQUNyQyxXQUFPLGFBQWEsRUFBRSxpQkFBaUI7QUFDdkMsV0FBTyxRQUFRLEVBQUUscUJBQXFCLENBQUM7QUFDdkMsV0FBTyxNQUFNLEVBQUUsS0FBSyxDQUFDO0FBQUEsRUFDdkIsQ0FBQztBQUVELEtBQUcsNkJBQTZCLFlBQVk7QUFDMUMsVUFBTSxTQUFpQixNQUFNLE1BQU07QUFBQSxNQUNqQyxXQUFXO0FBQUEsSUFDYixHQUFHLFFBQVE7QUFDWCxXQUFPLFVBQVUsV0FBVyxFQUFFLGlCQUFpQjtBQUMvQyxXQUFPLFdBQVcsRUFBRSxpQkFBaUI7QUFDckMsV0FBTyxhQUFhLEVBQUUsaUJBQWlCO0FBQ3ZDLFdBQU8sUUFBUSxFQUFFLHFCQUFxQixDQUFDO0FBQ3ZDLFdBQU8sTUFBTSxFQUFFLEtBQUssQ0FBQztBQUFBLEVBQ3ZCLENBQUM7QUFFRCxLQUFHLGtDQUFrQyxZQUFZO0FBQy9DLElBQUMsWUFBMEIsbUJBQW1CLE1BQU0sUUFBUSxPQUFPLElBQUksTUFBTSxjQUFjLENBQUMsQ0FBQztBQUM3RixVQUFNLFNBQWlCLE1BQU0sTUFBTSxDQUFDLEdBQUcsUUFBUTtBQUMvQyxXQUFPLFFBQVEsRUFBRSxxQkFBcUIsQ0FBQztBQUN2QyxXQUFPLE1BQU0sRUFBRSxLQUFLLENBQUM7QUFBQSxFQUN2QixDQUFDO0FBQ0gsQ0FBQzsiLAogICJuYW1lcyI6IFtdCn0K