import { test, expect } from '@playwright/test'; import { importUser } from './testUtils'; test('Record an offer', async ({ page }) => { // Generate a random string of 3 characters, skipping the "0." at the beginning const randomString = Math.random().toString(36).substring(2, 5); // Standard title prefix const description = `Offering of ${randomString}`; const updatedDescription = `Updated ${description}`; const randomNonZeroNumber = Math.floor(Math.random() * 998) + 1; // Create new ID for default user await importUser(page); // Select a project await page.goto('./discover'); await page.getByTestId('closeOnboardingAndFinish').click(); await page.locator('ul#listDiscoverResults li:nth-child(1)').click(); // Record an offer await page.locator('button', { hasText: 'Edit' }).isVisible(); // since the 'edit' takes longer to show, wait for that (lest the click miss) await page.getByTestId('offerButton').click(); await page.getByTestId('inputDescription').fill(description); await page.getByTestId('inputOfferAmount').fill(randomNonZeroNumber.toString()); await page.getByRole('button', { name: 'Sign & Send' }).click(); await expect(page.getByText('That offer was recorded.')).toBeVisible(); // go to the offer and check the values await page.goto('./projects'); await page.getByRole('link', { name: 'Offers', exact: true }).click(); await page.locator('li').filter({ hasText: description }).locator('a').first().click(); await expect(page.getByRole('heading', { name: 'Verifiable Claim Details' })).toBeVisible(); await expect(page.getByText(description, { exact: true })).toBeVisible(); await expect(page.getByText('Offered to a bigger plan')).toBeVisible(); const serverPagePromise = page.waitForEvent('popup'); await page.getByRole('link', { name: 'View on the Public Server' }).click(); const serverPage = await serverPagePromise; await serverPage.getByText(description); await serverPage.getByText('did:none:HIDDEN'); // Now update that offer // find the edit page and check the old values again await page.goto('./projects'); await page.getByRole('link', { name: 'Offers', exact: true }).click(); await page.locator('li').filter({ hasText: description }).locator('a').first().click(); await page.getByTestId('editClaimButton').click(); await page.locator('heading', { hasText: 'What is offered' }).isVisible(); const itemDesc = await page.getByTestId('itemDescription'); await expect(itemDesc).toHaveValue(description); const amount = await page.getByTestId('inputOfferAmount'); await expect(amount).toHaveValue(randomNonZeroNumber.toString()); // update the values await itemDesc.fill(updatedDescription); await amount.fill(String(randomNonZeroNumber + 1)); await page.getByRole('button', { name: 'Sign & Send' }).click(); await expect(page.getByText('That offer was recorded.')).toBeVisible(); // go to the offer claim again and check the updated values await page.goto('./projects'); await page.getByRole('link', { name: 'Offers', exact: true }).click(); await page.locator('li').filter({ hasText: description }).locator('a').first().click(); const newItemDesc = await page.getByTestId('description'); await expect(newItemDesc).toHaveText(updatedDescription); // go to edit page await page.getByTestId('editClaimButton').click(); const newAmount = await page.getByTestId('inputOfferAmount'); await expect(newAmount).toHaveValue((randomNonZeroNumber + 1).toString()); });