next.js/test/e2e/app-dir/parallel-routes-css/parallel-routes-css.test.ts
parallel-routes-css.test.ts54 lines2.0 KB
import { nextTestSetup } from 'e2e-utils'
import type { Playwright } from 'next-webdriver'

describe('parallel-routes-catchall-css', () => {
  const { next } = nextTestSetup({
    files: __dirname,
  })

  async function getChildrenBackgroundColor(browser: Playwright) {
    return browser.eval(
      `window.getComputedStyle(document.getElementById('main')).backgroundColor`
    )
  }

  async function getSlotBackgroundColor(browser: Playwright) {
    return browser.eval(
      `window.getComputedStyle(document.getElementById('slot')).backgroundColor`
    )
  }

  it('should properly load the Head content from multiple leaf segments', async () => {
    const browser = await next.browser('/')

    // the page background should be blue
    expect(await getChildrenBackgroundColor(browser)).toBe('rgb(0, 0, 255)')

    expect(await browser.elementByCss('title').text()).toBe('Home Page')
    expect(await browser.elementsByCss('title')).toHaveLength(1)

    // navigate to the page that matches a parallel route
    await browser.elementByCss("[href='/nested']").click()
    await browser.waitForElementByCss('#slot')

    // the slot's background color should be red
    expect(await getSlotBackgroundColor(browser)).toBe('rgb(255, 0, 0)')

    // the main element should either not exist or not be visible
    const mainDisplay = await browser.eval(
      `document.querySelector('#main') ? window.getComputedStyle(document.querySelector('#main')).display : null`
    )
    expect(mainDisplay === null || mainDisplay === 'none').toBe(true)

    // the slot background should still be red on a fresh load
    await browser.refresh()
    expect(await getSlotBackgroundColor(browser)).toBe('rgb(255, 0, 0)')

    // when we navigate from the route that matched the catch-all, we should see the CSS for the main element
    await browser.elementByCss("[href='/']").click()
    await browser.waitForElementByCss('#main')

    expect(await getChildrenBackgroundColor(browser)).toBe('rgb(0, 0, 255)')
  })
})
Quest for Codev2.0.0
/
SIGN IN