Connects to user's running Brave via Chrome DevTools Protocol to automate ChatGPT interaction. Uses puppeteer-core to open a tab, send the prompt, wait for response, and extract the result. No cookies, no separate profiles, no copy/paste. Just connects to the browser where the user is already logged in. One-time setup: relaunch Brave with --remote-debugging-port=9222 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
30 lines
778 B
TypeScript
30 lines
778 B
TypeScript
// @ts-ignore TS6133
|
||
import { expect, test } from "vitest";
|
||
|
||
import * as z from "zod/v3";
|
||
|
||
const RealSet = Set;
|
||
const RealMap = Map;
|
||
const RealDate = Date;
|
||
|
||
test("doesn’t throw when Date is undefined", () => {
|
||
delete (globalThis as any).Date;
|
||
const result = z.object({}).safeParse({});
|
||
expect(result.success).toEqual(true);
|
||
globalThis.Date = RealDate;
|
||
});
|
||
|
||
test("doesn’t throw when Set is undefined", () => {
|
||
delete (globalThis as any).Set;
|
||
const result = z.object({}).safeParse({});
|
||
expect(result.success).toEqual(true);
|
||
globalThis.Set = RealSet;
|
||
});
|
||
|
||
test("doesn’t throw when Map is undefined", () => {
|
||
delete (globalThis as any).Map;
|
||
const result = z.object({}).safeParse({});
|
||
expect(result.success).toEqual(true);
|
||
globalThis.Map = RealMap;
|
||
});
|