@nlabs/lex 1.54.2 → 1.55.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 (58) hide show
  1. package/.github/copilot-instructions.md +4 -4
  2. package/README.md +25 -25
  3. package/__mocks__/LexConfig.js +9 -9
  4. package/__mocks__/boxen.js +1 -1
  5. package/__mocks__/build.js +6 -6
  6. package/__mocks__/compare-versions.js +1 -1
  7. package/__mocks__/compile.js +2 -2
  8. package/__mocks__/execa.js +2 -2
  9. package/__mocks__/latest-version.js +1 -1
  10. package/__mocks__/ora.js +13 -13
  11. package/__mocks__/versions.js +4 -4
  12. package/config.json +2 -2
  13. package/examples/lex.config.js +4 -4
  14. package/lex.config.js +4 -4
  15. package/lib/Button.stories.js +1 -1
  16. package/lib/LexConfig.d.ts +2 -9
  17. package/lib/LexConfig.js +2 -2
  18. package/lib/commands/ai/ai.js +2 -2
  19. package/lib/commands/clean/clean.js +1 -1
  20. package/lib/commands/config/config.js +14 -8
  21. package/lib/commands/copy/copy.js +1 -1
  22. package/lib/commands/create/create.js +1 -1
  23. package/lib/commands/dev/dev.js +1 -1
  24. package/lib/commands/init/init.js +1 -1
  25. package/lib/commands/link/link.js +1 -1
  26. package/lib/commands/lint/lint.js +1 -1
  27. package/lib/commands/migrate/migrate.js +2 -2
  28. package/lib/commands/serverless/serverless.js +1 -1
  29. package/lib/commands/storybook/storybook.js +1 -1
  30. package/lib/commands/test/test.d.ts +2 -0
  31. package/lib/commands/test/test.js +130 -117
  32. package/lib/commands/versions/versions.d.ts +1 -1
  33. package/lib/commands/versions/versions.js +3 -3
  34. package/lib/create/changelog.js +1 -1
  35. package/lib/lex.js +2 -2
  36. package/lib/test-react/index.d.ts +1 -1
  37. package/lib/test-react/index.js +2 -2
  38. package/lib/types.d.ts +1 -1
  39. package/lib/types.js +1 -1
  40. package/lib/utils/aiService.js +1 -1
  41. package/lib/utils/app.js +2 -2
  42. package/lib/vitest.d.js +3 -0
  43. package/package.json +41 -53
  44. package/resolver.cjs +11 -9
  45. package/tsconfig/reactNative.json +3 -2
  46. package/tsconfig.build.json +3 -3
  47. package/tsconfig.json +4 -3
  48. package/tsconfig.lint.json +3 -2
  49. package/tsconfig.template.json +3 -2
  50. package/tsconfig.test.json +4 -3
  51. package/vitest.config.d.mts +2 -0
  52. package/vitest.config.mjs +61 -0
  53. package/vitest.config.template.cjs +66 -0
  54. package/vitest.setup.template.js +19 -0
  55. package/jest.config.d.mts +0 -50
  56. package/jest.config.mjs +0 -72
  57. package/jest.config.template.cjs +0 -71
  58. package/jest.setup.template.js +0 -18
@@ -24,7 +24,7 @@ const detectESM = (cwd)=>{
24
24
  return false;
25
25
  };
