@nlabs/lex 1.48.5 → 1.48.6

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.
package/babel.config.json CHANGED
@@ -9,6 +9,11 @@
9
9
  }
10
10
  ],
11
11
  "@babel/preset-typescript",
12
- "@babel/preset-react"
12
+ [
13
+ "@babel/preset-react",
14
+ {
15
+ "runtime": "automatic"
16
+ }
17
+ ]
13
18
  ]
14
19
  }
@@ -164,6 +164,7 @@ ${cliName} Error: Jest binary not found in Lex's node_modules or monorepo root`,
164
164
  } else {
165
165
  const projectJestConfigPath = pathResolve(process.cwd(), "jest.config.js");
166
166
  const projectJestConfigCjsPath = pathResolve(process.cwd(), "jest.config.cjs");
167
+ const projectJestConfigMjsPath = pathResolve(process.cwd(), "jest.config.mjs");
167
168
  const projectJestConfigJsonPath = pathResolve(process.cwd(), "jest.config.json");
168
169
  if (existsSync(projectJestConfigPath)) {
169
170
  jestConfigFile = projectJestConfigPath;
@@ -175,6 +176,11 @@ ${cliName} Error: Jest binary not found in Lex's node_modules or monorepo root`,
175
176
  if (debug) {
176
177
  log(`Using project Jest config file (CJS): ${jestConfigFile}`, "info", quiet);
177
178
  }
179
+ } else if (existsSync(projectJestConfigMjsPath)) {
180
+ jestConfigFile = projectJestConfigMjsPath;
181
+ if (debug) {
182
+ log(`Using project Jest config file (MJS): ${jestConfigFile}`, "info", quiet);
183
+ }
178
184
  } else if (existsSync(projectJestConfigJsonPath)) {
179
185
  jestConfigFile = projectJestConfigJsonPath;
180
186
  if (debug) {
@@ -208,18 +214,6 @@ ${cliName} Error: Jest binary not found in Lex's node_modules or monorepo root`,
208
214
  }
209
215
  }
210
216
  const jestSetupFile = setup || pathResolve(process.cwd(), "jest.setup.js");
211
- if (!existsSync(jestSetupFile)) {
212
- const lexDir = LexConfig.getLexDir();
213
- const templateSetupFile = pathResolve(lexDir, "jest.setup.template.js");
214
- if (existsSync(templateSetupFile)) {
215
- const fs = await import("fs");
216
- const templateContent = fs.readFileSync(templateSetupFile, "utf8");
217
- fs.writeFileSync(jestSetupFile, templateContent);
218
- if (debug) {
219
- log(`Created Jest setup file from template: ${jestSetupFile}`, "info", quiet);
220
- }
221
- }
222
- }
223
217
  const jestOptions = ["--no-cache"];
224
218
  const isESM = detectESM(process.cwd());
225
219
  let nodeOptions = process.env.NODE_OPTIONS || "";
@@ -318,7 +312,7 @@ ${cliName} Error: Jest binary not found in Lex's node_modules or monorepo root`,
318
312
  jestOptions.push("--testNamePattern", testNamePattern);
319
313
  }
320
314
  if (testPathPattern) {
321
- jestOptions.push("--testPathPatterns", testPathPattern);
315
+ jestOptions.push("--testPathPattern", testPathPattern);
322
316
  }
