playwright/docs/src/api/class-pageassertions.md
2021-12-16 11:27:30 -08:00

3.4 KiB

class: PageAssertions

  • langs: java, python, js

The [PageAssertions] class provides assertion methods that can be used to make assertions about the [Page] state in the tests. A new instance of [PageAssertions] is created by calling [method: PlaywrightAssertions.expectPage]:

import { test, expect } from '@playwright/test';

test('navigates to login', async ({ page }) => {
  // ...
  await page.click('#login');
  await expect(page).toHaveURL(/.*\/login/);
});
...
import static com.microsoft.playwright.assertions.PlaywrightAssertions.assertThat;

public class TestPage {
  ...
  @Test
  void navigatesToLoginPage() {
    ...
    page.click("#login");
    assertThat(page).hasURL(Pattern.compile(".*/login"));
  }
}
import re
from playwright.async_api import Page, expect

async def test_navigates_to_login_page(page: Page) -> None:
    # ..
    await page.click("#login")
    await expect(page).to_have_url(re.compile(r".*/login"))
import re
from playwright.sync_api import Page, expect

def test_navigates_to_login_page(page: Page) -> None:
    # ..
    page.click("#login")
    expect(page).to_have_url(re.compile(r".*/login"))

method: PageAssertions.not

  • langs: java, js
  • returns: <[PageAssertions]>

Makes the assertion check for the opposite condition. For example, this code tests that the page URL doesn't contain "error":

await expect(page).not.toHaveURL('error');
assertThat(page).not().hasURL("error");

method: PageAssertions.NotToHaveTitle

  • langs: python

The opposite of [method: PageAssertions.toHaveTitle].

param: PageAssertions.NotToHaveTitle.titleOrRegExp

  • titleOrRegExp <[string]|[RegExp]>

Expected title or RegExp.

option: PageAssertions.NotToHaveTitle.timeout = %%-assertions-timeout-%%

method: PageAssertions.NotToHaveURL

  • langs: python
    • alias-java: hasURL

The opposite of [method: PageAssertions.toHaveURL].

param: PageAssertions.NotToHaveURL.urlOrRegExp

  • urlOrRegExp <[string]|[RegExp]>

Expected substring or RegExp.

option: PageAssertions.NotToHaveURL.timeout = %%-assertions-timeout-%%

method: PageAssertions.toHaveTitle

  • langs:
    • alias-java: hasTitle

Ensures the page has the given title.

await expect(page).toHaveTitle(/.*checkout/);
assertThat(page).hasTitle("Playwright");
import re
from playwright.async_api import expect

# ...
await expect(page).to_have_title(re.compile(r".*checkout"))
import re
from playwright.sync_api import expect

# ...
expect(page).to_have_title(re.compile(r".*checkout"))

param: PageAssertions.toHaveTitle.titleOrRegExp

  • titleOrRegExp <[string]|[RegExp]>

Expected title or RegExp.

option: PageAssertions.toHaveTitle.timeout = %%-assertions-timeout-%%

method: PageAssertions.toHaveURL

  • langs:
    • alias-java: hasURL

Ensures the page is navigated to the given URL.

await expect(page).toHaveURL(/.*checkout/);
assertThat(page).hasURL(".com");
import re
from playwright.async_api import expect

# ...
await expect(page).to_have_url(re.compile(".*checkout"))
import re
from playwright.sync_api import expect

# ...
expect(page).to_have_url(re.compile(".*checkout"))

param: PageAssertions.toHaveURL.urlOrRegExp

  • urlOrRegExp <[string]|[RegExp]>

Expected substring or RegExp.

option: PageAssertions.toHaveURL.timeout = %%-assertions-timeout-%%