Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/playwright-community/expect-playwright
Expect utility matcher functions to simplify expect statements for the usage with Playwright Test or Jest Playwright.
https://github.com/playwright-community/expect-playwright
e2e-tests expect jest playwright playwright-test-runner testing testing-tools
Last synced: 3 months ago
JSON representation
Expect utility matcher functions to simplify expect statements for the usage with Playwright Test or Jest Playwright.
- Host: GitHub
- URL: https://github.com/playwright-community/expect-playwright
- Owner: playwright-community
- License: mit
- Created: 2020-03-31T18:49:10.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-02-13T19:02:08.000Z (almost 3 years ago)
- Last Synced: 2024-05-01T16:26:29.713Z (9 months ago)
- Topics: e2e-tests, expect, jest, playwright, playwright-test-runner, testing, testing-tools
- Language: TypeScript
- Homepage: https://playwright-community.github.io/expect-playwright/
- Size: 1.32 MB
- Stars: 142
- Watchers: 5
- Forks: 17
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-playwright - expect-playwright - Expect utility matcher functions to simplify expect statements for the usage with Playwright Test or Jest Playwright. (Utils)
README
# expect-playwright
![Node.js CI](https://github.com/playwright-community/expect-playwright/workflows/Node.js%20CI/badge.svg)
[![codecov](https://codecov.io/gh/playwright-community/expect-playwright/branch/master/graph/badge.svg?token=Eay491HC49)](https://codecov.io/gh/playwright-community/expect-playwright)
[![NPM](https://img.shields.io/npm/v/expect-playwright)](https://www.npmjs.com/package/expect-playwright)⚠️ We recommend the official [Playwright test runner](https://playwright.dev/docs/intro#first-test) ⚠️
The Playwright test runner includes all the matchers in this repo plus many more to make testing your projects easy. This doesn't mean, that we stop with maintaining this package.
---
This library provides utility matchers for Jest in combination with [Playwright]. All of them are exposed on the `expect` object. You can use them either directly or invert them via the `.not` property like shown in a example below.
```txt
npm install -D expect-playwright
```## Usage
### With [Playwright test runner](https://playwright.dev/docs/test-intro)
To activate with the Playwright test runner, use `expect.extend()` in the config to add the `expect-playwright` matchers.
```js
// playwright.config.ts
import { expect } from "@playwright/test"
import { matchers } from "expect-playwright"expect.extend(matchers)
// ...
```### With Jest
To activate it in your Jest environment you have to include it in your configuration.
```json
{
"setupFilesAfterEnv": ["expect-playwright"]
}
```## Why do I need it
The [Playwright] API is great, but it is low level and not designed for integration testing. So this package tries to provide a bunch of utility functions to perform the common checks easier.
Example which should wait and compare the text content of a paragraph on the page.
```javascript
// before
await page.waitForSelector("#foo")
const textContent = await page.$eval("#foo", (el) => el.textContent)
expect(textContent).stringContaining("my text")// after by using expect-playwright
await expect(page).toMatchText("#foo", "my text")
```But that's not all! Our matchers also work inside of iframes and accept an [ElementHandle] which targets an `iframe` element or a [Frame] obtained by calling `element.contentFrame()`. Not only that, but if you pass a promise, we will automatically resolve it for you!
```javascript
// before
const element = await page.$("iframe")
const frame = await element.contentFrame()
await expect(frame).toBeChecked("#foo")// after
await expect(page.$("iframe")).toBeChecked("#foo")
```## API documentation
### Table of Contents
- [toBeChecked](#toBeChecked)
- [toBeDisabled](#toBeDisabled)
- [toBeEnabled](#toBeEnabled)
- [toHaveFocus](#toHaveFocus)
- [toHaveSelector](#toHaveSelector)
- [toHaveSelectorCount](#toHaveSelectorCount)
- [toMatchAttribute](#toMatchAttribute)
- [toMatchComputedStyle](#toMatchComputedStyle)
- [toMatchText](#toMatchText)
- [toMatchTitle](#toMatchTitle)
- [toMatchURL](#toMatchURL)
- [toMatchValue](#toMatchValue)### toBeChecked
This function checks if a given element is checked.
You can do this via a selector on the whole page:
```javascript
await expect(page).toBeChecked("#my-element")
```Or by passing a Playwright [ElementHandle]:
```javascript
const element = await page.$("#my-element")
await expect(element).toBeChecked()
```### toBeDisabled
This function checks if a given element is disabled.
You can do this via a selector on the whole page:
```javascript
await expect(page).toBeDisabled("#my-element")
```Or by passing a Playwright [ElementHandle]:
```javascript
const element = await page.$("#my-element")
await expect(element).toBeDisabled()
```### toBeEnabled
This function checks if a given element is enabled.
You can do this via a selector on the whole page:
```javascript
await expect(page).toBeEnabled("#my-element")
```Or by passing a Playwright [ElementHandle]:
```javascript
const element = await page.$("#my-element")
await expect(element).toBeEnabled()
```### toHaveFocus
This function checks if a given element is focused.
You can do this via a selector on the whole page:
```js
await expect(page).toHaveFocus("#foobar")
```Or by passing a Playwright [ElementHandle]:
```javascript
const element = await page.$("#foobar")
await expect(element).toHaveFocus()
```### toHaveSelector
This function waits as a maximum as the timeout exceeds for a given selector once it appears on the page.
```js
await expect(page).toHaveSelector("#foobar")
```When used with `not`, `toHaveSelector` will wait until the element is not visible or not attached. See the Playwright [waitForSelector](https://playwright.dev/docs/api/class-page#page-wait-for-selector) docs for more details.
```js
await expect(page).not.toHaveSelector("#foobar")
```### toHaveSelectorCount
This function checks if the count of a given selector is the same as the provided value.
```javascript
await expect(page).toHaveSelectorCount(".my-element", 3)
```### toMatchAttribute
This function checks if an element's attribute matches the provided string or regex pattern.
You can do this via a selector on the whole page:
```javascript
await expect(page).toMatchAttribute("#foo", "href", "https://playwright.dev")
await expect(page).toMatchAttribute("#foo", "href", /playwright/)
```Or by passing a Playwright [ElementHandle]:
```javascript
const element = await page.$("#foo")
await expect(element).toMatchAttribute("href", "https://playwright.dev")
await expect(element).toMatchAttribute("href", /playwright/)
```### toMatchComputedStyle
This function checks if an element's computed style property matches the provided string or regex pattern.
You can do this via a selector on the whole page:
```javascript
await expect(page).toMatchComputedStyle("#my-element", "color", "rgb(0, 0, 0)")
await expect(page).toMatchComputedStyle("#my-element", "color", /rgb/)
```Or by passing a Playwright [ElementHandle]:
```javascript
const element = await page.$("#my-element")
await expect(element).toMatchComputedStyle("color", "rgb(0, 0, 0)")
await expect(element).toMatchComputedStyle("color", /rgb/)
```### toMatchText
This function checks if the `textContent` of a given element matches the provided string or regex pattern.
You can do this via a selector on the whole page:
```javascript
await expect(page).toMatchText("#my-element", "Playwright")
await expect(page).toMatchText("#my-element", /Play.+/)
```Or without a selector which will use the `body` element:
```javascript
await expect(page).toMatchText("Playwright")
await expect(page).toMatchText(/Play.+/)
```Or by passing a Playwright [ElementHandle]:
```javascript
const element = await page.$("#my-element")
await expect(element).toMatchText("Playwright")
await expect(element).toMatchText(/Play.+/)
```### toMatchTitle
This function checks if the page or frame title matches the provided string or regex pattern.
```javascript
await expect(page).toMatchTitle("My app - page 1")
await expect(page).toMatchTitle(/My app - page \d/)
```### toMatchURL
This function checks if the current page's URL matches the provided string or regex pattern.
```javascript
await expect(page).toMatchURL("https://github.com")
await expect(page).toMatchURL(/github\.com/)
```### toMatchValue
This function checks if the `value` of a given element is the same as the provided string or regex pattern.
You can do this via a selector or the element directly:
```javascript
await expect(page).toMatchValue("#my-element", "Playwright")
await expect(page).toMatchValue("#my-element", /Play.+/)
```Or by passing a Playwright [ElementHandle]:
```javascript
const element = await page.$("#my-element")
await expect(element).toMatchValue("Playwright")
await expect(element).toMatchValue(/Play.+/)
```## Examples
```typescript
import playwright from "playwright-chromium"describe("GitHub Playwright project", () => {
it("should should have Playwright in the README heading", async () => {
const browser = await playwright.chromium.launch()
const page = await browser.newPage()
await page.goto("https://github.com/microsoft/playwright")
await expect(page).toMatchText("#readme h1", "Playwright")
// or also all of them via the not property
await expect(page).not.toMatchText("this-is-no-anywhere", {
timeout: 1 * 1000,
})
await browser.close()
})
})
```## TypeScript
There are typings available. For that just import
```typescript
import "expect-playwright"
```at the top of your test file or include it globally in your `tsconfig.json`.
## Inspired by
- [expect-puppeteer](https://github.com/smooth-code/jest-puppeteer/tree/master/packages/expect-puppeteer)
[elementhandle]: https://playwright.dev/docs/api/class-elementhandle/
[frame]: https://playwright.dev/docs/api/class-frame/
[playwright]: https://playwright.dev