You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
119 lines
6.1 KiB
119 lines
6.1 KiB
import { test, expect } from '@playwright/test';
|
|
import { switchToUser, getTestUserData, importUserFromAccount } from './testUtils';
|
|
|
|
test('New offers for another user', async ({ page }) => {
|
|
await page.goto('./');
|
|
|
|
// Get the auto-created DID from the HomeView
|
|
await page.waitForLoadState('networkidle');
|
|
const autoCreatedDid = await page.getAttribute('#Content', 'data-active-did');
|
|
|
|
if (!autoCreatedDid) {
|
|
throw new Error('Auto-created DID not found in HomeView');
|
|
}
|
|
|
|
await page.getByTestId('closeOnboardingAndFinish').click();
|
|
await expect(page.getByTestId('newDirectOffersActivityNumber')).toBeHidden();
|
|
|
|
// Become User Zero
|
|
await importUserFromAccount(page, "00");
|
|
|
|
// As User Zero, add the auto-created DID as a contact
|
|
await page.goto('./contacts');
|
|
await page.getByPlaceholder('URL or DID, Name, Public Key').fill(autoCreatedDid + ', A Friend');
|
|
await expect(page.locator('button > svg.fa-plus')).toBeVisible();
|
|
await page.locator('button > svg.fa-plus').click();
|
|
await page.locator('div[role="alert"]:has-text("Register") button:has-text("No")').click(); // don't register
|
|
await expect(page.locator('div[role="alert"] h4:has-text("Success")')).toBeVisible();
|
|
await page.locator('div[role="alert"] button > svg.fa-xmark').click(); // dismiss info alert
|
|
await expect(page.locator('div[role="alert"] button > svg.fa-xmark')).toBeHidden(); // ensure alert is gone
|
|
|
|
// Wait for any dialogs to appear and dismiss them systematically
|
|
await page.waitForTimeout(1000); // Give time for any dialogs to appear
|
|
|
|
// Check for and dismiss export dialog
|
|
const exportDialog = page.locator('div[role="alert"]:has-text("Export Your Data")');
|
|
if (await exportDialog.isVisible()) {
|
|
await page.locator('div[role="alert"]:has-text("Export Your Data") button:has-text("No, Not Now")').click();
|
|
await expect(exportDialog).toBeHidden();
|
|
await page.waitForTimeout(500);
|
|
}
|
|
|
|
// Check for any other modal overlays that might be blocking
|
|
const modalOverlay = page.locator('div[class*="bg-slate-900"]');
|
|
if (await modalOverlay.isVisible()) {
|
|
// Try to find and click any close buttons in the overlay
|
|
const closeButtons = page.locator('div[class*="bg-slate-900"] button');
|
|
if (await closeButtons.count() > 0) {
|
|
await closeButtons.first().click();
|
|
await page.waitForTimeout(500);
|
|
}
|
|
}
|
|
|
|
// Ensure no dialogs are blocking before proceeding
|
|
await page.waitForTimeout(1000);
|
|
|
|
// show buttons to make offers directly to people
|
|
await page.getByRole('button').filter({ hasText: /See Actions/i }).click();
|
|
|
|
// make an offer directly to user 1
|
|
// Generate a random string of 3 characters, skipping the "0." at the beginning
|
|
const randomString1 = Math.random().toString(36).substring(2, 5);
|
|
await page.getByTestId('offerButton').click();
|
|
await page.getByTestId('inputDescription').fill(`help of ${randomString1} from #000`);
|
|
await page.getByTestId('inputOfferAmount').locator('input').fill('1');
|
|
await page.getByRole('button', { name: 'Sign & Send' }).click();
|
|
await expect(page.getByText('That offer was recorded.')).toBeVisible();
|
|
await page.locator('div[role="alert"]:has-text("That offer was recorded") button > svg.fa-xmark').click(); // dismiss info alert
|
|
await expect(page.locator('div[role="alert"]:has-text("That offer was recorded") button > svg.fa-xmark')).toBeHidden(); // ensure alert is gone
|
|
|
|
// make another offer to user 1
|
|
const randomString2 = Math.random().toString(36).substring(2, 5);
|
|
await page.getByTestId('offerButton').click();
|
|
await page.getByTestId('inputDescription').fill(`help of ${randomString2} from #000`);
|
|
await page.getByTestId('inputOfferAmount').locator('input').fill('3');
|
|
await page.getByRole('button', { name: 'Sign & Send' }).click();
|
|
await expect(page.getByText('That offer was recorded.')).toBeVisible();
|
|
await page.locator('div[role="alert"]:has-text("That offer was recorded") button > svg.fa-xmark').click(); // dismiss info alert
|
|
await expect(page.locator('div[role="alert"]:has-text("That offer was recorded") button > svg.fa-xmark')).toBeHidden(); // ensure alert is gone
|
|
|
|
// Switch back to the auto-created DID (the "another user") to see the offers
|
|
await switchToUser(page, autoCreatedDid);
|
|
await page.goto('./');
|
|
let offerNumElem = page.getByTestId('newDirectOffersActivityNumber');
|
|
await expect(offerNumElem).toHaveText('2');
|
|
|
|
// click on the number of new offers to go to the list page
|
|
await offerNumElem.click();
|
|
|
|
await expect(page.getByText('New Offers To You', { exact: true })).toBeVisible();
|
|
await page.getByTestId('showOffersToUser').locator('div > svg.fa-chevron-right').click();
|
|
// note that they show in reverse chronologicalorder
|
|
await expect(page.getByText(`help of ${randomString2} from #000`)).toBeVisible();
|
|
await expect(page.getByText(`help of ${randomString1} from #000`)).toBeVisible();
|
|
|
|
// click on the latest offer to keep it as "unread"
|
|
await page.hover(`li:has-text("help of ${randomString2} from #000")`);
|
|
// await page.locator('li').filter({ hasText: `help of ${randomString2} from #000` }).click();
|
|
// await page.locator('div').filter({ hasText: /keep all above/ }).click();
|
|
// now find the "Click to keep all above as new offers" after that list item and click it
|
|
const liElem = page.locator('li').filter({ hasText: `help of ${randomString2} from #000` });
|
|
await liElem.hover();
|
|
const keepAboveAsNew = await liElem.locator('div').filter({ hasText: /keep all above/ });
|
|
|
|
await keepAboveAsNew.click();
|
|
|
|
// now see that only one offer is shown as new
|
|
await page.goto('./');
|
|
offerNumElem = page.getByTestId('newDirectOffersActivityNumber');
|
|
await expect(offerNumElem).toHaveText('1');
|
|
await offerNumElem.click();
|
|
await expect(page.getByText('New Offer To You', { exact: true })).toBeVisible();
|
|
await page.getByTestId('showOffersToUser').locator('div > svg.fa-chevron-right').click();
|
|
|
|
// now see that no offers are shown as new
|
|
await page.goto('./');
|
|
// wait until the list with ID listLatestActivity has at least one visible item
|
|
await page.locator('#listLatestActivity li').first().waitFor({ state: 'visible' });
|
|
await expect(page.getByTestId('newDirectOffersActivityNumber')).toBeHidden();
|
|
});
|
|
|