mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-05-12 08:50:17 +00:00
## Summary <!-- One sentence describing what changed and why. --> Polish and fix UI for new website ## Changes - **What**: <!-- Core functionality added/modified --> - [x] update about video - [x] update Moment factory story content - [x] update homepage visual - [x] update customer story visual - [x] put images and videos to bucket ## Review Focus <!-- Critical design decisions or edge cases that need attention --> <!-- If this PR fixes an issue, uncomment and update the line below --> <!-- Fixes #ISSUE_NUMBER --> ## Screenshots (if applicable) <!-- Add screenshots or video recording to help explain your changes --> ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-11363-feat-website-Polish-and-fix-UI-3466d73d365081f895aff84b594450c9) by [Unito](https://www.unito.io) --------- Co-authored-by: DrJKL <DrJKL0424@gmail.com> Co-authored-by: Amp <amp@ampcode.com> Co-authored-by: GitHub Action <action@github.com> Co-authored-by: Alexander Brown <drjkl@comfy.org> Co-authored-by: github-actions <github-actions@github.com>
144 lines
4.6 KiB
TypeScript
144 lines
4.6 KiB
TypeScript
import { expect } from '@playwright/test'
|
|
|
|
import { test } from './fixtures/blockExternalMedia'
|
|
|
|
test.describe('Cloud page @smoke', () => {
|
|
test.beforeEach(async ({ page }) => {
|
|
await page.goto('/cloud')
|
|
})
|
|
|
|
test('has correct title', async ({ page }) => {
|
|
await expect(page).toHaveTitle('Comfy Cloud — AI in the Cloud')
|
|
})
|
|
|
|
test('HeroSection heading and subtitle are visible', async ({ page }) => {
|
|
await expect(
|
|
page.getByRole('heading', { name: /The full power of/i, level: 1 })
|
|
).toBeVisible()
|
|
await expect(
|
|
page.getByText(/The easiest way to start with ComfyUI/)
|
|
).toBeVisible()
|
|
})
|
|
|
|
test('HeroSection has CTA button linking to cloud', async ({ page }) => {
|
|
const cta = page.getByRole('link', { name: /TRY COMFY CLOUD FOR FREE/i })
|
|
await expect(cta).toBeVisible()
|
|
})
|
|
|
|
test('ReasonSection heading and reasons are visible', async ({ page }) => {
|
|
await expect(
|
|
page.getByRole('heading', { name: /Why.*professionals.*choose/i })
|
|
).toBeVisible()
|
|
|
|
for (const title of [
|
|
'Powerful GPUs',
|
|
'All models',
|
|
'More control',
|
|
'Community workflows'
|
|
]) {
|
|
await expect(page.getByText(title).first()).toBeVisible()
|
|
}
|
|
})
|
|
|
|
test('AIModelsSection heading and 5 model cards are visible', async ({
|
|
page
|
|
}) => {
|
|
const heading = page.getByRole('heading', { name: /leading AI models/i })
|
|
await expect(heading).toBeVisible()
|
|
|
|
const section = heading.locator('xpath=ancestor::section')
|
|
const grid = section.locator('.grid')
|
|
const modelCards = grid.locator('a[href="https://comfy.org/workflows"]')
|
|
await expect(modelCards).toHaveCount(5)
|
|
})
|
|
|
|
test('AIModelsSection CTA links to workflows', async ({ page }) => {
|
|
const cta = page.getByRole('link', {
|
|
name: /EXPLORE WORKFLOWS/i
|
|
})
|
|
await expect(cta.first()).toBeVisible()
|
|
await expect(cta.first()).toHaveAttribute(
|
|
'href',
|
|
'https://comfy.org/workflows'
|
|
)
|
|
})
|
|
|
|
test('AudienceSection heading and cards are visible', async ({ page }) => {
|
|
await expect(page.getByText(/creators/i).first()).toBeVisible()
|
|
|
|
for (const label of ['CREATORS', 'TEAMS & STUDIOS']) {
|
|
await expect(page.getByText(label).first()).toBeVisible()
|
|
}
|
|
})
|
|
|
|
test('PricingSection heading and CTA are visible', async ({ page }) => {
|
|
await expect(page.getByText(/Simple, credit-based pricing/)).toBeVisible()
|
|
|
|
const cta = page.getByRole('link', { name: /SEE PRICING PLANS/i })
|
|
await expect(cta).toBeVisible()
|
|
await expect(cta).toHaveAttribute('href', '/cloud/pricing')
|
|
})
|
|
|
|
test('ProductCardsSection has 3 product cards', async ({ page }) => {
|
|
const section = page.locator('section', {
|
|
has: page.getByRole('heading', { name: /The AI creation/ })
|
|
})
|
|
const cards = section.locator('a[href]')
|
|
await expect(cards).toHaveCount(3)
|
|
})
|
|
|
|
test('FAQSection heading is visible with 15 items', async ({ page }) => {
|
|
await expect(page.getByRole('heading', { name: /FAQ/i })).toBeVisible()
|
|
|
|
const faqButtons = page.locator('button[aria-controls^="faq-panel-"]')
|
|
await expect(faqButtons).toHaveCount(15)
|
|
})
|
|
})
|
|
|
|
test.describe('Cloud FAQ accordion @interaction', () => {
|
|
test.beforeEach(async ({ page }) => {
|
|
await page.goto('/cloud')
|
|
})
|
|
|
|
test('all FAQs are collapsed by default', async ({ page }) => {
|
|
await expect(
|
|
page.getByText(/Comfy Cloud is a version of ComfyUI/i)
|
|
).toBeHidden()
|
|
})
|
|
|
|
test('clicking a collapsed FAQ expands it', async ({ page }) => {
|
|
const firstQuestion = page.getByRole('button', {
|
|
name: /What is Comfy Cloud/i
|
|
})
|
|
await firstQuestion.scrollIntoViewIfNeeded()
|
|
// Gate: wait for Vue hydration to bind aria-expanded
|
|
await expect(firstQuestion).toHaveAttribute('aria-expanded', 'false')
|
|
await firstQuestion.click()
|
|
|
|
await expect(
|
|
page.getByText(/Comfy Cloud is a version of ComfyUI/i)
|
|
).toBeVisible()
|
|
})
|
|
|
|
test('clicking an expanded FAQ collapses it again', async ({ page }) => {
|
|
const firstQuestion = page.getByRole('button', {
|
|
name: /What is Comfy Cloud/i
|
|
})
|
|
await firstQuestion.scrollIntoViewIfNeeded()
|
|
// Gate: wait for Vue hydration to bind aria-expanded
|
|
await expect(firstQuestion).toHaveAttribute('aria-expanded', 'false')
|
|
|
|
await firstQuestion.click()
|
|
await expect(firstQuestion).toHaveAttribute('aria-expanded', 'true')
|
|
await expect(
|
|
page.getByText(/Comfy Cloud is a version of ComfyUI/i)
|
|
).toBeVisible()
|
|
|
|
await firstQuestion.click()
|
|
await expect(firstQuestion).toHaveAttribute('aria-expanded', 'false')
|
|
await expect(
|
|
page.getByText(/Comfy Cloud is a version of ComfyUI/i)
|
|
).toBeHidden()
|
|
})
|
|
})
|