41 lines
1.4 KiB
TypeScript
41 lines
1.4 KiB
TypeScript
import { expect } from "@playwright/test";
|
|
|
|
import { test } from "../fixtures/fixtures";
|
|
import { todo, getEmbedIframe, bookFirstEvent, getBooking, deleteAllBookingsByEmail } from "../lib/testUtils";
|
|
|
|
test("should open embed iframe on click - Configured with light theme", async ({
|
|
page,
|
|
addEmbedListeners,
|
|
getActionFiredDetails,
|
|
}) => {
|
|
await deleteAllBookingsByEmail("embed-user@example.com");
|
|
|
|
const calNamespace = "prerendertestLightTheme";
|
|
await addEmbedListeners(calNamespace);
|
|
await page.goto("/?only=prerender-test");
|
|
let embedIframe = await getEmbedIframe({ page, pathname: "/free" });
|
|
expect(embedIframe).toBeFalsy();
|
|
|
|
await page.click('[data-cal-link="free?light&popup"]');
|
|
|
|
embedIframe = await getEmbedIframe({ page, pathname: "/free" });
|
|
|
|
expect(embedIframe).toBeEmbedCalLink(calNamespace, getActionFiredDetails, {
|
|
pathname: "/free",
|
|
});
|
|
expect(await page.screenshot()).toMatchSnapshot("event-types-list.png");
|
|
if (!embedIframe) {
|
|
throw new Error("Embed iframe not found");
|
|
}
|
|
const bookingId = await bookFirstEvent("free", embedIframe, page);
|
|
const booking = await getBooking(bookingId);
|
|
|
|
expect(booking.attendees.length).toBe(1);
|
|
await deleteAllBookingsByEmail("embed-user@example.com");
|
|
});
|
|
|
|
todo("Floating Button Test with Dark Theme");
|
|
|
|
todo("Floating Button Test with Light Theme");
|
|
|
|
todo("Add snapshot test for embed iframe");
|