 aacb45156b
			
		
	
	aacb45156b
	
	
	
		
			
			- Install Jest for unit testing with React Testing Library - Install Playwright for end-to-end testing - Configure Jest with proper TypeScript support and module mapping - Create test setup files and utilities for both unit and e2e tests Components: * Jest configuration with coverage thresholds * Playwright configuration with browser automation * Unit tests for LoginForm, AuthContext, and useSocketIO hook * E2E tests for authentication, dashboard, and agents workflows * GitHub Actions workflow for automated testing * Mock data and API utilities for consistent testing * Test documentation with best practices Testing features: - Unit tests with 70% coverage threshold - E2E tests with API mocking and user journey testing - CI/CD integration for automated test runs - Cross-browser testing support with Playwright - Authentication system testing end-to-end 🚀 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
		
			
				
	
	
		
			130 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| var __create = Object.create;
 | |
| var __defProp = Object.defineProperty;
 | |
| var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
 | |
| var __getOwnPropNames = Object.getOwnPropertyNames;
 | |
| var __getProtoOf = Object.getPrototypeOf;
 | |
| var __hasOwnProp = Object.prototype.hasOwnProperty;
 | |
| var __export = (target, all) => {
 | |
|   for (var name in all)
 | |
|     __defProp(target, name, { get: all[name], enumerable: true });
 | |
| };
 | |
| var __copyProps = (to, from, except, desc) => {
 | |
|   if (from && typeof from === "object" || typeof from === "function") {
 | |
|     for (let key of __getOwnPropNames(from))
 | |
|       if (!__hasOwnProp.call(to, key) && key !== except)
 | |
|         __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
 | |
|   }
 | |
|   return to;
 | |
| };
 | |
| var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
 | |
|   // If the importer is in node compatibility mode or this is not an ESM
 | |
|   // file that has been converted to a CommonJS file using a Babel-
 | |
|   // compatible transform (i.e. "__esModule" has not been set), then set
 | |
|   // "default" to the CommonJS "module.exports" for node compatibility.
 | |
|   isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
 | |
|   mod
 | |
| ));
 | |
| var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
 | |
| var internalReporter_exports = {};
 | |
| __export(internalReporter_exports, {
 | |
|   InternalReporter: () => InternalReporter
 | |
| });
 | |
| module.exports = __toCommonJS(internalReporter_exports);
 | |
| var import_fs = __toESM(require("fs"));
 | |
| var import_utils = require("playwright-core/lib/utils");
 | |
| var import_base = require("./base");
 | |
| var import_multiplexer = require("./multiplexer");
 | |
| var import_test = require("../common/test");
 | |
| var import_babelBundle = require("../transform/babelBundle");
 | |
| class InternalReporter {
 | |
|   constructor(reporters) {
 | |
|     this._didBegin = false;
 | |
|     this._reporter = new import_multiplexer.Multiplexer(reporters);
 | |
|   }
 | |
|   version() {
 | |
|     return "v2";
 | |
|   }
 | |
|   onConfigure(config) {
 | |
|     this._config = config;
 | |
|     this._startTime = /* @__PURE__ */ new Date();
 | |
|     this._monotonicStartTime = (0, import_utils.monotonicTime)();
 | |
|     this._reporter.onConfigure?.(config);
 | |
|   }
 | |
|   onBegin(suite) {
 | |
|     this._didBegin = true;
 | |
|     this._reporter.onBegin?.(suite);
 | |
|   }
 | |
|   onTestBegin(test, result) {
 | |
|     this._reporter.onTestBegin?.(test, result);
 | |
|   }
 | |
|   onStdOut(chunk, test, result) {
 | |
|     this._reporter.onStdOut?.(chunk, test, result);
 | |
|   }
 | |
|   onStdErr(chunk, test, result) {
 | |
|     this._reporter.onStdErr?.(chunk, test, result);
 | |
|   }
 | |
|   onTestEnd(test, result) {
 | |
|     this._addSnippetToTestErrors(test, result);
 | |
|     this._reporter.onTestEnd?.(test, result);
 | |
|   }
 | |
|   async onEnd(result) {
 | |
|     if (!this._didBegin) {
 | |
|       this.onBegin(new import_test.Suite("", "root"));
 | |
|     }
 | |
|     return await this._reporter.onEnd?.({
 | |
|       ...result,
 | |
|       startTime: this._startTime,
 | |
|       duration: (0, import_utils.monotonicTime)() - this._monotonicStartTime
 | |
|     });
 | |
|   }
 | |
|   async onExit() {
 | |
|     await this._reporter.onExit?.();
 | |
|   }
 | |
|   onError(error) {
 | |
|     addLocationAndSnippetToError(this._config, error);
 | |
|     this._reporter.onError?.(error);
 | |
|   }
 | |
|   onStepBegin(test, result, step) {
 | |
|     this._reporter.onStepBegin?.(test, result, step);
 | |
|   }
 | |
|   onStepEnd(test, result, step) {
 | |
|     this._addSnippetToStepError(test, step);
 | |
|     this._reporter.onStepEnd?.(test, result, step);
 | |
|   }
 | |
|   printsToStdio() {
 | |
|     return this._reporter.printsToStdio ? this._reporter.printsToStdio() : true;
 | |
|   }
 | |
|   _addSnippetToTestErrors(test, result) {
 | |
|     for (const error of result.errors)
 | |
|       addLocationAndSnippetToError(this._config, error, test.location.file);
 | |
|   }
 | |
|   _addSnippetToStepError(test, step) {
 | |
|     if (step.error)
 | |
|       addLocationAndSnippetToError(this._config, step.error, test.location.file);
 | |
|   }
 | |
| }
 | |
| function addLocationAndSnippetToError(config, error, file) {
 | |
|   if (error.stack && !error.location)
 | |
|     error.location = (0, import_base.prepareErrorStack)(error.stack).location;
 | |
|   const location = error.location;
 | |
|   if (!location)
 | |
|     return;
 | |
|   try {
 | |
|     const tokens = [];
 | |
|     const source = import_fs.default.readFileSync(location.file, "utf8");
 | |
|     const codeFrame = (0, import_babelBundle.codeFrameColumns)(source, { start: location }, { highlightCode: true });
 | |
|     if (!file || import_fs.default.realpathSync(file) !== location.file) {
 | |
|       tokens.push(import_base.internalScreen.colors.gray(`   at `) + `${(0, import_base.relativeFilePath)(import_base.internalScreen, config, location.file)}:${location.line}`);
 | |
|       tokens.push("");
 | |
|     }
 | |
|     tokens.push(codeFrame);
 | |
|     error.snippet = tokens.join("\n");
 | |
|   } catch (e) {
 | |
|   }
 | |
| }
 | |
| // Annotate the CommonJS export names for ESM import in node:
 | |
| 0 && (module.exports = {
 | |
|   InternalReporter
 | |
| });
 |