26
26
  const defaultExit = (code)=>{
27
- if (process.env.JEST_WORKER_ID || process.env.NODE_ENV === 'test') {
27
+ if (process.env.VITEST || process.env.VITEST_WORKER_ID || process.env.NODE_ENV === 'test') {
28
28
  return undefined;
29
29
  }
30
30
  process.exit(code);
@@ -87,7 +87,7 @@ export const test = async (options, args, filesOrCallback, callbackParam)=>{
87
87
  files = filesOrCallback;
88
88
  callback = callbackParam || defaultExit;
89
89
  }
90
- const { analyze = false, aiAnalyze = false, aiDebug = false, aiGenerate = false, bail, changedFilesWithAncestor, changedSince, ci, cliName = 'Lex', collectCoverageFrom, colors, config, debug = false, debugTests = false, detectOpenHandles, env, errorOnDeprecated, expand, forceExit, generate = false, json, lastCommit, listTests, logHeapUsage, maxWorkers, noStackTrace, notify, onlyChanged, outputFile, passWithNoTests, quiet, removeCache, runInBand, setup, showConfig, silent, testLocationInResults, testNamePattern, testPathPattern, update, useStderr, verbose, watch, watchAll } = options;
90
+ const { analyze = false, aiAnalyze = false, aiDebug = false, aiGenerate = false, bail, changedFilesWithAncestor, changedSince, ci, clearCache, cliName = 'Lex', collectCoverageFrom, colors, config, debug = false, debugTests = false, detectOpenHandles, environment, env, errorOnDeprecated, expand, forceExit, generate = false, json, lastCommit, listTests, logHeapUsage, maxWorkers, noStackTrace, notify, onlyChanged, outputFile, passWithNoTests, quiet, removeCache, runInBand, setup, showConfig, silent, testLocationInResults, testNamePattern, testPathPattern, update, useStderr, verbose, watch, watchAll } = options;
91
91
  const useGenerate = generate || aiGenerate;
92
92
  const useAnalyze = analyze || aiAnalyze;
93
93
  const useDebug = debugTests || aiDebug;
@@ -112,7 +112,7 @@ export const test = async (options, args, filesOrCallback, callbackParam)=>{
112
112
  await aiFunction({
113
113
  context: true,
114
114
  file: targetFile,
115
- prompt: `Generate Jest unit tests for this file: ${targetFile}\n\n${readFileSync(targetFile, 'utf-8')}\n\nPlease create comprehensive tests that cover the main functionality. Include test fixtures and mocks where necessary.`,
115
+ prompt: `Generate Vitest unit tests for this file: ${targetFile}\n\n${readFileSync(targetFile, 'utf-8')}\n\nPlease create comprehensive tests that cover the main functionality. Include test fixtures and mocks where necessary.`,
116
116
  quiet,
117
117
  task: 'test'
118
118
  });
@@ -128,80 +128,88 @@ export const test = async (options, args, filesOrCallback, callbackParam)=>{
128
128
  }
129
129
  }
130
130
  }
131
- const projectJestBin = pathResolve(process.cwd(), 'node_modules/.bin/jest');
132
- let jestPath;
133
- if (existsSync(projectJestBin)) {
134
- jestPath = projectJestBin;
131
+ const projectVitestBin = pathResolve(process.cwd(), 'node_modules/.bin/vitest');
132
+ let vitestPath;
133
+ if (existsSync(projectVitestBin)) {
134
+ vitestPath = projectVitestBin;
135
135
  } else {
136
- jestPath = resolveBinaryPath('jest');
136
+ vitestPath = resolveBinaryPath('vitest');
137
137
  }
138
- if (!jestPath) {
139
- log(`\n${cliName} Error: Jest binary not found in Lex's node_modules or monorepo root`, 'error', quiet);
138
+ if (!vitestPath) {
139
+ log(`\n${cliName} Error: Vitest binary not found in Lex's node_modules or monorepo root`, 'error', quiet);
140
140
  log('Please reinstall Lex or check your installation.', 'info', quiet);
141
141
  return 1;
142
142
  }
143
- let jestConfigFile;
144
- let projectJestConfig = null;
143
+ let vitestConfigFile;
144
+ let projectVitestConfig = null;
145
145
  if (config) {
146
- jestConfigFile = config;
146
+ vitestConfigFile = config;
147
147
  } else {
148
- const projectJestConfigPath = pathResolve(process.cwd(), 'jest.config.js');
149
- const projectJestConfigCjsPath = pathResolve(process.cwd(), 'jest.config.cjs');
150
- const projectJestConfigMjsPath = pathResolve(process.cwd(), 'jest.config.mjs');
151
- const projectJestConfigJsonPath = pathResolve(process.cwd(), 'jest.config.json');
152
- if (existsSync(projectJestConfigPath)) {
153
- jestConfigFile = projectJestConfigPath;
148
+ const projectVitestConfigPaths = [
149
+ pathResolve(process.cwd(), 'vitest.config.ts'),
150
+ pathResolve(process.cwd(), 'vitest.config.mts'),
151
+ pathResolve(process.cwd(), 'vitest.config.js'),
152
+ pathResolve(process.cwd(), 'vitest.config.mjs'),
153
+ pathResolve(process.cwd(), 'vitest.config.cjs')
154
+ ];
155
+ const existingConfigPath = projectVitestConfigPaths.find((configPath)=>existsSync(configPath));
156
+ if (existingConfigPath) {
157
+ vitestConfigFile = existingConfigPath;
154
158
  if (debug) {
155
- log(`Using project Jest config file: ${jestConfigFile}`, 'info', quiet);
156
- }
157
- } else if (existsSync(projectJestConfigCjsPath)) {
158
- jestConfigFile = projectJestConfigCjsPath;
159
- if (debug) {
160
- log(`Using project Jest config file (CJS): ${jestConfigFile}`, 'info', quiet);
161
- }
162
- } else if (existsSync(projectJestConfigMjsPath)) {
163
- jestConfigFile = projectJestConfigMjsPath;
164
- if (debug) {
165
- log(`Using project Jest config file (MJS): ${jestConfigFile}`, 'info', quiet);
166
- }
167
- } else if (existsSync(projectJestConfigJsonPath)) {
168
- jestConfigFile = projectJestConfigJsonPath;
169
- if (debug) {
170
- log(`Using project Jest config file (JSON): ${jestConfigFile}`, 'info', quiet);
159
+ log(`Using project Vitest config file: ${vitestConfigFile}`, 'info', quiet);
171
160
  }
172
161
  } else {
173
- // No Jest config file exists in the project
174
- // Check if there's a Jest config in lex.config.cjs
175
- projectJestConfig = LexConfig.config.jest;
162
+ // No Vitest config file exists in the project
163
+ // Check if there's a Vitest config in lex.config.cjs
164
+ projectVitestConfig = LexConfig.config.vitest;
176
165
  const lexDir = LexConfig.getLexDir();
177
- const lexJestConfig = pathResolve(lexDir, 'jest.config.mjs');
166
+ const lexVitestConfig = pathResolve(lexDir, 'vitest.config.mjs');
178
167
  if (debug) {
179
- log(`Looking for Jest config at: ${lexJestConfig}`, 'info', quiet);
180
- log(`File exists: ${existsSync(lexJestConfig)}`, 'info', quiet);
168
+ log(`Looking for Vitest config at: ${lexVitestConfig}`, 'info', quiet);
169
+ log(`File exists: ${existsSync(lexVitestConfig)}`, 'info', quiet);
181
170
  }
182
- if (existsSync(lexJestConfig)) {
183
- jestConfigFile = lexJestConfig;
184
- if (projectJestConfig && Object.keys(projectJestConfig).length > 0) {
185
- if (debug) {
186
- log(`Using Lex Jest config with project Jest config from lex.config.cjs: ${jestConfigFile}`, 'info', quiet);
187
- }
188
- } else {
171
+ if (existsSync(lexVitestConfig)) {
172
+ vitestConfigFile = lexVitestConfig;
173
+ if (projectVitestConfig && Object.keys(projectVitestConfig).length > 0) {
189
174
  if (debug) {
190
- log(`Using Lex Jest config (no project Jest config found): ${jestConfigFile}`, 'info', quiet);
175
+ log(`Using Lex Vitest config with project Vitest config from lex.config.cjs: ${vitestConfigFile}`, 'info', quiet);
191
176
  }
177
+ } else if (debug) {
178
+ log(`Using Lex Vitest config (no project Vitest config found): ${vitestConfigFile}`, 'info', quiet);
192
179
  }
193
180
  } else {
194
181
  if (debug) {
195
- log('No Jest config found in project or Lex', 'warn', quiet);
182
+ log('No Vitest config found in project or Lex', 'warn', quiet);
196
183
  }
197
- jestConfigFile = '';
198
184
  }
199
185
  }
200
186
  }
201
- const jestSetupFile = setup || pathResolve(process.cwd(), 'jest.setup.js');
202
- const jestOptions = [
203
- '--no-cache'
204
- ];
187
+ if (showConfig) {
188
+ if (vitestConfigFile) {
189
+ const resolvedConfig = await import(vitestConfigFile);
190
+ log(JSON.stringify(resolvedConfig.default ?? resolvedConfig, null, 2), 'info', quiet);
191
+ } else {
192
+ log(JSON.stringify({
193
+ test: projectVitestConfig ?? {}
194
+ }, null, 2), 'info', quiet);
195
+ }
196
+ callback(0);
197
+ return 0;
198
+ }
199
+ const vitestSetupFile = setup || pathResolve(process.cwd(), 'vitest.setup.js');
200
+ const vitestArgs = [];
201
+ const vitestOptions = [];
202
+ const reporters = new Set();
203
+ const filters = [];
204
+ const watchMode = Boolean(watch || watchAll);
205
+ const listMode = Boolean(listTests);
206
+ if (listMode) {
207
+ vitestArgs.push('list');
208
+ } else if (watchMode) {
209
+ vitestArgs.push('watch');
210
+ } else {
211
+ vitestArgs.push('run');
212
+ }
205
213
  const isESM = detectESM(process.cwd());
206
214
  let nodeOptions = process.env.NODE_OPTIONS || '';
207
215
  if (isESM) {
@@ -210,126 +218,122 @@ export const test = async (options, args, filesOrCallback, callbackParam)=>{
210
218
  }
211
219
  log('ESM project detected, using --experimental-vm-modules in NODE_OPTIONS', 'info', quiet);
212
220
  }
213
- if (jestConfigFile) {
214
- jestOptions.push('--config', jestConfigFile);
221
+ if (vitestConfigFile) {
222
+ vitestOptions.push('--config', vitestConfigFile);
215
223
  }
216
224
  if (bail) {
217
- jestOptions.push('--bail');
225
+ vitestOptions.push('--bail', '1');
218
226
  }
219
227
  if (changedFilesWithAncestor) {
220
- jestOptions.push('--changedFilesWithAncestor');
228
+ vitestOptions.push('--changed');
221
229
  }
222
230
  if (changedSince) {
223
- jestOptions.push('--changedSince');
231
+ vitestOptions.push('--changed', changedSince);
224
232
  }
225
233
  if (ci) {
226
- jestOptions.push('--ci');
234
+ vitestOptions.push('--run');
227
235
  }
228
236
  if (collectCoverageFrom) {
229
- jestOptions.push('--collectCoverageFrom', collectCoverageFrom);
230
- }
231
- if (colors) {
232
- jestOptions.push('--colors');
237
+ vitestOptions.push('--coverage', '--coverage.include', collectCoverageFrom);
233
238
  }
234
239
  if (debug) {
235
- jestOptions.push('--debug');
240
+ vitestOptions.push('--inspect');
236
241
  }
237
242
  if (detectOpenHandles) {
238
- jestOptions.push('--detectOpenHandles');
243
+ reporters.add('hanging-process');
239
244
  }
240
- if (env) {
241
- jestOptions.push('--env');
245
+ const environmentName = environment || env;
246
+ if (environmentName) {
247
+ vitestOptions.push('--environment', environmentName);
242
248
  }
243
249
  if (errorOnDeprecated) {
244
- jestOptions.push('--errorOnDeprecated');
250
+ log('Vitest does not support --errorOnDeprecated; option ignored.', 'warn', quiet);
245
251
  }
246
252
  if (expand) {
247
- jestOptions.push('--expand');
253
+ vitestOptions.push('--expandSnapshotDiff');
248
254
  }
249
255
  if (forceExit) {
250
- jestOptions.push('--forceExit');
251
- }
252
- if (json) {
253
- jestOptions.push('--json');
256
+ log('Vitest does not support --forceExit; option ignored.', 'warn', quiet);
254
257
  }
255
258
  if (lastCommit) {
256
- jestOptions.push('--lastCommit');
257
- }
258
- if (listTests) {
259
- jestOptions.push('--listTests');
259
+ vitestOptions.push('--changed');
260
260
  }
261
261
  if (logHeapUsage) {
262
- jestOptions.push('--logHeapUsage');
262
+ vitestOptions.push('--logHeapUsage');
263
263
  }
264
264
  if (maxWorkers) {
265
- jestOptions.push('--maxWorkers', maxWorkers);
265
+ vitestOptions.push('--maxWorkers', maxWorkers);
266
266
  }
267
267
  if (noStackTrace) {
268
- jestOptions.push('--noStackTrace');
268
+ log('Vitest does not support --noStackTrace; option ignored.', 'warn', quiet);
269
269
  }
270
270
  if (notify) {
271
- jestOptions.push('--notify');
271
+ log('Vitest does not support --notify; option ignored.', 'warn', quiet);
272
272
  }
273
273
  if (onlyChanged) {
274
- jestOptions.push('--onlyChanged');
274
+ vitestOptions.push('--changed');
275
275
  }
276
276
  let tempOutputFile = outputFile;
277
- if ((useAnalyze || useDebug) && !outputFile) {
278
- tempOutputFile = '.lex-test-results.json';
279
- jestOptions.push('--json', '--outputFile', tempOutputFile);
280
- } else if (outputFile) {
281
- jestOptions.push('--outputFile', outputFile);
277
+ const shouldWriteJson = json || useAnalyze || useDebug || Boolean(outputFile);
278
+ if (shouldWriteJson) {
279
+ tempOutputFile = outputFile || '.lex-test-results.json';
280
+ vitestOptions.push('--outputFile', tempOutputFile);
281
+ reporters.add('json');
282
282
  }
283
283
  if (passWithNoTests) {
284
- jestOptions.push('--passWithNoTests');
284
+ vitestOptions.push('--passWithNoTests');
285
285
  }
286
286
  if (runInBand) {
287
- jestOptions.push('--runInBand');
288
- }
289
- if (showConfig) {
290
- jestOptions.push('--showConfig');
287
+ vitestOptions.push('--no-file-parallelism', '--maxWorkers', '1');
291
288
  }
292
289
  if (silent) {
293
- jestOptions.push('--silent');
290
+ vitestOptions.push('--silent');
294
291
  }
295
292
  if (testLocationInResults) {
296
- jestOptions.push('--testLocationInResults');
293
+ vitestOptions.push('--includeTaskLocation');
297
294
  }
298
295
  if (testNamePattern) {
299
- jestOptions.push('--testNamePattern', testNamePattern);
296
+ vitestOptions.push('--testNamePattern', testNamePattern);
300
297
  }
301
298
  if (testPathPattern) {
302
- jestOptions.push('--testPathPattern', testPathPattern);
299
+ filters.push(testPathPattern);
303
300
  }
304
301
  if (useStderr) {
305
- jestOptions.push('--useStderr');
302
+ log('Vitest does not support --useStderr; option ignored.', 'warn', quiet);
306
303
  }
307
304
  if (verbose) {
308
- jestOptions.push('--verbose');
309
- }
310
- if (watchAll) {
311
- jestOptions.push('--watchAll');
305
+ reporters.add('verbose');
312
306
  }
313
- if (removeCache) {
314
- jestOptions.push('--no-cache');
315
- }
316
- if (jestSetupFile && existsSync(jestSetupFile)) {
317
- jestOptions.push(`--setupFilesAfterEnv=${jestSetupFile}`);
307
+ if (removeCache || clearCache) {
308
+ vitestOptions.push('--clearCache');
318
309
  }
319
310
  if (update) {
320
- jestOptions.push('--updateSnapshot');
311
+ vitestOptions.push('--update');
321
312
  }
322
313
  if (watch) {
323
- jestOptions.push('--watch', watch);
314
+ filters.push(watch);
324
315
  }
325
316
  if (args) {
326
- jestOptions.push(...args);
317
+ vitestOptions.push(...args);
327
318
  }
328
319
  if (files && files.length > 0) {
329
- jestOptions.push(...files);
320
+ filters.push(...files);
321
+ }
322
+ if (reporters.size > 0) {
323
+ const reporterList = Array.from(reporters);
324
+ if (reporterList.includes('json') && !reporterList.includes('verbose')) {
325
+ // Keep console output while writing JSON results.
326
+ reporterList.unshift('default');
327
+ }
328
+ reporterList.forEach((reporter)=>vitestOptions.push('--reporter', reporter));
330
329
  }
330
+ const finalArgs = [
331
+ ...vitestArgs,
332
+ ...vitestOptions,
333
+ ...filters
334
+ ];
331
335
  if (debug) {
332
- log(`Jest options: ${jestOptions.join(' ')}`, 'info', quiet);
336
+ log(`Vitest options: ${finalArgs.join(' ')}`, 'info', quiet);
333
337
  log(`NODE_OPTIONS: ${nodeOptions}`, 'info', quiet);
334
338
  }
335
339
  try {
@@ -337,7 +341,16 @@ export const test = async (options, args, filesOrCallback, callbackParam)=>{
337
341
  ...process.env,
338
342
  NODE_OPTIONS: nodeOptions
339
343
  };
340
- await execa(jestPath, jestOptions, {
344
+ if (colors) {
345
+ env.FORCE_COLOR = '1';
346
+ }
347
+ if (ci) {
348
+ env.CI = 'true';
349
+ }
350
+ if (vitestSetupFile && existsSync(vitestSetupFile)) {
351
+ env.LEX_VITEST_SETUP = vitestSetupFile;
352
+ }
353
+ await execa(vitestPath, finalArgs, {
341
354
  encoding: 'utf8',
342
355
  env,
343
356
  stdio: 'inherit'
@@ -350,7 +363,7 @@ export const test = async (options, args, filesOrCallback, callbackParam)=>{
350
363
  const filePatterns = getTestFilePatterns(testPathPattern);
351
364
  await aiFunction({
352
365
  context: true,
353
- prompt: `Analyze these Jest test results and suggest test coverage improvements:
366
+ prompt: `Analyze these Vitest test results and suggest test coverage improvements:
354
367
 
355
368
  ${JSON.stringify(testResults, null, 2)}
356
369
 
@@ -384,7 +397,7 @@ Please provide:
384
397
  const testResults = processTestResults(tempOutputFile);
385
398
  await aiFunction({
386
399
  context: true,
387
- prompt: `Debug these failed Jest tests and suggest fixes:
400
+ prompt: `Debug these failed Vitest tests and suggest fixes:
388
401
 
389
402
  ${JSON.stringify(error.message, null, 2)}
390
403
 
@@ -413,4 +426,4 @@ Please provide:
413
426
  };
414
427
  export default test;
415
428
 
416
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/test/test.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\n\nimport {LexConfig, getTypeScriptConfigPath} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {aiFunction} from '../ai/ai.js';\n\nconst detectESM = (cwd: string): boolean => {\n  const packageJsonPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(packageJsonPath)) {\n    try {\n      const packageJsonContent = readFileSync(packageJsonPath, 'utf8');\n      const packageJson = JSON.parse(packageJsonContent);\n      return packageJson.type === 'module';\n    } catch(_error) {\n      return false;\n    }\n  }\n\n  return false;\n};\n\nexport interface TestOptions {\n  readonly analyze?: boolean;\n  readonly aiDebug?: boolean;\n  readonly aiGenerate?: boolean;\n  readonly aiAnalyze?: boolean;\n  readonly bail?: boolean;\n  readonly changedFilesWithAncestor?: boolean;\n  readonly changedSince?: string;\n  readonly ci?: boolean;\n  readonly cliName?: string;\n  readonly collectCoverageFrom?: string;\n  readonly colors?: boolean;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly debugTests?: boolean;\n  readonly detectOpenHandles?: boolean;\n  readonly env?: string;\n  readonly errorOnDeprecated?: boolean;\n  readonly expand?: boolean;\n  readonly forceExit?: boolean;\n  readonly generate?: boolean;\n  readonly json?: boolean;\n  readonly lastCommit?: boolean;\n  readonly listTests?: boolean;\n  readonly logHeapUsage?: boolean;\n  readonly maxWorkers?: string;\n  readonly noStackTrace?: boolean;\n  readonly notify?: boolean;\n  readonly onlyChanged?: boolean;\n  readonly outputFile?: string;\n  readonly passWithNoTests?: boolean;\n  readonly quiet?: boolean;\n  readonly removeCache?: boolean;\n  readonly runInBand?: boolean;\n  readonly setup?: string;\n  readonly showConfig?: boolean;\n  readonly silent?: boolean;\n  readonly testLocationInResults?: boolean;\n  readonly testNamePattern?: string;\n  readonly testPathPattern?: string;\n  readonly update?: boolean;\n  readonly useStderr?: boolean;\n  readonly verbose?: boolean;\n  readonly watch?: string;\n  readonly watchAll?: boolean;\n}\n\nexport type TestCallback = typeof process.exit;\n\nconst defaultExit = ((code?: number) => {\n  if(process.env.JEST_WORKER_ID || process.env.NODE_ENV === 'test') {\n    return undefined as never;\n  }\n\n  process.exit(code);\n}) as typeof process.exit;\n\nexport const getTestFilePatterns = (testPathPattern?: string): string[] => {\n  const defaultPatterns = ['**/*.test.*', '**/*.spec.*', '**/*.integration.*'];\n\n  if(!testPathPattern) {\n    return defaultPatterns;\n  }\n\n  return [testPathPattern];\n};\n\nconst findUncoveredSourceFiles = (): string[] => {\n  const sourceFiles = globSync('src/**/*.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**', '**/*.test.*', '**/*.spec.*']\n  });\n\n  const testFiles = globSync('**/*.{test,spec}.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**']\n  });\n\n  return sourceFiles.filter((sourceFile) => {\n    const baseName = sourceFile.replace(/\\.[^/.]+$/, '');\n    return !testFiles.some((testFile) => testFile.includes(baseName));\n  });\n};\n\nconst processTestResults = (outputFile?: string): any => {\n  if(!outputFile) {\n    return null;\n  }\n\n  try {\n    const content = readFileSync(outputFile, 'utf-8');\n    return JSON.parse(content);\n  } catch(_error) {\n    return null;\n  }\n};\n\nexport const test = async (\n  options: TestOptions,\n  args?: string[],\n  filesOrCallback?: string[] | TestCallback,\n  callbackParam?: TestCallback\n): Promise<number> => {\n  // Backward-compat argument normalization: allow callback as third param\n  let files: string[] | undefined;\n  let callback: TestCallback = defaultExit;\n\n  if(typeof filesOrCallback === 'function') {\n    callback = filesOrCallback as TestCallback;\n  } else {\n    files = filesOrCallback as string[] | undefined;\n    callback = callbackParam || defaultExit;\n  }\n  const {\n    analyze = false,\n    aiAnalyze = false,\n    aiDebug = false,\n    aiGenerate = false,\n    bail,\n    changedFilesWithAncestor,\n    changedSince,\n    ci,\n    cliName = 'Lex',\n    collectCoverageFrom,\n    colors,\n    config,\n    debug = false,\n    debugTests = false,\n    detectOpenHandles,\n    env,\n    errorOnDeprecated,\n    expand,\n    forceExit,\n    generate = false,\n    json,\n    lastCommit,\n    listTests,\n    logHeapUsage,\n    maxWorkers,\n    noStackTrace,\n    notify,\n    onlyChanged,\n    outputFile,\n    passWithNoTests,\n    quiet,\n    removeCache,\n    runInBand,\n    setup,\n    showConfig,\n    silent,\n    testLocationInResults,\n    testNamePattern,\n    testPathPattern,\n    update,\n    useStderr,\n    verbose,\n    watch,\n    watchAll\n  } = options;\n\n  const useGenerate = generate || aiGenerate;\n  const useAnalyze = analyze || aiAnalyze;\n  const useDebug = debugTests || aiDebug;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  const spinner = createSpinner(quiet);\n\n  await LexConfig.parseConfig(options);\n\n  const {useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    const testConfigPath = getTypeScriptConfigPath('tsconfig.test.json');\n    if(existsSync(testConfigPath)) {\n      log('Using tsconfig.test.json for testing...', 'info', quiet);\n    } else {\n      LexConfig.checkTestTypescriptConfig();\n    }\n  }\n\n  if(useGenerate) {\n    spinner.start('AI is analyzing code to generate test cases...');\n\n    try {\n      const uncoveredFiles = findUncoveredSourceFiles();\n\n      if(uncoveredFiles.length > 0) {\n        const targetFile = uncoveredFiles[0];\n\n        await aiFunction({\n          context: true,\n          file: targetFile,\n          prompt: `Generate Jest unit tests for this file: ${targetFile}\\n\\n${readFileSync(targetFile, 'utf-8')}\\n\\nPlease create comprehensive tests that cover the main functionality. Include test fixtures and mocks where necessary.`,\n          quiet,\n          task: 'test'\n        });\n\n        spinner.succeed(`AI test generation suggestions provided for ${targetFile}`);\n      } else {\n        spinner.succeed('All source files appear to have corresponding test files');\n      }\n    } catch(aiError) {\n      spinner.fail('Could not generate AI test suggestions');\n      if(!quiet) {\n        // eslint-disable-next-line no-console\n        console.error('AI test generation error:', aiError);\n      }\n    }\n  }\n\n  const projectJestBin = pathResolve(process.cwd(), 'node_modules/.bin/jest');\n  let jestPath: string;\n\n  if(existsSync(projectJestBin)) {\n    jestPath = projectJestBin;\n  } else {\n    jestPath = resolveBinaryPath('jest');\n  }\n\n  if(!jestPath) {\n    log(`\\n${cliName} Error: Jest binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your installation.', 'info', quiet);\n    return 1;\n  }\n\n  let jestConfigFile: string;\n  let projectJestConfig: any = null;\n\n  if(config) {\n    jestConfigFile = config;\n  } else {\n    const projectJestConfigPath = pathResolve(process.cwd(), 'jest.config.js');\n    const projectJestConfigCjsPath = pathResolve(process.cwd(), 'jest.config.cjs');\n    const projectJestConfigMjsPath = pathResolve(process.cwd(), 'jest.config.mjs');\n    const projectJestConfigJsonPath = pathResolve(process.cwd(), 'jest.config.json');\n\n    if(existsSync(projectJestConfigPath)) {\n      jestConfigFile = projectJestConfigPath;\n      if(debug) {\n        log(`Using project Jest config file: ${jestConfigFile}`, 'info', quiet);\n      }\n    } else if(existsSync(projectJestConfigCjsPath)) {\n      jestConfigFile = projectJestConfigCjsPath;\n      if(debug) {\n        log(`Using project Jest config file (CJS): ${jestConfigFile}`, 'info', quiet);\n      }\n    } else if(existsSync(projectJestConfigMjsPath)) {\n      jestConfigFile = projectJestConfigMjsPath;\n      if(debug) {\n        log(`Using project Jest config file (MJS): ${jestConfigFile}`, 'info', quiet);\n      }\n    } else if(existsSync(projectJestConfigJsonPath)) {\n      jestConfigFile = projectJestConfigJsonPath;\n      if(debug) {\n        log(`Using project Jest config file (JSON): ${jestConfigFile}`, 'info', quiet);\n      }\n    } else {\n      // No Jest config file exists in the project\n      // Check if there's a Jest config in lex.config.cjs\n      projectJestConfig = LexConfig.config.jest;\n\n      const lexDir = LexConfig.getLexDir();\n      const lexJestConfig = pathResolve(lexDir, 'jest.config.mjs');\n\n      if(debug) {\n        log(`Looking for Jest config at: ${lexJestConfig}`, 'info', quiet);\n        log(`File exists: ${existsSync(lexJestConfig)}`, 'info', quiet);\n      }\n\n      if(existsSync(lexJestConfig)) {\n        jestConfigFile = lexJestConfig;\n        if(projectJestConfig && Object.keys(projectJestConfig).length > 0) {\n          if(debug) {\n            log(`Using Lex Jest config with project Jest config from lex.config.cjs: ${jestConfigFile}`, 'info', quiet);\n          }\n        } else {\n          if(debug) {\n            log(`Using Lex Jest config (no project Jest config found): ${jestConfigFile}`, 'info', quiet);\n          }\n        }\n      } else {\n        if(debug) {\n          log('No Jest config found in project or Lex', 'warn', quiet);\n        }\n        jestConfigFile = '';\n      }\n    }\n  }\n\n  const jestSetupFile: string = setup || pathResolve(process.cwd(), 'jest.setup.js');\n  const jestOptions: string[] = ['--no-cache'];\n\n  const isESM = detectESM(process.cwd());\n  let nodeOptions = process.env.NODE_OPTIONS || '';\n  if(isESM) {\n    if(!nodeOptions.includes('--experimental-vm-modules')) {\n      nodeOptions = `${nodeOptions} --experimental-vm-modules`.trim();\n    }\n    log('ESM project detected, using --experimental-vm-modules in NODE_OPTIONS', 'info', quiet);\n  }\n\n  if(jestConfigFile) {\n    jestOptions.push('--config', jestConfigFile);\n  }\n\n  if(bail) {\n    jestOptions.push('--bail');\n  }\n\n  if(changedFilesWithAncestor) {\n    jestOptions.push('--changedFilesWithAncestor');\n  }\n\n  if(changedSince) {\n    jestOptions.push('--changedSince');\n  }\n\n  if(ci) {\n    jestOptions.push('--ci');\n  }\n\n  if(collectCoverageFrom) {\n    jestOptions.push('--collectCoverageFrom', collectCoverageFrom);\n  }\n\n  if(colors) {\n    jestOptions.push('--colors');\n  }\n\n  if(debug) {\n    jestOptions.push('--debug');\n  }\n\n  if(detectOpenHandles) {\n    jestOptions.push('--detectOpenHandles');\n  }\n\n  if(env) {\n    jestOptions.push('--env');\n  }\n\n  if(errorOnDeprecated) {\n    jestOptions.push('--errorOnDeprecated');\n  }\n\n  if(expand) {\n    jestOptions.push('--expand');\n  }\n\n  if(forceExit) {\n    jestOptions.push('--forceExit');\n  }\n\n  if(json) {\n    jestOptions.push('--json');\n  }\n\n  if(lastCommit) {\n    jestOptions.push('--lastCommit');\n  }\n\n  if(listTests) {\n    jestOptions.push('--listTests');\n  }\n\n  if(logHeapUsage) {\n    jestOptions.push('--logHeapUsage');\n  }\n\n  if(maxWorkers) {\n    jestOptions.push('--maxWorkers', maxWorkers);\n  }\n\n  if(noStackTrace) {\n    jestOptions.push('--noStackTrace');\n  }\n\n  if(notify) {\n    jestOptions.push('--notify');\n  }\n\n  if(onlyChanged) {\n    jestOptions.push('--onlyChanged');\n  }\n\n  let tempOutputFile = outputFile;\n\n  if((useAnalyze || useDebug) && !outputFile) {\n    tempOutputFile = '.lex-test-results.json';\n    jestOptions.push('--json', '--outputFile', tempOutputFile);\n  } else if(outputFile) {\n    jestOptions.push('--outputFile', outputFile);\n  }\n\n  if(passWithNoTests) {\n    jestOptions.push('--passWithNoTests');\n  }\n\n  if(runInBand) {\n    jestOptions.push('--runInBand');\n  }\n\n  if(showConfig) {\n    jestOptions.push('--showConfig');\n  }\n\n  if(silent) {\n    jestOptions.push('--silent');\n  }\n\n  if(testLocationInResults) {\n    jestOptions.push('--testLocationInResults');\n  }\n\n  if(testNamePattern) {\n    jestOptions.push('--testNamePattern', testNamePattern);\n  }\n\n  if(testPathPattern) {\n    jestOptions.push('--testPathPattern', testPathPattern);\n  }\n\n  if(useStderr) {\n    jestOptions.push('--useStderr');\n  }\n\n  if(verbose) {\n    jestOptions.push('--verbose');\n  }\n\n  if(watchAll) {\n    jestOptions.push('--watchAll');\n  }\n\n  if(removeCache) {\n    jestOptions.push('--no-cache');\n  }\n\n  if(jestSetupFile && existsSync(jestSetupFile)) {\n    jestOptions.push(`--setupFilesAfterEnv=${jestSetupFile}`);\n  }\n\n  if(update) {\n    jestOptions.push('--updateSnapshot');\n  }\n\n  if(watch) {\n    jestOptions.push('--watch', watch);\n  }\n\n  if(args) {\n    jestOptions.push(...args);\n  }\n\n  if(files && files.length > 0) {\n    jestOptions.push(...files);\n  }\n\n  if(debug) {\n    log(`Jest options: ${jestOptions.join(' ')}`, 'info', quiet);\n    log(`NODE_OPTIONS: ${nodeOptions}`, 'info', quiet);\n  }\n\n  try {\n    const env: Record<string, string> = {\n      ...process.env,\n      NODE_OPTIONS: nodeOptions\n    };\n\n    await execa(jestPath, jestOptions, {\n      encoding: 'utf8',\n      env,\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Testing completed!');\n\n    if(useAnalyze) {\n      spinner.start('AI is analyzing test coverage and suggesting improvements...');\n\n      try {\n        const testResults = processTestResults(tempOutputFile);\n        const filePatterns = getTestFilePatterns(testPathPattern);\n\n        await aiFunction({\n          context: true,\n          prompt: `Analyze these Jest test results and suggest test coverage improvements:\n\n${JSON.stringify(testResults, null, 2)}\n\nTest patterns: ${filePatterns.join(', ')}\n\nPlease provide:\n1. Analysis of current coverage gaps\n2. Suggestions for improving test cases\n3. Recommendations for additional integration test scenarios\n4. Best practices for increasing test effectiveness`,\n          quiet,\n          task: 'optimize'\n        });\n\n        spinner.succeed('AI test analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI test analysis');\n        if(!quiet) {\n          // eslint-disable-next-line no-console\n          console.error('AI analysis error:', aiError);\n        }\n      }\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    spinner.fail('Testing failed!');\n\n    if(useDebug) {\n      spinner.start('AI is analyzing test failures...');\n\n      try {\n        const testResults = processTestResults(tempOutputFile);\n\n        await aiFunction({\n          context: true,\n          prompt: `Debug these failed Jest tests and suggest fixes:\n\n${JSON.stringify(error.message, null, 2)}\n\nTest results: ${JSON.stringify(testResults, null, 2)}\n\nPlease provide:\n1. Analysis of why the tests are failing\n2. Specific suggestions to fix each failing test\n3. Any potential issues with test fixtures or mocks\n4. Code examples for solutions`,\n          quiet,\n          task: 'help'\n        });\n\n        spinner.succeed('AI debugging assistance complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI debugging assistance');\n        if(!quiet) {\n          // eslint-disable-next-line no-console\n          console.error('AI debugging error:', aiError);\n        }\n      }\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport default test;"],"names":["execa","existsSync","readFileSync","sync","globSync","resolve","pathResolve","LexConfig","getTypeScriptConfigPath","createSpinner","resolveBinaryPath","log","aiFunction","detectESM","cwd","packageJsonPath","packageJsonContent","packageJson","JSON","parse","type","_error","defaultExit","code","process","env","JEST_WORKER_ID","NODE_ENV","undefined","exit","getTestFilePatterns","testPathPattern","defaultPatterns","findUncoveredSourceFiles","sourceFiles","ignore","testFiles","filter","sourceFile","baseName","replace","some","testFile","includes","processTestResults","outputFile","content","test","options","args","filesOrCallback","callbackParam","files","callback","analyze","aiAnalyze","aiDebug","aiGenerate","bail","changedFilesWithAncestor","changedSince","ci","cliName","collectCoverageFrom","colors","config","debug","debugTests","detectOpenHandles","errorOnDeprecated","expand","forceExit","generate","json","lastCommit","listTests","logHeapUsage","maxWorkers","noStackTrace","notify","onlyChanged","passWithNoTests","quiet","removeCache","runInBand","setup","showConfig","silent","testLocationInResults","testNamePattern","update","useStderr","verbose","watch","watchAll","useGenerate","useAnalyze","useDebug","spinner","parseConfig","useTypescript","testConfigPath","checkTestTypescriptConfig","start","uncoveredFiles","length","targetFile","context","file","prompt","task","succeed","aiError","fail","console","error","projectJestBin","jestPath","jestConfigFile","projectJestConfig","projectJestConfigPath","projectJestConfigCjsPath","projectJestConfigMjsPath","projectJestConfigJsonPath","jest","lexDir","getLexDir","lexJestConfig","Object","keys","jestSetupFile","jestOptions","isESM","nodeOptions","NODE_OPTIONS","trim","push","tempOutputFile","join","encoding","stdio","testResults","filePatterns","stringify","message"],"mappings":"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"}
429
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/test/test.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\n\nimport {LexConfig, getTypeScriptConfigPath} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {aiFunction} from '../ai/ai.js';\n\nconst detectESM = (cwd: string): boolean => {\n  const packageJsonPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(packageJsonPath)) {\n    try {\n      const packageJsonContent = readFileSync(packageJsonPath, 'utf8');\n      const packageJson = JSON.parse(packageJsonContent);\n      return packageJson.type === 'module';\n    } catch(_error) {\n      return false;\n    }\n  }\n\n  return false;\n};\n\nexport interface TestOptions {\n  readonly analyze?: boolean;\n  readonly aiDebug?: boolean;\n  readonly aiGenerate?: boolean;\n  readonly aiAnalyze?: boolean;\n  readonly bail?: boolean;\n  readonly changedFilesWithAncestor?: boolean;\n  readonly changedSince?: string;\n  readonly ci?: boolean;\n  readonly clearCache?: boolean;\n  readonly cliName?: string;\n  readonly collectCoverageFrom?: string;\n  readonly colors?: boolean;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly debugTests?: boolean;\n  readonly detectOpenHandles?: boolean;\n  readonly environment?: string;\n  readonly env?: string;\n  readonly errorOnDeprecated?: boolean;\n  readonly expand?: boolean;\n  readonly forceExit?: boolean;\n  readonly generate?: boolean;\n  readonly json?: boolean;\n  readonly lastCommit?: boolean;\n  readonly listTests?: boolean;\n  readonly logHeapUsage?: boolean;\n  readonly maxWorkers?: string;\n  readonly noStackTrace?: boolean;\n  readonly notify?: boolean;\n  readonly onlyChanged?: boolean;\n  readonly outputFile?: string;\n  readonly passWithNoTests?: boolean;\n  readonly quiet?: boolean;\n  readonly removeCache?: boolean;\n  readonly runInBand?: boolean;\n  readonly setup?: string;\n  readonly showConfig?: boolean;\n  readonly silent?: boolean;\n  readonly testLocationInResults?: boolean;\n  readonly testNamePattern?: string;\n  readonly testPathPattern?: string;\n  readonly update?: boolean;\n  readonly useStderr?: boolean;\n  readonly verbose?: boolean;\n  readonly watch?: string;\n  readonly watchAll?: boolean;\n}\n\nexport type TestCallback = typeof process.exit;\n\nconst defaultExit = ((code?: number) => {\n  if(process.env.VITEST || process.env.VITEST_WORKER_ID || process.env.NODE_ENV === 'test') {\n    return undefined as never;\n  }\n\n  process.exit(code);\n}) as typeof process.exit;\n\nexport const getTestFilePatterns = (testPathPattern?: string): string[] => {\n  const defaultPatterns = ['**/*.test.*', '**/*.spec.*', '**/*.integration.*'];\n\n  if(!testPathPattern) {\n    return defaultPatterns;\n  }\n\n  return [testPathPattern];\n};\n\nconst findUncoveredSourceFiles = (): string[] => {\n  const sourceFiles = globSync('src/**/*.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**', '**/*.test.*', '**/*.spec.*']\n  });\n\n  const testFiles = globSync('**/*.{test,spec}.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**']\n  });\n\n  return sourceFiles.filter((sourceFile) => {\n    const baseName = sourceFile.replace(/\\.[^/.]+$/, '');\n    return !testFiles.some((testFile) => testFile.includes(baseName));\n  });\n};\n\nconst processTestResults = (outputFile?: string): any => {\n  if(!outputFile) {\n    return null;\n  }\n\n  try {\n    const content = readFileSync(outputFile, 'utf-8');\n    return JSON.parse(content);\n  } catch(_error) {\n    return null;\n  }\n};\n\nexport const test = async (\n  options: TestOptions,\n  args?: string[],\n  filesOrCallback?: string[] | TestCallback,\n  callbackParam?: TestCallback\n): Promise<number> => {\n  // Backward-compat argument normalization: allow callback as third param\n  let files: string[] | undefined;\n  let callback: TestCallback = defaultExit;\n\n  if(typeof filesOrCallback === 'function') {\n    callback = filesOrCallback as TestCallback;\n  } else {\n    files = filesOrCallback as string[] | undefined;\n    callback = callbackParam || defaultExit;\n  }\n  const {\n    analyze = false,\n    aiAnalyze = false,\n    aiDebug = false,\n    aiGenerate = false,\n    bail,\n    changedFilesWithAncestor,\n    changedSince,\n    ci,\n    clearCache,\n    cliName = 'Lex',\n    collectCoverageFrom,\n    colors,\n    config,\n    debug = false,\n    debugTests = false,\n    detectOpenHandles,\n    environment,\n    env,\n    errorOnDeprecated,\n    expand,\n    forceExit,\n    generate = false,\n    json,\n    lastCommit,\n    listTests,\n    logHeapUsage,\n    maxWorkers,\n    noStackTrace,\n    notify,\n    onlyChanged,\n    outputFile,\n    passWithNoTests,\n    quiet,\n    removeCache,\n    runInBand,\n    setup,\n    showConfig,\n    silent,\n    testLocationInResults,\n    testNamePattern,\n    testPathPattern,\n    update,\n    useStderr,\n    verbose,\n    watch,\n    watchAll\n  } = options;\n\n  const useGenerate = generate || aiGenerate;\n  const useAnalyze = analyze || aiAnalyze;\n  const useDebug = debugTests || aiDebug;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  const spinner = createSpinner(quiet);\n\n  await LexConfig.parseConfig(options);\n\n  const {useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    const testConfigPath = getTypeScriptConfigPath('tsconfig.test.json');\n    if(existsSync(testConfigPath)) {\n      log('Using tsconfig.test.json for testing...', 'info', quiet);\n    } else {\n      LexConfig.checkTestTypescriptConfig();\n    }\n  }\n\n  if(useGenerate) {\n    spinner.start('AI is analyzing code to generate test cases...');\n\n    try {\n      const uncoveredFiles = findUncoveredSourceFiles();\n\n      if(uncoveredFiles.length > 0) {\n        const targetFile = uncoveredFiles[0];\n\n        await aiFunction({\n          context: true,\n          file: targetFile,\n          prompt: `Generate Vitest unit tests for this file: ${targetFile}\\n\\n${readFileSync(targetFile, 'utf-8')}\\n\\nPlease create comprehensive tests that cover the main functionality. Include test fixtures and mocks where necessary.`,\n          quiet,\n          task: 'test'\n        });\n\n        spinner.succeed(`AI test generation suggestions provided for ${targetFile}`);\n      } else {\n        spinner.succeed('All source files appear to have corresponding test files');\n      }\n    } catch(aiError) {\n      spinner.fail('Could not generate AI test suggestions');\n      if(!quiet) {\n        // eslint-disable-next-line no-console\n        console.error('AI test generation error:', aiError);\n      }\n    }\n  }\n\n  const projectVitestBin = pathResolve(process.cwd(), 'node_modules/.bin/vitest');\n  let vitestPath: string;\n\n  if(existsSync(projectVitestBin)) {\n    vitestPath = projectVitestBin;\n  } else {\n    vitestPath = resolveBinaryPath('vitest');\n  }\n\n  if(!vitestPath) {\n    log(`\\n${cliName} Error: Vitest binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your installation.', 'info', quiet);\n    return 1;\n  }\n\n  let vitestConfigFile: string | undefined;\n  let projectVitestConfig: Record<string, unknown> | null = null;\n\n  if(config) {\n    vitestConfigFile = config;\n  } else {\n    const projectVitestConfigPaths = [\n      pathResolve(process.cwd(), 'vitest.config.ts'),\n      pathResolve(process.cwd(), 'vitest.config.mts'),\n      pathResolve(process.cwd(), 'vitest.config.js'),\n      pathResolve(process.cwd(), 'vitest.config.mjs'),\n      pathResolve(process.cwd(), 'vitest.config.cjs')\n    ];\n    const existingConfigPath = projectVitestConfigPaths.find((configPath) => existsSync(configPath));\n\n    if(existingConfigPath) {\n      vitestConfigFile = existingConfigPath;\n      if(debug) {\n        log(`Using project Vitest config file: ${vitestConfigFile}`, 'info', quiet);\n      }\n    } else {\n      // No Vitest config file exists in the project\n      // Check if there's a Vitest config in lex.config.cjs\n      projectVitestConfig = LexConfig.config.vitest;\n\n      const lexDir = LexConfig.getLexDir();\n      const lexVitestConfig = pathResolve(lexDir, 'vitest.config.mjs');\n\n      if(debug) {\n        log(`Looking for Vitest config at: ${lexVitestConfig}`, 'info', quiet);\n        log(`File exists: ${existsSync(lexVitestConfig)}`, 'info', quiet);\n      }\n\n      if(existsSync(lexVitestConfig)) {\n        vitestConfigFile = lexVitestConfig;\n        if(projectVitestConfig && Object.keys(projectVitestConfig).length > 0) {\n          if(debug) {\n            log(`Using Lex Vitest config with project Vitest config from lex.config.cjs: ${vitestConfigFile}`, 'info', quiet);\n          }\n        } else if(debug) {\n          log(`Using Lex Vitest config (no project Vitest config found): ${vitestConfigFile}`, 'info', quiet);\n        }\n      } else {\n        if(debug) {\n          log('No Vitest config found in project or Lex', 'warn', quiet);\n        }\n      }\n    }\n  }\n\n  if(showConfig) {\n    if(vitestConfigFile) {\n      const resolvedConfig = await import(vitestConfigFile);\n      log(JSON.stringify(resolvedConfig.default ?? resolvedConfig, null, 2), 'info', quiet);\n    } else {\n      log(JSON.stringify({test: projectVitestConfig ?? {}}, null, 2), 'info', quiet);\n    }\n    callback(0);\n    return 0;\n  }\n\n  const vitestSetupFile: string = setup || pathResolve(process.cwd(), 'vitest.setup.js');\n  const vitestArgs: string[] = [];\n  const vitestOptions: string[] = [];\n  const reporters = new Set<string>();\n  const filters: string[] = [];\n  const watchMode = Boolean(watch || watchAll);\n  const listMode = Boolean(listTests);\n\n  if(listMode) {\n    vitestArgs.push('list');\n  } else if(watchMode) {\n    vitestArgs.push('watch');\n  } else {\n    vitestArgs.push('run');\n  }\n\n  const isESM = detectESM(process.cwd());\n  let nodeOptions = process.env.NODE_OPTIONS || '';\n  if(isESM) {\n    if(!nodeOptions.includes('--experimental-vm-modules')) {\n      nodeOptions = `${nodeOptions} --experimental-vm-modules`.trim();\n    }\n    log('ESM project detected, using --experimental-vm-modules in NODE_OPTIONS', 'info', quiet);\n  }\n\n  if(vitestConfigFile) {\n    vitestOptions.push('--config', vitestConfigFile);\n  }\n\n  if(bail) {\n    vitestOptions.push('--bail', '1');\n  }\n\n  if(changedFilesWithAncestor) {\n    vitestOptions.push('--changed');\n  }\n\n  if(changedSince) {\n    vitestOptions.push('--changed', changedSince);\n  }\n\n  if(ci) {\n    vitestOptions.push('--run');\n  }\n\n  if(collectCoverageFrom) {\n    vitestOptions.push('--coverage', '--coverage.include', collectCoverageFrom);\n  }\n\n  if(debug) {\n    vitestOptions.push('--inspect');\n  }\n\n  if(detectOpenHandles) {\n    reporters.add('hanging-process');\n  }\n\n  const environmentName = environment || env;\n  if(environmentName) {\n    vitestOptions.push('--environment', environmentName);\n  }\n\n  if(errorOnDeprecated) {\n    log('Vitest does not support --errorOnDeprecated; option ignored.', 'warn', quiet);\n  }\n\n  if(expand) {\n    vitestOptions.push('--expandSnapshotDiff');\n  }\n\n  if(forceExit) {\n    log('Vitest does not support --forceExit; option ignored.', 'warn', quiet);\n  }\n\n  if(lastCommit) {\n    vitestOptions.push('--changed');\n  }\n\n  if(logHeapUsage) {\n    vitestOptions.push('--logHeapUsage');\n  }\n\n  if(maxWorkers) {\n    vitestOptions.push('--maxWorkers', maxWorkers);\n  }\n\n  if(noStackTrace) {\n    log('Vitest does not support --noStackTrace; option ignored.', 'warn', quiet);\n  }\n\n  if(notify) {\n    log('Vitest does not support --notify; option ignored.', 'warn', quiet);\n  }\n\n  if(onlyChanged) {\n    vitestOptions.push('--changed');\n  }\n\n  let tempOutputFile = outputFile;\n  const shouldWriteJson = json || useAnalyze || useDebug || Boolean(outputFile);\n\n  if(shouldWriteJson) {\n    tempOutputFile = outputFile || '.lex-test-results.json';\n    vitestOptions.push('--outputFile', tempOutputFile);\n    reporters.add('json');\n  }\n\n  if(passWithNoTests) {\n    vitestOptions.push('--passWithNoTests');\n  }\n\n  if(runInBand) {\n    vitestOptions.push('--no-file-parallelism', '--maxWorkers', '1');\n  }\n\n  if(silent) {\n    vitestOptions.push('--silent');\n  }\n\n  if(testLocationInResults) {\n    vitestOptions.push('--includeTaskLocation');\n  }\n\n  if(testNamePattern) {\n    vitestOptions.push('--testNamePattern', testNamePattern);\n  }\n\n  if(testPathPattern) {\n    filters.push(testPathPattern);\n  }\n\n  if(useStderr) {\n    log('Vitest does not support --useStderr; option ignored.', 'warn', quiet);\n  }\n\n  if(verbose) {\n    reporters.add('verbose');\n  }\n\n  if(removeCache || clearCache) {\n    vitestOptions.push('--clearCache');\n  }\n\n  if(update) {\n    vitestOptions.push('--update');\n  }\n\n  if(watch) {\n    filters.push(watch);\n  }\n\n  if(args) {\n    vitestOptions.push(...args);\n  }\n\n  if(files && files.length > 0) {\n    filters.push(...files);\n  }\n\n  if(reporters.size > 0) {\n    const reporterList = Array.from(reporters);\n    if(reporterList.includes('json') && !reporterList.includes('verbose')) {\n      // Keep console output while writing JSON results.\n      reporterList.unshift('default');\n    }\n    reporterList.forEach((reporter) => vitestOptions.push('--reporter', reporter));\n  }\n\n  const finalArgs = [...vitestArgs, ...vitestOptions, ...filters];\n\n  if(debug) {\n    log(`Vitest options: ${finalArgs.join(' ')}`, 'info', quiet);\n    log(`NODE_OPTIONS: ${nodeOptions}`, 'info', quiet);\n  }\n\n  try {\n    const env: Record<string, string> = {\n      ...process.env,\n      NODE_OPTIONS: nodeOptions\n    };\n\n    if(colors) {\n      env.FORCE_COLOR = '1';\n    }\n\n    if(ci) {\n      env.CI = 'true';\n    }\n\n    if(vitestSetupFile && existsSync(vitestSetupFile)) {\n      env.LEX_VITEST_SETUP = vitestSetupFile;\n    }\n\n    await execa(vitestPath, finalArgs, {\n      encoding: 'utf8',\n      env,\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Testing completed!');\n\n    if(useAnalyze) {\n      spinner.start('AI is analyzing test coverage and suggesting improvements...');\n\n      try {\n        const testResults = processTestResults(tempOutputFile);\n        const filePatterns = getTestFilePatterns(testPathPattern);\n\n        await aiFunction({\n          context: true,\n          prompt: `Analyze these Vitest test results and suggest test coverage improvements:\n\n${JSON.stringify(testResults, null, 2)}\n\nTest patterns: ${filePatterns.join(', ')}\n\nPlease provide:\n1. Analysis of current coverage gaps\n2. Suggestions for improving test cases\n3. Recommendations for additional integration test scenarios\n4. Best practices for increasing test effectiveness`,\n          quiet,\n          task: 'optimize'\n        });\n\n        spinner.succeed('AI test analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI test analysis');\n        if(!quiet) {\n          // eslint-disable-next-line no-console\n          console.error('AI analysis error:', aiError);\n        }\n      }\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    spinner.fail('Testing failed!');\n\n    if(useDebug) {\n      spinner.start('AI is analyzing test failures...');\n\n      try {\n        const testResults = processTestResults(tempOutputFile);\n\n        await aiFunction({\n          context: true,\n          prompt: `Debug these failed Vitest tests and suggest fixes:\n\n${JSON.stringify(error.message, null, 2)}\n\nTest results: ${JSON.stringify(testResults, null, 2)}\n\nPlease provide:\n1. Analysis of why the tests are failing\n2. Specific suggestions to fix each failing test\n3. Any potential issues with test fixtures or mocks\n4. Code examples for solutions`,\n          quiet,\n          task: 'help'\n        });\n\n        spinner.succeed('AI debugging assistance complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI debugging assistance');\n        if(!quiet) {\n          // eslint-disable-next-line no-console\n          console.error('AI debugging error:', aiError);\n        }\n      }\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport default test;\n"],"names":["execa","existsSync","readFileSync","sync","globSync","resolve","pathResolve","LexConfig","getTypeScriptConfigPath","createSpinner","resolveBinaryPath","log","aiFunction","detectESM","cwd","packageJsonPath","packageJsonContent","packageJson","JSON","parse","type","_error","defaultExit","code","process","env","VITEST","VITEST_WORKER_ID","NODE_ENV","undefined","exit","getTestFilePatterns","testPathPattern","defaultPatterns","findUncoveredSourceFiles","sourceFiles","ignore","testFiles","filter","sourceFile","baseName","replace","some","testFile","includes","processTestResults","outputFile","content","test","options","args","filesOrCallback","callbackParam","files","callback","analyze","aiAnalyze","aiDebug","aiGenerate","bail","changedFilesWithAncestor","changedSince","ci","clearCache","cliName","collectCoverageFrom","colors","config","debug","debugTests","detectOpenHandles","environment","errorOnDeprecated","expand","forceExit","generate","json","lastCommit","listTests","logHeapUsage","maxWorkers","noStackTrace","notify","onlyChanged","passWithNoTests","quiet","removeCache","runInBand","setup","showConfig","silent","testLocationInResults","testNamePattern","update","useStderr","verbose","watch","watchAll","useGenerate","useAnalyze","useDebug","spinner","parseConfig","useTypescript","testConfigPath","checkTestTypescriptConfig","start","uncoveredFiles","length","targetFile","context","file","prompt","task","succeed","aiError","fail","console","error","projectVitestBin","vitestPath","vitestConfigFile","projectVitestConfig","projectVitestConfigPaths","existingConfigPath","find","configPath","vitest","lexDir","getLexDir","lexVitestConfig","Object","keys","resolvedConfig","stringify","default","vitestSetupFile","vitestArgs","vitestOptions","reporters","Set","filters","watchMode","Boolean","listMode","push","isESM","nodeOptions","NODE_OPTIONS","trim","add","environmentName","tempOutputFile","shouldWriteJson","size","reporterList","Array","from","unshift","forEach","reporter","finalArgs","join","FORCE_COLOR","CI","LEX_VITEST_SETUP","encoding","stdio","testResults","filePatterns","message"],"mappings":"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"}
@@ -1,9 +1,9 @@
1
1
  export declare const parseVersion: (packageVersion: string) => string;
2
2
  export declare const packages: {
3
- jest: string;
4
3
  lex: any;
5
4
  swc: string;
6
5
  typescript: string;
6
+ vitest: string;
7
7
  webpack: string;
8
8
  };
9
9
  export declare const jsonVersions: (lexPackages: any) => {};
@@ -8,10 +8,10 @@ const packagePath = getLexPackageJsonPath();
8
8
  const packageJson = JSON.parse(readFileSync(packagePath, 'utf8'));
9
9
  export const parseVersion = (packageVersion)=>packageVersion?.replace(/\^/g, '') || 'N/A';
10
10
  export const packages = {
11
- jest: parseVersion(packageJson?.dependencies?.jest),
12
11
  lex: packageJson.version,
13
12
  swc: parseVersion(packageJson?.dependencies?.['@swc/core']),
14
13
  typescript: parseVersion(packageJson?.dependencies?.typescript),
14
+ vitest: parseVersion(packageJson?.dependencies?.vitest),
15
15
  webpack: parseVersion(packageJson?.dependencies?.webpack)
16
16
  };
17
17
  export const jsonVersions = (lexPackages)=>Object.keys(lexPackages).reduce((list, key)=>{
@@ -26,7 +26,7 @@ export const versions = (cmd, callback)=>{
26
26
  log(` Lex: ${packages.lex}`, 'info', false);
27
27
  log(' ----------', 'note', false);
28
28
  log(` SWC: ${packages.swc}`, 'info', false);
29
- log(` Jest: ${packages.jest}`, 'info', false);
29
+ log(` Vitest: ${packages.vitest}`, 'info', false);
30
30
  log(` Typescript: ${packages.typescript}`, 'info', false);
31
31
  log(` Webpack: ${packages.webpack}`, 'info', false);
32
32
  }
@@ -36,4 +36,4 @@ export const versions = (cmd, callback)=>{
36
36
  return Promise.resolve(0);
37
37
  };
38
38
 
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy92ZXJzaW9ucy92ZXJzaW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcblxuaW1wb3J0IHtnZXRMZXhQYWNrYWdlSnNvblBhdGh9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpIHx8ICdOL0EnO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGplc3Q6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5qZXN0KSxcbiAgbGV4OiBwYWNrYWdlSnNvbi52ZXJzaW9uLFxuICBzd2M6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5bJ0Bzd2MvY29yZSddKSxcbiAgdHlwZXNjcmlwdDogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/LnR5cGVzY3JpcHQpLFxuICB3ZWJwYWNrOiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8ud2VicGFjaylcbn07XG5cbmV4cG9ydCBjb25zdCBqc29uVmVyc2lvbnMgPSAobGV4UGFja2FnZXMpID0+IE9iamVjdC5rZXlzKGxleFBhY2thZ2VzKS5yZWR1Y2UoKGxpc3QsIGtleSkgPT4ge1xuICBsaXN0W2tleV0gPSBwYWNrYWdlc1trZXldO1xuICByZXR1cm4gbGlzdDtcbn0sIHt9KTtcblxuZXhwb3J0IGludGVyZmFjZSBWZXJzaW9uc0NtZCB7XG4gIHJlYWRvbmx5IGpzb24/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY29uc3QgdmVyc2lvbnMgPSAoY21kOiBWZXJzaW9uc0NtZCwgY2FsbGJhY2s6IChzdGF0dXM6IG51bWJlcik9PiB2b2lkKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgaWYoY21kLmpzb24pIHtcbiAgICBjb25zb2xlLmxvZyhKU09OLnN0cmluZ2lmeShqc29uVmVyc2lvbnMocGFja2FnZXMpKSk7XG4gIH0gZWxzZSB7XG4gICAgbG9nKCdWZXJzaW9uczonLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgTGV4OiAke3BhY2thZ2VzLmxleH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coJyAgLS0tLS0tLS0tLScsICdub3RlJywgZmFsc2UpO1xuICAgIGxvZyhgICBTV0M6ICR7cGFja2FnZXMuc3djfWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBKZXN0OiAke3BhY2thZ2VzLmplc3R9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFR5cGVzY3JpcHQ6ICR7cGFja2FnZXMudHlwZXNjcmlwdH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgV2VicGFjazogJHtwYWNrYWdlcy53ZWJwYWNrfWAsICdpbmZvJywgZmFsc2UpO1xuICB9XG5cbiAgaWYoY2FsbGJhY2spIHtcbiAgICBjYWxsYmFjaygwKTtcbiAgfVxuXG4gIHJldHVybiBQcm9taXNlLnJlc29sdmUoMCk7XG59OyJdLCJuYW1lcyI6WyJyZWFkRmlsZVN5bmMiLCJnZXRMZXhQYWNrYWdlSnNvblBhdGgiLCJsb2ciLCJwYWNrYWdlUGF0aCIsInBhY2thZ2VKc29uIiwiSlNPTiIsInBhcnNlIiwicGFyc2VWZXJzaW9uIiwicGFja2FnZVZlcnNpb24iLCJyZXBsYWNlIiwicGFja2FnZXMiLCJqZXN0IiwiZGVwZW5kZW5jaWVzIiwibGV4IiwidmVyc2lvbiIsInN3YyIsInR5cGVzY3JpcHQiLCJ3ZWJwYWNrIiwianNvblZlcnNpb25zIiwibGV4UGFja2FnZXMiLCJPYmplY3QiLCJrZXlzIiwicmVkdWNlIiwibGlzdCIsImtleSIsInZlcnNpb25zIiwiY21kIiwiY2FsbGJhY2siLCJqc29uIiwiY29uc29sZSIsInN0cmluZ2lmeSIsIlByb21pc2UiLCJyZXNvbHZlIl0sIm1hcHBpbmdzIjoiQUFBQTs7O0NBR0MsR0FDRCxTQUFRQSxZQUFZLFFBQU8sS0FBSztBQUVoQyxTQUFRQyxxQkFBcUIsUUFBTyxzQkFBc0I7QUFDMUQsU0FBUUMsR0FBRyxRQUFPLHFCQUFxQjtBQUV2QyxNQUFNQyxjQUFjRjtBQUNwQixNQUFNRyxjQUFjQyxLQUFLQyxLQUFLLENBQUNOLGFBQWFHLGFBQWE7QUFFekQsT0FBTyxNQUFNSSxlQUFlLENBQUNDLGlCQUFtQ0EsZ0JBQWdCQyxRQUFRLE9BQU8sT0FBTyxNQUFNO0FBRTVHLE9BQU8sTUFBTUMsV0FBVztJQUN0QkMsTUFBTUosYUFBYUgsYUFBYVEsY0FBY0Q7SUFDOUNFLEtBQUtULFlBQVlVLE9BQU87SUFDeEJDLEtBQUtSLGFBQWFILGFBQWFRLGNBQWMsQ0FBQyxZQUFZO0lBQzFESSxZQUFZVCxhQUFhSCxhQUFhUSxjQUFjSTtJQUNwREMsU0FBU1YsYUFBYUgsYUFBYVEsY0FBY0s7QUFDbkQsRUFBRTtBQUVGLE9BQU8sTUFBTUMsZUFBZSxDQUFDQyxjQUFnQkMsT0FBT0MsSUFBSSxDQUFDRixhQUFhRyxNQUFNLENBQUMsQ0FBQ0MsTUFBTUM7UUFDbEZELElBQUksQ0FBQ0MsSUFBSSxHQUFHZCxRQUFRLENBQUNjLElBQUk7UUFDekIsT0FBT0Q7SUFDVCxHQUFHLENBQUMsR0FBRztBQU1QLE9BQU8sTUFBTUUsV0FBVyxDQUFDQyxLQUFrQkM7SUFDekMsSUFBR0QsSUFBSUUsSUFBSSxFQUFFO1FBQ1hDLFFBQVEzQixHQUFHLENBQUNHLEtBQUt5QixTQUFTLENBQUNaLGFBQWFSO0lBQzFDLE9BQU87UUFDTFIsSUFBSSxhQUFhLFFBQVE7UUFDekJBLElBQUksQ0FBQyxPQUFPLEVBQUVRLFNBQVNHLEdBQUcsRUFBRSxFQUFFLFFBQVE7UUFDdENYLElBQUksZ0JBQWdCLFFBQVE7UUFDNUJBLElBQUksQ0FBQyxPQUFPLEVBQUVRLFNBQVNLLEdBQUcsRUFBRSxFQUFFLFFBQVE7UUFDdENiLElBQUksQ0FBQyxRQUFRLEVBQUVRLFNBQVNDLElBQUksRUFBRSxFQUFFLFFBQVE7UUFDeENULElBQUksQ0FBQyxjQUFjLEVBQUVRLFNBQVNNLFVBQVUsRUFBRSxFQUFFLFFBQVE7UUFDcERkLElBQUksQ0FBQyxXQUFXLEVBQUVRLFNBQVNPLE9BQU8sRUFBRSxFQUFFLFFBQVE7SUFDaEQ7SUFFQSxJQUFHVSxVQUFVO1FBQ1hBLFNBQVM7SUFDWDtJQUVBLE9BQU9JLFFBQVFDLE9BQU8sQ0FBQztBQUN6QixFQUFFIn0=
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy92ZXJzaW9ucy92ZXJzaW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcblxuaW1wb3J0IHtnZXRMZXhQYWNrYWdlSnNvblBhdGh9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpIHx8ICdOL0EnO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGxleDogcGFja2FnZUpzb24udmVyc2lvbixcbiAgc3djOiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8uWydAc3djL2NvcmUnXSksXG4gIHR5cGVzY3JpcHQ6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy50eXBlc2NyaXB0KSxcbiAgdml0ZXN0OiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8udml0ZXN0KSxcbiAgd2VicGFjazogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/LndlYnBhY2spXG59O1xuXG5leHBvcnQgY29uc3QganNvblZlcnNpb25zID0gKGxleFBhY2thZ2VzKSA9PiBPYmplY3Qua2V5cyhsZXhQYWNrYWdlcykucmVkdWNlKChsaXN0LCBrZXkpID0+IHtcbiAgbGlzdFtrZXldID0gcGFja2FnZXNba2V5XTtcbiAgcmV0dXJuIGxpc3Q7XG59LCB7fSk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmVyc2lvbnNDbWQge1xuICByZWFkb25seSBqc29uPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNvbnN0IHZlcnNpb25zID0gKGNtZDogVmVyc2lvbnNDbWQsIGNhbGxiYWNrOiAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBpZihjbWQuanNvbikge1xuICAgIGNvbnNvbGUubG9nKEpTT04uc3RyaW5naWZ5KGpzb25WZXJzaW9ucyhwYWNrYWdlcykpKTtcbiAgfSBlbHNlIHtcbiAgICBsb2coJ1ZlcnNpb25zOicsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBMZXg6ICR7cGFja2FnZXMubGV4fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZygnICAtLS0tLS0tLS0tJywgJ25vdGUnLCBmYWxzZSk7XG4gICAgbG9nKGAgIFNXQzogJHtwYWNrYWdlcy5zd2N9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFZpdGVzdDogJHtwYWNrYWdlcy52aXRlc3R9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFR5cGVzY3JpcHQ6ICR7cGFja2FnZXMudHlwZXNjcmlwdH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgV2VicGFjazogJHtwYWNrYWdlcy53ZWJwYWNrfWAsICdpbmZvJywgZmFsc2UpO1xuICB9XG5cbiAgaWYoY2FsbGJhY2spIHtcbiAgICBjYWxsYmFjaygwKTtcbiAgfVxuXG4gIHJldHVybiBQcm9taXNlLnJlc29sdmUoMCk7XG59O1xuIl0sIm5hbWVzIjpbInJlYWRGaWxlU3luYyIsImdldExleFBhY2thZ2VKc29uUGF0aCIsImxvZyIsInBhY2thZ2VQYXRoIiwicGFja2FnZUpzb24iLCJKU09OIiwicGFyc2UiLCJwYXJzZVZlcnNpb24iLCJwYWNrYWdlVmVyc2lvbiIsInJlcGxhY2UiLCJwYWNrYWdlcyIsImxleCIsInZlcnNpb24iLCJzd2MiLCJkZXBlbmRlbmNpZXMiLCJ0eXBlc2NyaXB0Iiwidml0ZXN0Iiwid2VicGFjayIsImpzb25WZXJzaW9ucyIsImxleFBhY2thZ2VzIiwiT2JqZWN0Iiwia2V5cyIsInJlZHVjZSIsImxpc3QiLCJrZXkiLCJ2ZXJzaW9ucyIsImNtZCIsImNhbGxiYWNrIiwianNvbiIsImNvbnNvbGUiLCJzdHJpbmdpZnkiLCJQcm9taXNlIiwicmVzb2x2ZSJdLCJtYXBwaW5ncyI6IkFBQUE7OztDQUdDLEdBQ0QsU0FBUUEsWUFBWSxRQUFPLEtBQUs7QUFFaEMsU0FBUUMscUJBQXFCLFFBQU8sc0JBQXNCO0FBQzFELFNBQVFDLEdBQUcsUUFBTyxxQkFBcUI7QUFFdkMsTUFBTUMsY0FBY0Y7QUFDcEIsTUFBTUcsY0FBY0MsS0FBS0MsS0FBSyxDQUFDTixhQUFhRyxhQUFhO0FBRXpELE9BQU8sTUFBTUksZUFBZSxDQUFDQyxpQkFBbUNBLGdCQUFnQkMsUUFBUSxPQUFPLE9BQU8sTUFBTTtBQUU1RyxPQUFPLE1BQU1DLFdBQVc7SUFDdEJDLEtBQUtQLFlBQVlRLE9BQU87SUFDeEJDLEtBQUtOLGFBQWFILGFBQWFVLGNBQWMsQ0FBQyxZQUFZO0lBQzFEQyxZQUFZUixhQUFhSCxhQUFhVSxjQUFjQztJQUNwREMsUUFBUVQsYUFBYUgsYUFBYVUsY0FBY0U7SUFDaERDLFNBQVNWLGFBQWFILGFBQWFVLGNBQWNHO0FBQ25ELEVBQUU7QUFFRixPQUFPLE1BQU1DLGVBQWUsQ0FBQ0MsY0FBZ0JDLE9BQU9DLElBQUksQ0FBQ0YsYUFBYUcsTUFBTSxDQUFDLENBQUNDLE1BQU1DO1FBQ2xGRCxJQUFJLENBQUNDLElBQUksR0FBR2QsUUFBUSxDQUFDYyxJQUFJO1FBQ3pCLE9BQU9EO0lBQ1QsR0FBRyxDQUFDLEdBQUc7QUFNUCxPQUFPLE1BQU1FLFdBQVcsQ0FBQ0MsS0FBa0JDO0lBQ3pDLElBQUdELElBQUlFLElBQUksRUFBRTtRQUNYQyxRQUFRM0IsR0FBRyxDQUFDRyxLQUFLeUIsU0FBUyxDQUFDWixhQUFhUjtJQUMxQyxPQUFPO1FBQ0xSLElBQUksYUFBYSxRQUFRO1FBQ3pCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTQyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDVCxJQUFJLGdCQUFnQixRQUFRO1FBQzVCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTRyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDWCxJQUFJLENBQUMsVUFBVSxFQUFFUSxTQUFTTSxNQUFNLEVBQUUsRUFBRSxRQUFRO1FBQzVDZCxJQUFJLENBQUMsY0FBYyxFQUFFUSxTQUFTSyxVQUFVLEVBQUUsRUFBRSxRQUFRO1FBQ3BEYixJQUFJLENBQUMsV0FBVyxFQUFFUSxTQUFTTyxPQUFPLEVBQUUsRUFBRSxRQUFRO0lBQ2hEO0lBRUEsSUFBR1UsVUFBVTtRQUNYQSxTQUFTO0lBQ1g7SUFFQSxPQUFPSSxRQUFRQyxPQUFPLENBQUM7QUFDekIsRUFBRSJ9