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:
69
frontend/node_modules/data-urls/lib/parser.js
generated
vendored
Normal file
69
frontend/node_modules/data-urls/lib/parser.js
generated
vendored
Normal file
@@ -0,0 +1,69 @@
|
||||
"use strict";
|
||||
const MIMEType = require("whatwg-mimetype");
|
||||
const { parseURL, serializeURL, percentDecodeString } = require("whatwg-url");
|
||||
const { stripLeadingAndTrailingASCIIWhitespace, isomorphicDecode, forgivingBase64Decode } = require("./utils.js");
|
||||
|
||||
module.exports = stringInput => {
|
||||
const urlRecord = parseURL(stringInput);
|
||||
|
||||
if (urlRecord === null) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return module.exports.fromURLRecord(urlRecord);
|
||||
};
|
||||
|
||||
module.exports.fromURLRecord = urlRecord => {
|
||||
if (urlRecord.scheme !== "data") {
|
||||
return null;
|
||||
}
|
||||
|
||||
const input = serializeURL(urlRecord, true).substring("data:".length);
|
||||
|
||||
let position = 0;
|
||||
|
||||
let mimeType = "";
|
||||
while (position < input.length && input[position] !== ",") {
|
||||
mimeType += input[position];
|
||||
++position;
|
||||
}
|
||||
mimeType = stripLeadingAndTrailingASCIIWhitespace(mimeType);
|
||||
|
||||
if (position === input.length) {
|
||||
return null;
|
||||
}
|
||||
|
||||
++position;
|
||||
|
||||
const encodedBody = input.substring(position);
|
||||
|
||||
let body = percentDecodeString(encodedBody);
|
||||
|
||||
// Can't use /i regexp flag because it isn't restricted to ASCII.
|
||||
const mimeTypeBase64MatchResult = /(.*); *[Bb][Aa][Ss][Ee]64$/u.exec(mimeType);
|
||||
if (mimeTypeBase64MatchResult) {
|
||||
const stringBody = isomorphicDecode(body);
|
||||
body = forgivingBase64Decode(stringBody);
|
||||
|
||||
if (body === null) {
|
||||
return null;
|
||||
}
|
||||
mimeType = mimeTypeBase64MatchResult[1];
|
||||
}
|
||||
|
||||
if (mimeType.startsWith(";")) {
|
||||
mimeType = `text/plain${mimeType}`;
|
||||
}
|
||||
|
||||
let mimeTypeRecord;
|
||||
try {
|
||||
mimeTypeRecord = new MIMEType(mimeType);
|
||||
} catch (e) {
|
||||
mimeTypeRecord = new MIMEType("text/plain;charset=US-ASCII");
|
||||
}
|
||||
|
||||
return {
|
||||
mimeType: mimeTypeRecord,
|
||||
body
|
||||
};
|
||||
};
|
||||
20
frontend/node_modules/data-urls/lib/utils.js
generated
vendored
Normal file
20
frontend/node_modules/data-urls/lib/utils.js
generated
vendored
Normal file
@@ -0,0 +1,20 @@
|
||||
"use strict";
|
||||
|
||||
exports.stripLeadingAndTrailingASCIIWhitespace = string => {
|
||||
return string.replace(/^[ \t\n\f\r]+/u, "").replace(/[ \t\n\f\r]+$/u, "");
|
||||
};
|
||||
|
||||
exports.isomorphicDecode = input => {
|
||||
return Array.from(input, byte => String.fromCodePoint(byte)).join("");
|
||||
};
|
||||
|
||||
exports.forgivingBase64Decode = data => {
|
||||
let asString;
|
||||
try {
|
||||
asString = atob(data);
|
||||
} catch {
|
||||
return null;
|
||||
}
|
||||
|
||||
return Uint8Array.from(asString, c => c.codePointAt(0));
|
||||
};
|
||||
Reference in New Issue
Block a user