♻️ (playwright.config.ts): set headless to false for better debugging ♻️ (addNewVariableButton.tsx): add data-testid to save button for testing 🐛 (addNewVariableButton.tsx): fix optional chaining in error handling ♻️ (sideBarFolderButtons/index.tsx): add data-testid to input for testing ♻️ (sideBarFolderButtons/index.tsx): remove unnecessary commas 🐛 (api.tsx): fix duplicate request check to include method "get" ♻️ (api.tsx): remove unnecessary commas in function calls ♻️ (index.tsx): reorder import statements for better readability 💡 (index.tsx): remove trailing commas to adhere to coding standards ✅ (chatInputOutput.spec.ts): update file path for ChatTest.json for consistency 🐛 (darkStore.ts): add null check for GitHub stars to prevent potential errors ✅ (tests): update chatInputOutputUser.spec.ts to add new test for output inspection 🔧 (tests): fix path for collection.json in dragAndDrop.spec.ts ✅ (filterEdge.spec.ts): fix locator strings and remove redundant code ✅ (floatComponent.spec.ts): correct checkbox state expectations and remove redundant tests ✅ (folders.spec.ts): update folder creation and editing flow for consistency ✅ (globalVariables.spec.ts): remove redundant 'Save Variable' click action ✅ (inputComponent.spec.ts): fix incorrect locator for server port and improve readability ✅ (intComponent.spec.ts): add additional test steps for more options modal ✅ (saveComponents.spec.ts): update file path for flow_group_test.json
146 lines
5.5 KiB
TypeScript
146 lines
5.5 KiB
TypeScript
import { expect, test } from "@playwright/test";
|
|
|
|
test("user must interact with chat with Input/Output", async ({ page }) => {
|
|
if (!process.env.CI) {
|
|
dotenv.config();
|
|
dotenv.config({ path: path.resolve(__dirname, "../../.env") });
|
|
}
|
|
|
|
await page.goto("/");
|
|
|
|
await page.waitForTimeout(1000);
|
|
|
|
let modalCount = 0;
|
|
try {
|
|
const modalTitleElement = await page?.getByTestId("modal-title");
|
|
if (modalTitleElement) {
|
|
modalCount = await modalTitleElement.count();
|
|
}
|
|
} catch (error) {
|
|
modalCount = 0;
|
|
}
|
|
|
|
while (modalCount === 0) {
|
|
await page.getByText("New Project", { exact: true }).click();
|
|
await page.waitForTimeout(5000);
|
|
modalCount = await page.getByTestId("modal-title")?.count();
|
|
}
|
|
|
|
await page.getByRole("heading", { name: "Basic Prompting" }).click();
|
|
await page.waitForTimeout(1000);
|
|
|
|
await page.getByTitle("fit view").click();
|
|
await page.getByTitle("zoom out").click();
|
|
await page.getByTitle("zoom out").click();
|
|
await page.getByTitle("zoom out").click();
|
|
|
|
if (!process.env.OPENAI_API_KEY) {
|
|
//You must set the OPENAI_API_KEY on .env file to run this test
|
|
expect(false).toBe(true);
|
|
}
|
|
|
|
await page
|
|
.getByTestId("popover-anchor-input-openai_api_key")
|
|
.fill(process.env.OPENAI_API_KEY ?? "");
|
|
await page.getByText("Playground", { exact: true }).click();
|
|
await page.getByPlaceholder("Send a message...").fill("Hello, how are you?");
|
|
await page.getByTestId("icon-LucideSend").click();
|
|
let valueUser = await page.getByTestId("sender_name_user").textContent();
|
|
let valueAI = await page.getByTestId("sender_name_ai").textContent();
|
|
|
|
expect(valueUser).toBe("User");
|
|
expect(valueAI).toBe("AI");
|
|
|
|
await page.keyboard.press("Escape");
|
|
|
|
await page
|
|
.getByTestId("textarea-input_value")
|
|
.nth(1)
|
|
.fill(
|
|
"testtesttesttesttesttestte;.;.,;,.;,.;.,;,..,;;;;;;;;;;;;;;;;;;;;;,;.;,.;,.,;.,;.;.,~~çççççççççççççççççççççççççççççççççççççççisdajfdasiopjfaodisjhvoicxjiovjcxizopjviopasjioasfhjaiohf23432432432423423sttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttestççççççççççççççççççççççççççççççççç,.,.,.,.,.,.,.,.,.,.,.,.,.,.,.,.,!",
|
|
);
|
|
await page
|
|
.getByTestId("popover-anchor-input-sender_name")
|
|
.nth(1)
|
|
.fill("TestSenderNameUser");
|
|
await page
|
|
.getByTestId("popover-anchor-input-sender_name")
|
|
.nth(0)
|
|
.fill("TestSenderNameAI");
|
|
|
|
await page.getByText("Playground", { exact: true }).click();
|
|
await page.getByTestId("icon-LucideSend").click();
|
|
|
|
valueUser = await page
|
|
.getByTestId("sender_name_testsendernameuser")
|
|
.textContent();
|
|
valueAI = await page
|
|
.getByTestId("sender_name_testsendernameai")
|
|
.textContent();
|
|
|
|
expect(valueUser).toBe("TestSenderNameUser");
|
|
expect(valueAI).toBe("TestSenderNameAI");
|
|
|
|
expect(
|
|
await page
|
|
.getByText(
|
|
"testtesttesttesttesttestte;.;.,;,.;,.;.,;,..,;;;;;;;;;;;;;;;;;;;;;,;.;,.;,.,;.,;.;.,~~çççççççççççççççççççççççççççççççççççççççisdajfdasiopjfaodisjhvoicxjiovjcxizopjviopasjioasfhjaiohf23432432432423423sttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttestççççççççççççççççççççççççççççççççç,.,.,.,.,.,.,.,.,.,.,.,.,.,.,.,.,!",
|
|
{ exact: true },
|
|
)
|
|
.isVisible(),
|
|
);
|
|
});
|
|
|
|
test("user must be able to see output inspection", async ({ page }) => {
|
|
if (!process.env.CI) {
|
|
dotenv.config();
|
|
dotenv.config({ path: path.resolve(__dirname, "../../.env") });
|
|
}
|
|
|
|
await page.goto("/");
|
|
|
|
await page.waitForTimeout(1000);
|
|
|
|
let modalCount = 0;
|
|
try {
|
|
const modalTitleElement = await page?.getByTestId("modal-title");
|
|
if (modalTitleElement) {
|
|
modalCount = await modalTitleElement.count();
|
|
}
|
|
} catch (error) {
|
|
modalCount = 0;
|
|
}
|
|
|
|
while (modalCount === 0) {
|
|
await page.getByText("New Project", { exact: true }).click();
|
|
await page.waitForTimeout(5000);
|
|
modalCount = await page.getByTestId("modal-title")?.count();
|
|
}
|
|
|
|
await page.getByRole("heading", { name: "Basic Prompting" }).click();
|
|
await page.waitForTimeout(1000);
|
|
|
|
await page.getByTitle("fit view").click();
|
|
await page.getByTitle("zoom out").click();
|
|
await page.getByTitle("zoom out").click();
|
|
await page.getByTitle("zoom out").click();
|
|
|
|
if (!process.env.OPENAI_API_KEY) {
|
|
//You must set the OPENAI_API_KEY on .env file to run this test
|
|
expect(false).toBe(true);
|
|
}
|
|
|
|
await page
|
|
.getByTestId("popover-anchor-input-openai_api_key")
|
|
.fill(process.env.OPENAI_API_KEY ?? "");
|
|
|
|
await page.getByTestId("button_run_chat output").last().click();
|
|
|
|
await page.waitForTimeout(2000);
|
|
|
|
await page.getByTestId("icon-ScanEye").last().click();
|
|
|
|
const textAreaOutputValue = await page.getByPlaceholder("Empty").inputValue();
|
|
expect(textAreaOutputValue).not.toBe("");
|
|
expect(textAreaOutputValue).not.toBe(null);
|
|
});
|