323
317
  if (useStderr) {
324
318
  jestOptions.push("--useStderr");
@@ -432,4 +426,4 @@ export {
432
426
  getTestFilePatterns,
433
427
  test
434
428
  };
435
- //# 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 {getDirName, 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\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/**', '**/*.test.*', '**/*.spec.*']\n  });\n\n  const testFiles = globSync('**/*.{test,spec}.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**']\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 (options: TestOptions, args: string[], callback: TestCallback = process.exit): Promise<number> => {\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          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          task: 'test',\n          file: targetFile,\n          context: true,\n          quiet\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        console.error('AI test generation error:', aiError);\n      }\n    }\n  }\n\n  const dirName = getDirName();\n  const dirPath: string = pathResolve(dirName, '../..');\n\n  const projectJestBin = pathResolve(process.cwd(), 'node_modules/.bin/jest');\n  let jestPath: string;\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 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(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\n  if(!existsSync(jestSetupFile)) {\n    const lexDir = LexConfig.getLexDir();\n    const templateSetupFile = pathResolve(lexDir, 'jest.setup.template.js');\n    if(existsSync(templateSetupFile)) {\n      const fs = await import('fs');\n      const templateContent = fs.readFileSync(templateSetupFile, 'utf8');\n      fs.writeFileSync(jestSetupFile, templateContent);\n      if(debug) {\n        log(`Created Jest setup file from template: ${jestSetupFile}`, 'info', quiet);\n      }\n    }\n  }\n\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('--testPathPatterns', 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(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      stdio: 'inherit',\n      env\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          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          task: 'optimize',\n          context: true,\n          quiet\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          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          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          task: 'help',\n          context: true,\n          quiet\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          console.error('AI debugging error:', aiError);\n        }\n      }\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport default test;"],
  "mappings": "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",
  "names": ["env"]
}

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 {getDirName, 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\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/**', '**/*.test.*', '**/*.spec.*']\n  });\n\n  const testFiles = globSync('**/*.{test,spec}.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**']\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 (options: TestOptions, args: string[], callback: TestCallback = process.exit): Promise<number> => {\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          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          task: 'test',\n          file: targetFile,\n          context: true,\n          quiet\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        console.error('AI test generation error:', aiError);\n      }\n    }\n  }\n\n  const dirName = getDirName();\n  const dirPath: string = pathResolve(dirName, '../..');\n\n  const projectJestBin = pathResolve(process.cwd(), 'node_modules/.bin/jest');\n  let jestPath: string;\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(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      stdio: 'inherit',\n      env\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          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          task: 'optimize',\n          context: true,\n          quiet\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          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          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          task: 'help',\n          context: true,\n          quiet\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          console.error('AI debugging error:', aiError);\n        }\n      }\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport default test;"],
  "mappings": "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",
  "names": ["env"]
}

@@ -1,8 +1,6 @@
1
1
  /**
2
- * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
2
+ * Copyright (c) 2025-Present, Nitrogen Labs, Inc.
3
3
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
4
  */
5
5
  import '@testing-library/jest-dom';
6
- import * as react from 'react';
7
6
  export { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup } from '@testing-library/react';
8
- export { react };
@@ -1,5 +1,4 @@
1
1
  import "@testing-library/jest-dom";
