 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>
		
			
				
	
	
		
			89 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| const {signalsByName} = require('human-signals');
 | |
| 
 | |
| const getErrorPrefix = ({timedOut, timeout, errorCode, signal, signalDescription, exitCode, isCanceled}) => {
 | |
| 	if (timedOut) {
 | |
| 		return `timed out after ${timeout} milliseconds`;
 | |
| 	}
 | |
| 
 | |
| 	if (isCanceled) {
 | |
| 		return 'was canceled';
 | |
| 	}
 | |
| 
 | |
| 	if (errorCode !== undefined) {
 | |
| 		return `failed with ${errorCode}`;
 | |
| 	}
 | |
| 
 | |
| 	if (signal !== undefined) {
 | |
| 		return `was killed with ${signal} (${signalDescription})`;
 | |
| 	}
 | |
| 
 | |
| 	if (exitCode !== undefined) {
 | |
| 		return `failed with exit code ${exitCode}`;
 | |
| 	}
 | |
| 
 | |
| 	return 'failed';
 | |
| };
 | |
| 
 | |
| const makeError = ({
 | |
| 	stdout,
 | |
| 	stderr,
 | |
| 	all,
 | |
| 	error,
 | |
| 	signal,
 | |
| 	exitCode,
 | |
| 	command,
 | |
| 	escapedCommand,
 | |
| 	timedOut,
 | |
| 	isCanceled,
 | |
| 	killed,
 | |
| 	parsed: {options: {timeout}}
 | |
| }) => {
 | |
| 	// `signal` and `exitCode` emitted on `spawned.on('exit')` event can be `null`.
 | |
| 	// We normalize them to `undefined`
 | |
| 	exitCode = exitCode === null ? undefined : exitCode;
 | |
| 	signal = signal === null ? undefined : signal;
 | |
| 	const signalDescription = signal === undefined ? undefined : signalsByName[signal].description;
 | |
| 
 | |
| 	const errorCode = error && error.code;
 | |
| 
 | |
| 	const prefix = getErrorPrefix({timedOut, timeout, errorCode, signal, signalDescription, exitCode, isCanceled});
 | |
| 	const execaMessage = `Command ${prefix}: ${command}`;
 | |
| 	const isError = Object.prototype.toString.call(error) === '[object Error]';
 | |
| 	const shortMessage = isError ? `${execaMessage}\n${error.message}` : execaMessage;
 | |
| 	const message = [shortMessage, stderr, stdout].filter(Boolean).join('\n');
 | |
| 
 | |
| 	if (isError) {
 | |
| 		error.originalMessage = error.message;
 | |
| 		error.message = message;
 | |
| 	} else {
 | |
| 		error = new Error(message);
 | |
| 	}
 | |
| 
 | |
| 	error.shortMessage = shortMessage;
 | |
| 	error.command = command;
 | |
| 	error.escapedCommand = escapedCommand;
 | |
| 	error.exitCode = exitCode;
 | |
| 	error.signal = signal;
 | |
| 	error.signalDescription = signalDescription;
 | |
| 	error.stdout = stdout;
 | |
| 	error.stderr = stderr;
 | |
| 
 | |
| 	if (all !== undefined) {
 | |
| 		error.all = all;
 | |
| 	}
 | |
| 
 | |
| 	if ('bufferedData' in error) {
 | |
| 		delete error.bufferedData;
 | |
| 	}
 | |
| 
 | |
| 	error.failed = true;
 | |
| 	error.timedOut = Boolean(timedOut);
 | |
| 	error.isCanceled = isCanceled;
 | |
| 	error.killed = killed && !timedOut;
 | |
| 
 | |
| 	return error;
 | |
| };
 | |
| 
 | |
| module.exports = makeError;
 |