mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-22 03:10:15 +01:00
* feat: add zod schemas for better type safety * refactor(useSetOptions): remove 'as Type' in favor of zod schema * fix: descendant console error, change <p> tag to <div> tag for content in PluginTooltip component * style(MessagesView): instant/snappier scroll behavior matching official site * fix(Messages): add null check for scrollableRef before accessing its properties in handleScroll and useEffect * fix(messageSchema.js): change type of invocationId from string to number fix(schemas.ts): make authenticated property in tPluginSchema optional fix(schemas.ts): make isButton property in tPluginSchema optional fix(schemas.ts): make messages property in tConversationSchema optional and change its type to array of strings fix(schemas.ts): make systemMessage property in tConversationSchema nullable and optional fix(schemas.ts): make modelLabel property in tConversationSchema nullable and optional fix(schemas.ts): make chatGptLabel property in tConversationSchema nullable and optional fix(schemas.ts): make promptPrefix property in tConversationSchema nullable and optional fix(schemas.ts): make context property in tConversationSchema nullable and optional fix(schemas.ts): make jailbreakConversationId property in tConversationSchema nullable and optional fix(schemas.ts): make conversationSignature property in tConversationSchema nullable and optional fix(schemas.ts): make clientId property * refactor(types): replace main types with zod schemas and inferred types * refactor(types/schemas): use schemas for better type safety of main types * style(ModelSelect/Buttons): remove shadow and transition * style(ModelSelect): button changes to closer match OpenAI * style(ModelSelect): remove green rings which flicker * style(scrollToBottom): add two separate scrolling functions * fix(OptionsBar.tsx): handle onFocus and onBlur events to update opacityClass fix(Messages/index.jsx): increase debounce time for scrollIntoView function
37 lines
1.4 KiB
TypeScript
37 lines
1.4 KiB
TypeScript
import { Page, FullConfig, chromium } from '@playwright/test';
|
|
|
|
type User = { username: string; password: string };
|
|
|
|
async function login(page: Page, user: User) {
|
|
await page.locator('input[name="email"]').fill(user.username);
|
|
await page.locator('input[name="password"]').fill(user.password);
|
|
await page.locator('button[type="submit"]').click();
|
|
}
|
|
|
|
async function authenticate(config: FullConfig, user: User) {
|
|
console.log('🤖: global setup has been started');
|
|
const { baseURL, storageState } = config.projects[0].use;
|
|
console.log('🤖: using baseURL', baseURL);
|
|
const browser = await chromium.launch();
|
|
const page = await browser.newPage();
|
|
console.log('🤖: 🗝 authenticating user:', user.username);
|
|
|
|
if (!baseURL) {
|
|
throw new Error('🤖: baseURL is not defined');
|
|
}
|
|
await page.goto(baseURL);
|
|
await login(page, user);
|
|
await page.locator('h1:has-text("LibreChat")').waitFor();
|
|
console.log('🤖: ✔️ user successfully authenticated');
|
|
// Set localStorage before navigating to the page
|
|
await page.context().addInitScript(() => {
|
|
localStorage.setItem('navVisible', 'true');
|
|
});
|
|
console.log('🤖: ✔️ localStorage: set Nav as Visible', storageState);
|
|
await page.context().storageState({ path: storageState as string });
|
|
console.log('🤖: ✔️ authentication state successfully saved in', storageState);
|
|
await browser.close();
|
|
console.log('🤖: global setup has been finished');
|
|
}
|
|
|
|
export default authenticate;
|