2
- import * as react from "react";
3
2
  import {
4
3
  render,
5
4
  screen,
@@ -75,7 +74,6 @@ export {
75
74
  queryByRole,
76
75
  queryByTestId,
77
76
  queryByText,
78
- react,
79
77
  render,
80
78
  renderHook,
81
79
  screen,
@@ -83,4 +81,4 @@ export {
83
81
  waitForElementToBeRemoved,
84
82
  within
85
83
  };
86
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3Rlc3QtcmVhY3QvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgJ0B0ZXN0aW5nLWxpYnJhcnkvamVzdC1kb20nO1xuXG4vLyBSZS1leHBvcnQgUmVhY3QgdGVzdGluZyB1dGlsaXRpZXMgd2l0aG91dCBhbnkgTGV4IGRlcGVuZGVuY2llc1xuLy8gRXhwb3J0IFJlYWN0IGZvciBjb252ZW5pZW5jZVxuaW1wb3J0ICogYXMgcmVhY3QgZnJvbSAncmVhY3QnO1xuXG5leHBvcnQge1xuICByZW5kZXIsXG4gIHNjcmVlbixcbiAgZmlyZUV2ZW50LFxuICB3YWl0Rm9yLFxuICB3YWl0Rm9yRWxlbWVudFRvQmVSZW1vdmVkLFxuICB3aXRoaW4sXG4gIGdldEJ5Um9sZSxcbiAgZ2V0QnlMYWJlbFRleHQsXG4gIGdldEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBnZXRCeVRleHQsXG4gIGdldEJ5VGVzdElkLFxuICBnZXRBbGxCeVJvbGUsXG4gIGdldEFsbEJ5TGFiZWxUZXh0LFxuICBnZXRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QWxsQnlUZXh0LFxuICBnZXRBbGxCeVRlc3RJZCxcbiAgcXVlcnlCeVJvbGUsXG4gIHF1ZXJ5QnlMYWJlbFRleHQsXG4gIHF1ZXJ5QnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QnlUZXh0LFxuICBxdWVyeUJ5VGVzdElkLFxuICBxdWVyeUFsbEJ5Um9sZSxcbiAgcXVlcnlBbGxCeUxhYmVsVGV4dCxcbiAgcXVlcnlBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgcXVlcnlBbGxCeVRleHQsXG4gIHF1ZXJ5QWxsQnlUZXN0SWQsXG4gIGZpbmRCeVJvbGUsXG4gIGZpbmRCeUxhYmVsVGV4dCxcbiAgZmluZEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBmaW5kQnlUZXh0LFxuICBmaW5kQnlUZXN0SWQsXG4gIGZpbmRBbGxCeVJvbGUsXG4gIGZpbmRBbGxCeUxhYmVsVGV4dCxcbiAgZmluZEFsbEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBmaW5kQWxsQnlUZXh0LFxuICBmaW5kQWxsQnlUZXN0SWQsXG4gIHJlbmRlckhvb2ssXG4gIGFjdCxcbiAgY2xlYW51cFxufSBmcm9tICdAdGVzdGluZy1saWJyYXJ5L3JlYWN0JztcbmV4cG9ydCB7cmVhY3R9OyJdLAogICJtYXBwaW5ncyI6ICJBQUlBLE9BQU87QUFJUCxZQUFZLFdBQVc7QUFFdkI7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxPQUNLOyIsCiAgIm5hbWVzIjogW10KfQo=
84
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3Rlc3QtcmVhY3QvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI1LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgJ0B0ZXN0aW5nLWxpYnJhcnkvamVzdC1kb20nO1xuXG5leHBvcnQge1xuICByZW5kZXIsXG4gIHNjcmVlbixcbiAgZmlyZUV2ZW50LFxuICB3YWl0Rm9yLFxuICB3YWl0Rm9yRWxlbWVudFRvQmVSZW1vdmVkLFxuICB3aXRoaW4sXG4gIGdldEJ5Um9sZSxcbiAgZ2V0QnlMYWJlbFRleHQsXG4gIGdldEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBnZXRCeVRleHQsXG4gIGdldEJ5VGVzdElkLFxuICBnZXRBbGxCeVJvbGUsXG4gIGdldEFsbEJ5TGFiZWxUZXh0LFxuICBnZXRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QWxsQnlUZXh0LFxuICBnZXRBbGxCeVRlc3RJZCxcbiAgcXVlcnlCeVJvbGUsXG4gIHF1ZXJ5QnlMYWJlbFRleHQsXG4gIHF1ZXJ5QnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QnlUZXh0LFxuICBxdWVyeUJ5VGVzdElkLFxuICBxdWVyeUFsbEJ5Um9sZSxcbiAgcXVlcnlBbGxCeUxhYmVsVGV4dCxcbiAgcXVlcnlBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgcXVlcnlBbGxCeVRleHQsXG4gIHF1ZXJ5QWxsQnlUZXN0SWQsXG4gIGZpbmRCeVJvbGUsXG4gIGZpbmRCeUxhYmVsVGV4dCxcbiAgZmluZEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBmaW5kQnlUZXh0LFxuICBmaW5kQnlUZXN0SWQsXG4gIGZpbmRBbGxCeVJvbGUsXG4gIGZpbmRBbGxCeUxhYmVsVGV4dCxcbiAgZmluZEFsbEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBmaW5kQWxsQnlUZXh0LFxuICBmaW5kQWxsQnlUZXN0SWQsXG4gIHJlbmRlckhvb2ssXG4gIGFjdCxcbiAgY2xlYW51cFxufSBmcm9tICdAdGVzdGluZy1saWJyYXJ5L3JlYWN0JzsiXSwKICAibWFwcGluZ3MiOiAiQUFJQSxPQUFPO0FBRVA7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxPQUNLOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */
5
+ /**
6
+ * Deep merge function that recursively merges objects and arrays
7
+ * @param target - The target object to merge into
8
+ * @param source - The source object to merge from
9
+ * @returns The merged object
10
+ */
11
+ export declare const deepMerge: (target: any, source: any) => any;
@@ -0,0 +1,24 @@
1
+ const deepMerge = (target, source) => {
2
+ if (!source) return target;
3
+ const result = { ...target };
4
+ for (const key in source) {
5
+ if (source.hasOwnProperty(key)) {
6
+ if (source[key] && typeof source[key] === "object" && !Array.isArray(source[key])) {
7
+ result[key] = deepMerge(target[key] || {}, source[key]);
8
+ } else if (Array.isArray(source[key])) {
9
+ if (Array.isArray(target[key])) {
10
+ result[key] = [...target[key], ...source[key]];
11
+ } else {
12
+ result[key] = [...source[key]];
13
+ }
14
+ } else {
15
+ result[key] = source[key];
16
+ }
17
+ }
18
+ }
19
+ return result;
20
+ };
21
+ export {
22
+ deepMerge
23
+ };
24
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3V0aWxzL2RlZXBNZXJnZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cblxuLyoqXG4gKiBEZWVwIG1lcmdlIGZ1bmN0aW9uIHRoYXQgcmVjdXJzaXZlbHkgbWVyZ2VzIG9iamVjdHMgYW5kIGFycmF5c1xuICogQHBhcmFtIHRhcmdldCAtIFRoZSB0YXJnZXQgb2JqZWN0IHRvIG1lcmdlIGludG9cbiAqIEBwYXJhbSBzb3VyY2UgLSBUaGUgc291cmNlIG9iamVjdCB0byBtZXJnZSBmcm9tXG4gKiBAcmV0dXJucyBUaGUgbWVyZ2VkIG9iamVjdFxuICovXG5leHBvcnQgY29uc3QgZGVlcE1lcmdlID0gKHRhcmdldDogYW55LCBzb3VyY2U6IGFueSk6IGFueSA9PiB7XG4gIGlmKCFzb3VyY2UpIHJldHVybiB0YXJnZXQ7XG5cbiAgY29uc3QgcmVzdWx0ID0gey4uLnRhcmdldH07XG5cbiAgZm9yKGNvbnN0IGtleSBpbiBzb3VyY2UpIHtcbiAgICBpZihzb3VyY2UuaGFzT3duUHJvcGVydHkoa2V5KSkge1xuICAgICAgaWYoc291cmNlW2tleV0gJiYgdHlwZW9mIHNvdXJjZVtrZXldID09PSAnb2JqZWN0JyAmJiAhQXJyYXkuaXNBcnJheShzb3VyY2Vba2V5XSkpIHtcbiAgICAgICAgcmVzdWx0W2tleV0gPSBkZWVwTWVyZ2UodGFyZ2V0W2tleV0gfHwge30sIHNvdXJjZVtrZXldKTtcbiAgICAgIH0gZWxzZSBpZihBcnJheS5pc0FycmF5KHNvdXJjZVtrZXldKSkge1xuICAgICAgICAvLyBGb3IgYXJyYXlzLCBtZXJnZSBpZiBib3RoIGFyZSBhcnJheXMsIG90aGVyd2lzZSByZXBsYWNlXG4gICAgICAgIGlmKEFycmF5LmlzQXJyYXkodGFyZ2V0W2tleV0pKSB7XG4gICAgICAgICAgcmVzdWx0W2tleV0gPSBbLi4udGFyZ2V0W2tleV0sIC4uLnNvdXJjZVtrZXldXTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXN1bHRba2V5XSA9IFsuLi5zb3VyY2Vba2V5XV07XG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlc3VsdFtrZXldID0gc291cmNlW2tleV07XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHJlc3VsdDtcbn07Il0sCiAgIm1hcHBpbmdzIjogIkFBV08sTUFBTSxZQUFZLENBQUMsUUFBYSxXQUFxQjtBQUMxRCxNQUFHLENBQUMsT0FBUSxRQUFPO0FBRW5CLFFBQU0sU0FBUyxFQUFDLEdBQUcsT0FBTTtBQUV6QixhQUFVLE9BQU8sUUFBUTtBQUN2QixRQUFHLE9BQU8sZUFBZSxHQUFHLEdBQUc7QUFDN0IsVUFBRyxPQUFPLEdBQUcsS0FBSyxPQUFPLE9BQU8sR0FBRyxNQUFNLFlBQVksQ0FBQyxNQUFNLFFBQVEsT0FBTyxHQUFHLENBQUMsR0FBRztBQUNoRixlQUFPLEdBQUcsSUFBSSxVQUFVLE9BQU8sR0FBRyxLQUFLLENBQUMsR0FBRyxPQUFPLEdBQUcsQ0FBQztBQUFBLE1BQ3hELFdBQVUsTUFBTSxRQUFRLE9BQU8sR0FBRyxDQUFDLEdBQUc7QUFFcEMsWUFBRyxNQUFNLFFBQVEsT0FBTyxHQUFHLENBQUMsR0FBRztBQUM3QixpQkFBTyxHQUFHLElBQUksQ0FBQyxHQUFHLE9BQU8sR0FBRyxHQUFHLEdBQUcsT0FBTyxHQUFHLENBQUM7QUFBQSxRQUMvQyxPQUFPO0FBQ0wsaUJBQU8sR0FBRyxJQUFJLENBQUMsR0FBRyxPQUFPLEdBQUcsQ0FBQztBQUFBLFFBQy9CO0FBQUEsTUFDRixPQUFPO0FBQ0wsZUFBTyxHQUFHLElBQUksT0FBTyxHQUFHO0FBQUEsTUFDMUI7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUVBLFNBQU87QUFDVDsiLAogICJuYW1lcyI6IFtdCn0K
package/jest.config.mjs CHANGED
@@ -2,68 +2,65 @@
2
2
  * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
3
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
4
  */
5
- import {readFileSync} from 'fs';
6
5
  import {fileURLToPath} from 'url';
7
6
  import {dirname, resolve} from 'path';
7
+ import {deepMerge} from './dist/utils/deepMerge.js';
8
+
9
+ import {readFileSync} from 'fs';
8
10
 
9
11
  const __filename = fileURLToPath(import.meta.url);
10
12
  const __dirname = dirname(__filename);
11
13
  const pack = JSON.parse(readFileSync(resolve(__dirname, 'package.json'), 'utf8'));
12
14
 
13
- export default {
15
+ let projectJestConfig = null;
16
+ if(process.env.LEX_CONFIG) {
17
+ try {
18
+ const lexConfig = JSON.parse(process.env.LEX_CONFIG);
19
+ projectJestConfig = lexConfig.jest;
20
+ } catch(error) {
21
+ console.warn('Failed to parse LEX_CONFIG:', error.message);
22
+ }
23
+ }
24
+
25
+ const baseConfig = {
26
+ collectCoverage: true,
27
+ coverageDirectory: '<rootDir>/coverage',
28
+ coveragePathIgnorePatterns: [
29
+ '/node_modules/',
30
+ '/dist',
31
+ '/lib',
32
+ '__snapshots__',
33
+ '.d.ts'
34
+ ],
35
+ coverageReporters: ['html', 'text'],
14
36
  displayName: pack.name,
15
- testEnvironment: 'jsdom',
16
37
  moduleFileExtensions: ['ts', 'tsx', 'js', 'json', 'node'],
17
- moduleDirectories: ['js', '.', 'node_modules'],
18
38
  moduleNameMapper: {
19
39
  '^(\\.{1,2}/.*)\\.js$': '$1',
20
- '^execa$': resolve(__dirname, '__mocks__/execa.js'),
21
- '^boxen$': resolve(__dirname, '__mocks__/boxen.js'),
22
- '^chalk$': resolve(__dirname, '__mocks__/chalk.js'),
23
- '^ora$': resolve(__dirname, '__mocks__/ora.js'),
24
- '^latest-version$': resolve(__dirname, '__mocks__/latest-version.js'),
25
- '^compare-versions$': resolve(__dirname, '__mocks__/compare-versions.js'),
26
- '.*LexConfig.*': resolve(__dirname, '__mocks__/LexConfig.js'),
27
- '.*build\\.js$': resolve(__dirname, '__mocks__/build.js'),
28
- '.*versions\\.js$': resolve(__dirname, '__mocks__/versions.js'),
29
- '.*compile\\.js$': resolve(__dirname, '__mocks__/compile.js'),
30
- 'utils/file\\.js$': resolve(__dirname, '__mocks__/file.js'),
31
- '.*/utils/file\\.js$': resolve(__dirname, '__mocks__/file.js'),
32
- '^(\\.{1,2}/)*utils/file\\.js$': resolve(__dirname, '__mocks__/file.js'),
33
- // '^(\.{1,2}/.*)\.js$': '$1',
34
- '\.(css|less|scss|sass)$': 'identity-obj-proxy',
35
- '\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$': resolve(__dirname, '__mocks__/fileMock.js')
36
40
  },
37
41
  rootDir: process.cwd(),
38
- transformIgnorePatterns: [
39
- 'node_modules/(?!(strip-indent|chalk|@testing-library/jest-dom|zod|@nlabs|@nlabs/arkhamjs|@nlabs/utils|@nlabs/lex|react-markdown|devlop)/.*)'
40
- ],
41
- setupFilesAfterEnv: ['<rootDir>/jest.setup.js'],
42
+ testEnvironment: 'node',
43
+ testRegex: '(/__tests__/.*|\\.(test|spec|integration))\\.(ts|tsx)?$',
42
44
  transform: {
43
45
  '^.+\.js$|^.+\.jsx$': ['babel-jest', {
44
46
  presets: [
45
47
  ['@babel/preset-env', {targets: {node: 'current'}}],
46
- '@babel/preset-react'
48
+ '@babel/preset-typescript'
47
49
  ]
48
50
  }],
49
51
  '^.+\.ts$|^.+\.tsx$': ['babel-jest', {
50
52
  presets: [
51
53
  ['@babel/preset-env', {targets: {node: 'current'}}],
52
54
  '@babel/preset-typescript',
53
- '@babel/preset-react'
55
+ ['@babel/preset-react', {runtime: 'automatic'}]
54
56
  ]
55
57
  }]
56
58
  },
57
- testRegex: '(/__tests__/.*|\\.(test|spec|integration))\\.(ts|tsx)?$',
58
- collectCoverage: true,
59
- coverageDirectory: '<rootDir>/coverage',
60
- coveragePathIgnorePatterns: [
61
- '/node_modules/',
62
- '/dist',
63
- '/lib',
64
- '__snapshots__',
65
- '.d.ts'
66
- ],
67
- coverageReporters: ['html', 'text'],
68
59
  verbose: true
69
- };
60
+ };
61
+
62
+ const finalConfig = projectJestConfig && Object.keys(projectJestConfig).length > 0
63
+ ? deepMerge(baseConfig, projectJestConfig)
64
+ : baseConfig;
65
+
66
+ export default finalConfig;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.48.5",
3
+ "version": "1.48.6",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -106,7 +106,7 @@
106
106
  "ajv": "^8.17.1",
107
107
  "assert": "^2.1.0",
108
108
  "autoprefixer": "^10.4.21",
109
- "babel-jest": "^30.0.4",
109
+ "babel-jest": "^29.7.0",
110
110
  "babel-loader": "^10.0.0",
111
111
  "babel-plugin-module-resolver": "^5.0.2",
112
112
  "babel-plugin-transform-import-meta": "^2.3.3",
@@ -130,6 +130,7 @@
130
130
  "eslint": "^9.31.0",
131
131
  "eslint-config-styleguidejs": "^4.0.22",
132
132
  "execa": "9.6.0",
133
+ "expect": "^29.7.0",
133
134
  "exports-loader": "^5.0.0",
134
135
  "favicons-webpack-plugin": "^6.0.1",
135
136
  "file-loader": "^6.2.0",
@@ -187,7 +188,6 @@
187
188
  "svg-spritemap-webpack-plugin": "^4.7.0",
188
189
  "svgo": "4.0.0",
189
190
  "tls": "^0.0.1",
190
- "ts-jest": "^29.4.0",
191
191
  "ts-node": "^10.9.2",
192
192
  "tsconfig-paths-webpack-plugin": "^4.2.0",
193
193
  "typescript": "5.8.3",
@@ -203,7 +203,10 @@
203
203
  "webpack-plugin-serve": "^1.6.0"
204
204
  },
205
205
  "devDependencies": {
206
- "@types/jest": "^30.0.0",
206
+ "@babel/plugin-transform-react-jsx": "^7.27.1",
207
+ "@babel/runtime": "^7.27.6",
208
+ "@babel/runtime-corejs3": "^7.28.0",
209
+ "@types/jest": "^29.5.14",
207
210
  "@types/luxon": "^3.6.2",
208
211
  "@types/node": "^24.0.14",
209
212
  "@types/ora": "^3.2.0",
@@ -8,7 +8,7 @@
8
8
  "esModuleInterop": true,
9
9
  "inlineSourceMap": true,
10
10
  "isolatedModules": true,
11
- "jsx": "react",
11
+ "jsx": "react-jsx",
12
12
  "lib": [
13
13
  "dom",
14
14
  "ESNext"
package/tsconfig.json CHANGED
@@ -7,7 +7,7 @@
7
7
  "esModuleInterop": true,
8
8
  "inlineSourceMap": true,
9
9
  "isolatedModules": true,
10
- "jsx": "react",
10
+ "jsx": "react-jsx",
11
11
  "lib": [
12
12
  "dom",
13
13
  "ESNext"
@@ -11,7 +11,7 @@
11
11
  "forceConsistentCasingInFileNames": true,
12
12
  "inlineSourceMap": false,
13
13
  "isolatedModules": true,
14
- "jsx": "react",
14
+ "jsx": "react-jsx",
15
15
  "lib": [
16
16
  "ESNext",
17
17
  "DOM"
@@ -5,7 +5,7 @@
5
5
  "emitDeclarationOnly": true,
6
6
  "esModuleInterop": true,
7
7
  "inlineSourceMap": true,
8
- "jsx": "react",
8
+ "jsx": "react-jsx",
9
9
  "lib": [
10
10
  "ESNext",
11
11
  "dom"
@@ -32,4 +32,4 @@
32
32
  "./lib",
33
33
  "./node_modules"
34
34
  ]
35
- }
35
+ }
@@ -10,7 +10,7 @@
10
10
  "forceConsistentCasingInFileNames": true,
11
11
  "inlineSourceMap": true,
12
12
  "isolatedModules": true,
13
- "jsx": "react",
13
+ "jsx": "react-jsx",
14
14
  "lib": [
15
15
  "ESNext",
16
16
  "DOM"
@@ -1,103 +0,0 @@
1
- # TypeScript Configurations in Lex
2
-
3
- Lex now uses specialized TypeScript configurations for different commands to optimize performance and functionality.
4
-
5
- ## Configuration Files
6
-
7
- ### 1. `tsconfig.build.json` - For Compilation and Building
8
-
9
- Used by: `lex compile`, `lex build`
10
-
11
- **Purpose:** Optimized for compilation and bundling with ESM output.
12
-
13
- **Key Features:**
14
-
15
- - ESM module format (`"module": "ESNext"`)
16
- - Declaration file generation (`"declaration": true`)
17
- - Source maps for debugging (`"inlineSourceMap": true`)
18
- - Strict type checking (`"strict": true`)
19
- - Excludes test files for faster compilation
20
-
21
- **Use Cases:**
22
-
23
- - Building production bundles
24
- - Generating type declarations
25
- - Compiling source code for distribution
26
-
27
- ### 2. `tsconfig.lint.json` - For Static Analysis
28
-
29
- Used by: `lex lint`
30
-
31
- **Purpose:** Optimized for static analysis and linting.
32
-
33
- **Key Features:**
34
-
35
- - No emission (`"noEmit": true`)
36
- - Strict unused variable checking (`"noUnusedLocals": true`)
37
- - Disabled pretty printing for faster analysis
38
- - Excludes test files to focus on source code
39
- - ESLint-friendly settings
40
-
41
- **Use Cases:**
42
-
43
- - Static type checking
44
- - Code quality analysis
45
- - Linting with ESLint + TypeScript
46
-
47
- ### 3. `tsconfig.test.json` - For Testing
48
-
49
- Used by: `lex test`
50
-
51
- **Purpose:** Optimized for testing environment.
52
-
53
- **Key Features:**
54
-
55
- - Includes test files (`**/*.test.*`, `**/*.spec.*`)
56
- - Jest types included (`"types": ["jest", "node"]`)
57
- - Relaxed strict mode for test flexibility (`"strict": false`)
58
- - Source maps for debugging tests
59
- - Coverage reporting support
60
-
61
- **Use Cases:**
62
-
63
- - Running unit tests
64
- - Integration testing
65
- - Test debugging and coverage
66
-
67
- ## Automatic Configuration
68
-
69
- Lex automatically creates these configuration files when needed:
70
-
71
- 1. **First run:** If no specialized config exists, Lex creates it from templates
72
- 2. **Fallback:** If specialized config doesn't exist, falls back to default `tsconfig.json`
73
- 3. **Custom configs:** You can override any config by creating your own version
74
-
75
- ## Migration from Single Config
76
-
77
- If you're migrating from a single `tsconfig.json`:
78
-
79
- 1. **Keep your existing config:** It will be used as a fallback
80
- 2. **Customize specialized configs:** Modify the generated configs for your needs
81
- 3. **Gradual adoption:** Commands will automatically use the appropriate config
82
-
83
- ## Customization
84
-
85
- You can customize any of these configurations:
86
-
87
- ```json
88
- // tsconfig.build.json - Customize for your build needs
89
- {
90
- "extends": "../../tsconfig.base.json",
91
- "compilerOptions": {
92
- "outDir": "./lib", // Custom output directory
93
- "target": "ES2020" // Custom target
94
- }
95
- }
96
- ```
97
-
98
- ## Benefits
99
-
100
- 1. **Performance:** Each config is optimized for its specific use case
101
- 2. **Clarity:** Clear separation of concerns between compilation, linting, and testing
102
- 3. **Flexibility:** Easy to customize each workflow independently
103
- 4. **Compatibility:** Maintains backward compatibility with existing setups
package/jest.setup.js DELETED
@@ -1,34 +0,0 @@
1
- require('@testing-library/jest-dom');
2
-
3
- const originalReadFileSync = require('fs').readFileSync;
4
- require('fs').readFileSync = jest.fn((path, encoding) => {
5
- if (path && path.toString().includes('package.json')) {
6
- return JSON.stringify({
7
- version: '1.0.0',
8
- dependencies: {
9
- esbuild: '^0.19.0',
10
- jest: '^29.0.0',
11
- typescript: '^5.0.0',
12
- webpack: '^5.0.0'
13
- }
14
- });
15
- }
16
- return originalReadFileSync(path, encoding);
17
- });
18
-
19
- global.ResizeObserver = jest.fn().mockImplementation(() => ({
20
- observe: jest.fn(),
21
- unobserve: jest.fn(),
22
- disconnect: jest.fn(),
23
- }));
24
-
25
- global.matchMedia = jest.fn().mockImplementation(query => ({
26
- matches: false,
27
- media: query,
28
- onchange: null,
29
- addListener: jest.fn(),
30
- removeListener: jest.fn(),
31
- addEventListener: jest.fn(),
32
- removeEventListener: jest.fn(),
33
- dispatchEvent: jest.fn(),
34
- }));