|
1 | 1 | import { expect, test } from "@playwright/test"; |
| 2 | +import { HOST_EMAIL, signIn } from "./helpers"; |
2 | 3 |
|
3 | 4 | test("homepage hydrates without chat date mismatches", async ({ |
4 | 5 | browser, |
@@ -108,3 +109,57 @@ test("homepage drop-off only shows curated featured hosts", async ({ |
108 | 109 | page.getByTestId("homepage-featured-host-demo-newtown-worm-farm") |
109 | 110 | ).toHaveCount(0); |
110 | 111 | }); |
| 112 | + |
| 113 | +test("homepage account button stays hidden while signed-in profile state loads", async ({ |
| 114 | + page, |
| 115 | +}) => { |
| 116 | + await signIn(page, { email: HOST_EMAIL, redirectTo: "/profile" }); |
| 117 | + |
| 118 | + let resolveProfileRequest = () => {}; |
| 119 | + const profileRequestStarted = new Promise<void>((resolve) => { |
| 120 | + resolveProfileRequest = resolve; |
| 121 | + }); |
| 122 | + let continueProfileRequest = () => {}; |
| 123 | + const profileRequestCanContinue = new Promise<void>((resolve) => { |
| 124 | + continueProfileRequest = resolve; |
| 125 | + }); |
| 126 | + |
| 127 | + await page.route(/\/rest\/v1\/profiles(?:\?|$)/, async (route) => { |
| 128 | + const request = route.request(); |
| 129 | + |
| 130 | + if ( |
| 131 | + request.method() === "GET" && |
| 132 | + request.url().includes("select=first_name") |
| 133 | + ) { |
| 134 | + resolveProfileRequest(); |
| 135 | + await profileRequestCanContinue; |
| 136 | + } |
| 137 | + |
| 138 | + await route.continue(); |
| 139 | + }); |
| 140 | + |
| 141 | + await page.goto("/", { waitUntil: "domcontentloaded" }); |
| 142 | + await profileRequestStarted; |
| 143 | + |
| 144 | + try { |
| 145 | + await expect(page.getByTestId("account-button-profile")).toHaveCount(0); |
| 146 | + await expect(page.getByTestId("account-button-sign-in")).toHaveCount(0); |
| 147 | + } finally { |
| 148 | + continueProfileRequest(); |
| 149 | + } |
| 150 | + |
| 151 | + const profileAccountButton = page.getByTestId("account-button-profile"); |
| 152 | + |
| 153 | + await expect(profileAccountButton).toHaveAttribute("href", "/profile"); |
| 154 | + await expect(profileAccountButton).toHaveCSS("opacity", "1"); |
| 155 | +}); |
| 156 | + |
| 157 | +test("homepage account button links guests to sign in", async ({ page }) => { |
| 158 | + await page.goto("/", { waitUntil: "domcontentloaded" }); |
| 159 | + |
| 160 | + await expect(page.getByTestId("account-button-sign-in")).toHaveAttribute( |
| 161 | + "href", |
| 162 | + "/sign-in" |
| 163 | + ); |
| 164 | + await expect(page.getByTestId("account-button-profile")).toHaveCount(0); |
| 165 | +}); |
0 commit comments