- 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>
47 lines
2.0 KiB
TypeScript
47 lines
2.0 KiB
TypeScript
/// <reference types="node" />
|
|
/// <reference types="node" />
|
|
/// <reference types="node" />
|
|
/// <reference types="node" />
|
|
import * as net from 'net';
|
|
import * as tls from 'tls';
|
|
import * as http from 'http';
|
|
import { Agent, AgentConnectOpts } from 'agent-base';
|
|
import { URL } from 'url';
|
|
import type { OutgoingHttpHeaders } from 'http';
|
|
type Protocol<T> = T extends `${infer Protocol}:${infer _}` ? Protocol : never;
|
|
type ConnectOptsMap = {
|
|
http: Omit<net.TcpNetConnectOpts, 'host' | 'port'>;
|
|
https: Omit<tls.ConnectionOptions, 'host' | 'port'>;
|
|
};
|
|
type ConnectOpts<T> = {
|
|
[P in keyof ConnectOptsMap]: Protocol<T> extends P ? ConnectOptsMap[P] : never;
|
|
}[keyof ConnectOptsMap];
|
|
export type HttpsProxyAgentOptions<T> = ConnectOpts<T> & http.AgentOptions & {
|
|
headers?: OutgoingHttpHeaders | (() => OutgoingHttpHeaders);
|
|
};
|
|
/**
|
|
* The `HttpsProxyAgent` implements an HTTP Agent subclass that connects to
|
|
* the specified "HTTP(s) proxy server" in order to proxy HTTPS requests.
|
|
*
|
|
* Outgoing HTTP requests are first tunneled through the proxy server using the
|
|
* `CONNECT` HTTP request method to establish a connection to the proxy server,
|
|
* and then the proxy server connects to the destination target and issues the
|
|
* HTTP request from the proxy server.
|
|
*
|
|
* `https:` requests have their socket connection upgraded to TLS once
|
|
* the connection to the proxy server has been established.
|
|
*/
|
|
export declare class HttpsProxyAgent<Uri extends string> extends Agent {
|
|
static protocols: readonly ["http", "https"];
|
|
readonly proxy: URL;
|
|
proxyHeaders: OutgoingHttpHeaders | (() => OutgoingHttpHeaders);
|
|
connectOpts: net.TcpNetConnectOpts & tls.ConnectionOptions;
|
|
constructor(proxy: Uri | URL, opts?: HttpsProxyAgentOptions<Uri>);
|
|
/**
|
|
* Called when the node-core HTTP client library is creating a
|
|
* new HTTP request.
|
|
*/
|
|
connect(req: http.ClientRequest, opts: AgentConnectOpts): Promise<net.Socket>;
|
|
}
|
|
export {};
|
|
//# sourceMappingURL=index.d.ts.map
|