Set up comprehensive frontend testing infrastructure
- 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>
This commit is contained in:
		
							
								
								
									
										67
									
								
								frontend/node_modules/async/ensureAsync.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								frontend/node_modules/async/ensureAsync.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
| 'use strict'; | ||||
|  | ||||
| Object.defineProperty(exports, "__esModule", { | ||||
|     value: true | ||||
| }); | ||||
| exports.default = ensureAsync; | ||||
|  | ||||
| var _setImmediate = require('./internal/setImmediate.js'); | ||||
|  | ||||
| var _setImmediate2 = _interopRequireDefault(_setImmediate); | ||||
|  | ||||
| var _wrapAsync = require('./internal/wrapAsync.js'); | ||||
|  | ||||
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||||
|  | ||||
| /** | ||||
|  * Wrap an async function and ensure it calls its callback on a later tick of | ||||
|  * the event loop.  If the function already calls its callback on a next tick, | ||||
|  * no extra deferral is added. This is useful for preventing stack overflows | ||||
|  * (`RangeError: Maximum call stack size exceeded`) and generally keeping | ||||
|  * [Zalgo](http://blog.izs.me/post/59142742143/designing-apis-for-asynchrony) | ||||
|  * contained. ES2017 `async` functions are returned as-is -- they are immune | ||||
|  * to Zalgo's corrupting influences, as they always resolve on a later tick. | ||||
|  * | ||||
|  * @name ensureAsync | ||||
|  * @static | ||||
|  * @memberOf module:Utils | ||||
|  * @method | ||||
|  * @category Util | ||||
|  * @param {AsyncFunction} fn - an async function, one that expects a node-style | ||||
|  * callback as its last argument. | ||||
|  * @returns {AsyncFunction} Returns a wrapped function with the exact same call | ||||
|  * signature as the function passed in. | ||||
|  * @example | ||||
|  * | ||||
|  * function sometimesAsync(arg, callback) { | ||||
|  *     if (cache[arg]) { | ||||
|  *         return callback(null, cache[arg]); // this would be synchronous!! | ||||
|  *     } else { | ||||
|  *         doSomeIO(arg, callback); // this IO would be asynchronous | ||||
|  *     } | ||||
|  * } | ||||
|  * | ||||
|  * // this has a risk of stack overflows if many results are cached in a row | ||||
|  * async.mapSeries(args, sometimesAsync, done); | ||||
|  * | ||||
|  * // this will defer sometimesAsync's callback if necessary, | ||||
|  * // preventing stack overflows | ||||
|  * async.mapSeries(args, async.ensureAsync(sometimesAsync), done); | ||||
|  */ | ||||
| function ensureAsync(fn) { | ||||
|     if ((0, _wrapAsync.isAsync)(fn)) return fn; | ||||
|     return function (...args /*, callback*/) { | ||||
|         var callback = args.pop(); | ||||
|         var sync = true; | ||||
|         args.push((...innerArgs) => { | ||||
|             if (sync) { | ||||
|                 (0, _setImmediate2.default)(() => callback(...innerArgs)); | ||||
|             } else { | ||||
|                 callback(...innerArgs); | ||||
|             } | ||||
|         }); | ||||
|         fn.apply(this, args); | ||||
|         sync = false; | ||||
|     }; | ||||
| } | ||||
| module.exports = exports.default; | ||||
		Reference in New Issue
	
	Block a user
	 anthonyrawlins
					anthonyrawlins