|
| 1 | +import { expect, test } from '@playwright/test'; |
| 2 | + |
| 3 | +test.describe('PPR', () => { |
| 4 | + test('PPR should show loading first', async ({ page }) => { |
| 5 | + await page.goto('/', { waitUntil: 'commit' }); |
| 6 | + await expect( |
| 7 | + page.getByRole('heading', { name: 'Partial Prerendering' }), |
| 8 | + ).toBeVisible(); |
| 9 | + |
| 10 | + const loader = page.getByTestId('reviews-loader'); |
| 11 | + await expect(loader).toBeVisible(); |
| 12 | + await expect(page.getByText('Customer Reviews')).toHaveCount(0); |
| 13 | + |
| 14 | + await page.waitForTimeout(6000); |
| 15 | + await expect(page.getByText('Customer Reviews')).toBeVisible(); |
| 16 | + await expect(loader).not.toBeVisible(); |
| 17 | + }); |
| 18 | + |
| 19 | + test('PPR rsc prefetch request should be cached', async ({ request }) => { |
| 20 | + const resp = await request.get('/', { |
| 21 | + headers: { rsc: '1', 'next-router-prefetch': '1' }, |
| 22 | + }); |
| 23 | + expect(resp.status()).toEqual(200); |
| 24 | + |
| 25 | + const headers = resp.headers(); |
| 26 | + expect(headers['x-nextjs-postponed']).toEqual('1'); |
| 27 | + expect(headers['x-nextjs-cache']).toEqual('HIT'); |
| 28 | + expect(headers['cache-control']).toEqual( |
| 29 | + 's-maxage=31536000, stale-while-revalidate=2592000', |
| 30 | + ); |
| 31 | + }); |
| 32 | +}); |
0 commit comments