From 4fef795ec726287447e9e65e77561778f9090adb Mon Sep 17 00:00:00 2001 From: Elliot Braem <16282460+elliotBraem@users.noreply.github.com> Date: Tue, 9 Apr 2024 11:12:26 -0400 Subject: [PATCH 1/2] fix tests wip --- .../widget/ModalDonation/AmountInput.jsx | 1 + playwright-tests/tests/donate.spec.js | 19 ++++++++++++++++--- playwright-tests/tests/pot.spec.js | 18 +++++++++++++----- playwright-tests/tests/pots.spec.js | 4 +++- 4 files changed, 33 insertions(+), 9 deletions(-) diff --git a/apps/potlock/widget/ModalDonation/AmountInput.jsx b/apps/potlock/widget/ModalDonation/AmountInput.jsx index c2383c94..7c5c8828 100644 --- a/apps/potlock/widget/ModalDonation/AmountInput.jsx +++ b/apps/potlock/widget/ModalDonation/AmountInput.jsx @@ -116,6 +116,7 @@ const AmountInput = (props) => { value={value} placeholder="0" onChange={(e) => HandleAmoutChange(e.target.value)} + name="amount" />
{" "} diff --git a/playwright-tests/tests/donate.spec.js b/playwright-tests/tests/donate.spec.js index 751e3d1d..bbd8cd49 100644 --- a/playwright-tests/tests/donate.spec.js +++ b/playwright-tests/tests/donate.spec.js @@ -9,19 +9,32 @@ test("should open donate modal", async ({ page }) => { test.setTimeout(120000); // 2 minutes... we want to improve performance await page.goto(`${ROOT_SRC}?tab=project&projectId=${DEFAULT_PROJECT_ID}`); await page.getByRole("button", { name: "Donate" }).click(); - expect(await page.isVisible("text=Donate to project")).toBeTruthy(); + expect(await page.isVisible("text=Donate to")).toBeTruthy(); }); test("project with no active pot should donate direct with correct amount", async ({ page }) => { test.setTimeout(120000); // 2 minutes... we want to improve performance + + // go to project page (PotLock project) await page.goto(`${ROOT_SRC}?tab=project&projectId=${DEFAULT_PROJECT_ID}`); + + // click donate button await page.getByRole("button", { name: "Donate" }).click(); - expect(await page.isVisible("text=Donate to project")).toBeTruthy(); + + // wait for modal to appear + expect(await page.isVisible("text=Donate to")).toBeTruthy(); + + // input amount await page.fill("input[name=amount]", "100"); - await page.getByRole("button", { name: "Donate" }).nth(1).click(); + + await page.getByRole("button", { name: "Proceed to Donate" }).nth(1).click(); + + // Confirm Donation + await page.getByRole("button", { name: "Confirm donation" }).click(); // Confirmation modal should be visible const transactionObj = JSON.parse(await page.locator("div.modal-body code").innerText()); + // check if transaction object is correct expect(transactionObj).toMatchObject({ bypass_protocol_fee: false, message: "", diff --git a/playwright-tests/tests/pot.spec.js b/playwright-tests/tests/pot.spec.js index e7befc8d..e7ad8968 100644 --- a/playwright-tests/tests/pot.spec.js +++ b/playwright-tests/tests/pot.spec.js @@ -6,13 +6,21 @@ import { test, expect } from "@playwright/test"; import { ROOT_SRC, DEFAULT_POT_ID } from "../util/constants"; test.beforeEach(async ({ page }) => { - await page.goto(`${ROOT_SRC}?tab=pot&potId=${DEFAULT_POT_ID}`); + await page.goto(`${ROOT_SRC}?tab=pot&potId=${DEFAULT_POT_ID}&nav=projects`); }); -test("clicking pot card should go to pot page", async ({ page }) => { - await page.getByText("NEAR Retroactive Builders").click(); +test("clicking project card should go to project page", async ({ page }) => { + test.setTimeout(120000); // 1 minute... we want to improve performance - const url = page.url(); + const projectSearchBar = await page.getByPlaceholder("Search projects"); - expect(url).toContain("?tab=pot&potId=build.v1.potfactory.potlock.near"); + await projectSearchBar.fill("magic"); + + const projectCard = page.getByText("MagicBuild"); + + await Promise.all([projectCard.click(), page.waitForLoadState("load")]); + + const projectUrl = page.url(); + + expect(projectUrl).toContain("?tab=project&projectId=magicbuild"); }); diff --git a/playwright-tests/tests/pots.spec.js b/playwright-tests/tests/pots.spec.js index 0470dfd5..be7ee868 100644 --- a/playwright-tests/tests/pots.spec.js +++ b/playwright-tests/tests/pots.spec.js @@ -10,7 +10,9 @@ test.beforeEach(async ({ page }) => { }); test("clicking pot card should go to pot page", async ({ page }) => { - await page.getByText("NEAR Retroactive Builders").click(); + const potCard = await page.getByText("NEAR Retroactive Builders"); + + await Promise.all([potCard.click(), page.waitForLoadState("load")]); const url = page.url(); From b7802c037bc56fcf660f367b1f85d93fe09a9805 Mon Sep 17 00:00:00 2001 From: Elliot Braem <16282460+elliotBraem@users.noreply.github.com> Date: Tue, 9 Apr 2024 11:19:47 -0400 Subject: [PATCH 2/2] working tests --- playwright-tests/tests/donate.spec.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/playwright-tests/tests/donate.spec.js b/playwright-tests/tests/donate.spec.js index bbd8cd49..bd932b5f 100644 --- a/playwright-tests/tests/donate.spec.js +++ b/playwright-tests/tests/donate.spec.js @@ -27,7 +27,7 @@ test("project with no active pot should donate direct with correct amount", asyn // input amount await page.fill("input[name=amount]", "100"); - await page.getByRole("button", { name: "Proceed to Donate" }).nth(1).click(); + await page.getByRole("button", { name: "Proceed to donate" }).click(); // Confirm Donation await page.getByRole("button", { name: "Confirm donation" }).click();