Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/microsoft/playwright
Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API.
https://github.com/microsoft/playwright
automation chrome chromium e2e-testing electron end-to-end-testing firefox javascript playwright test test-automation testing testing-tools web webkit
Last synced: 1 day ago
JSON representation
Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API.
- Host: GitHub
- URL: https://github.com/microsoft/playwright
- Owner: microsoft
- License: apache-2.0
- Created: 2019-11-15T18:32:42.000Z (about 5 years ago)
- Default Branch: main
- Last Pushed: 2025-01-08T00:47:00.000Z (7 days ago)
- Last Synced: 2025-01-08T01:29:53.627Z (7 days ago)
- Topics: automation, chrome, chromium, e2e-testing, electron, end-to-end-testing, firefox, javascript, playwright, test, test-automation, testing, testing-tools, web, webkit
- Language: TypeScript
- Homepage: https://playwright.dev
- Size: 156 MB
- Stars: 68,276
- Watchers: 484
- Forks: 3,770
- Open Issues: 710
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
- Support: SUPPORT.md
Awesome Lists containing this project
- awesome - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome-stacks - Playwright - Feature Tests via Playwright (Projects Using Stacks / Integrations)
- stars - microsoft/playwright
- awesome - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome-nodejs-cn - Playwright - 用单一 API 实现 Chromium, WebKit 和 Firefox 内核的无头浏览器 (包 / 测试)
- awesome-nodejs - playwright - Automate Chromium, Firefox and WebKit with a single API. ![](https://img.shields.io/github/stars/microsoft/playwright.svg?style=social&label=Star) (Repository / Automation & RPA)
- awesome-web-cn - playwright - 一个用于 Web 测试和自动化的框架 (Uncategorized / Uncategorized)
- Awesome - Playwright - Node.js library to automate Chromium, Firefox and WebKit with a single API. (Development / Programming)
- awesome-ccamel - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome-trevor - Playwright - framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (Programming / JavaScript)
- awesome-libraries - playwright
- awesome-repositories - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome-regression-testing - Playwright - Node library to automate Chromium, Firefox and WebKit with a single API. (Tools and frameworks (a-z↓))
- awesome-starred - playwright - Node.js library to automate Chromium, Firefox and WebKit with a single API (TypeScript)
- awesome-github-star - playwright
- awesome-starts - microsoft/playwright - Node.js library to automate Chromium, Firefox and WebKit with a single API (TypeScript)
- stars - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome - playwright
- awesome-list - playwright
- awesome-nodejs - Playwright - Headless Chromium, WebKit, and Firefox with a single API. (Packages / Testing)
- awesome-react-components - playwright - to-end testing for modern web apps. (Dev Tools / Test)
- awesome-learning - Playwright - Github
- fucking-awesome-react-components - playwright - to-end testing for modern web apps. (Dev Tools / Test)
- StarryDivineSky - microsoft/playwright
- awesome-browser-automation - Playwright - Cross-browser web automation platform for Node.js. (Tools)
- awesome-node - Playwright - Headless Chromium, WebKit, and Firefox with a single API. (Packages / Testing)
- awesome-docs - Playwright
- awesome-javascript - Playwright - Node.js library to automate Chromium, Firefox and WebKit with a single API. (Testing Frameworks / Runner)
- awesome-chrome-devtools - Playwright - Library to automate Chromium, Firefox and WebKit with a single API. Available for Node.js, Python, .Net, Java. See also [awesome-playwright](https://github.com/mxschmitt/awesome-playwright). (Chrome DevTools Protocol / The big two automation libraries)
- awesome-star-libs - microsoft / playwright
- jimsghstars - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- my-awesome - microsoft/playwright - testing,electron,end-to-end-testing,firefox,javascript,playwright,test,test-automation,testing,testing-tools,web,webkit pushed_at:2024-12 star:67.9k fork:3.7k Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- stars - microsoft/playwright - Playwright is a framework for Web Testing and Automation. It allows testing Chromium, Firefox and WebKit with a single API. (TypeScript)
- awesome-engineering - Playwright - language browser testing and automation framework (Awesome Tools / Languages)
- awesome-engineering - Playwright - language browser testing and automation framework (Awesome Tools / Languages)
- stars - playwright
- stars - playwright
- awesome-nodejs-cn - Playwright - **star:68227** Headless Chromium,WebKit,和 Firefox 使用单一的 API。 ![star > 2000][Awesome] (包 / 测试)
- awesome-react-components - playwright - to-end testing for modern web apps. (Dev Tools / Test)
- awesome-react-components - playwright - to-end testing for modern web apps. (Dev Tools / Test)
README
# 🎭 Playwright
[![npm version](https://img.shields.io/npm/v/playwright.svg)](https://www.npmjs.com/package/playwright) [![Chromium version](https://img.shields.io/badge/chromium-132.0.6834.57-blue.svg?logo=google-chrome)](https://www.chromium.org/Home) [![Firefox version](https://img.shields.io/badge/firefox-133.0.3-blue.svg?logo=firefoxbrowser)](https://www.mozilla.org/en-US/firefox/new/) [![WebKit version](https://img.shields.io/badge/webkit-18.2-blue.svg?logo=safari)](https://webkit.org/) [![Join Discord](https://img.shields.io/badge/join-discord-infomational)](https://aka.ms/playwright/discord)
## [Documentation](https://playwright.dev) | [API reference](https://playwright.dev/docs/api/class-playwright)
Playwright is a framework for Web Testing and Automation. It allows testing [Chromium](https://www.chromium.org/Home), [Firefox](https://www.mozilla.org/en-US/firefox/new/) and [WebKit](https://webkit.org/) with a single API. Playwright is built to enable cross-browser web automation that is **ever-green**, **capable**, **reliable** and **fast**.
| | Linux | macOS | Windows |
| :--- | :---: | :---: | :---: |
| Chromium 132.0.6834.57 | :white_check_mark: | :white_check_mark: | :white_check_mark: |
| WebKit 18.2 | :white_check_mark: | :white_check_mark: | :white_check_mark: |
| Firefox 133.0.3 | :white_check_mark: | :white_check_mark: | :white_check_mark: |Headless execution is supported for all browsers on all platforms. Check out [system requirements](https://playwright.dev/docs/intro#system-requirements) for details.
Looking for Playwright for [Python](https://playwright.dev/python/docs/intro), [.NET](https://playwright.dev/dotnet/docs/intro), or [Java](https://playwright.dev/java/docs/intro)?
## Installation
Playwright has its own test runner for end-to-end tests, we call it Playwright Test.
### Using init command
The easiest way to get started with Playwright Test is to run the init command.
```Shell
# Run from your project's root directory
npm init playwright@latest
# Or create a new project
npm init playwright@latest new-project
```This will create a configuration file, optionally add examples, a GitHub Action workflow and a first test example.spec.ts. You can now jump directly to writing assertions section.
### Manually
Add dependency and install browsers.
```Shell
npm i -D @playwright/test
# install supported browsers
npx playwright install
```You can optionally install only selected browsers, see [install browsers](https://playwright.dev/docs/cli#install-browsers) for more details. Or you can install no browsers at all and use existing [browser channels](https://playwright.dev/docs/browsers).
* [Getting started](https://playwright.dev/docs/intro)
* [API reference](https://playwright.dev/docs/api/class-playwright)## Capabilities
### Resilient • No flaky tests
**Auto-wait**. Playwright waits for elements to be actionable prior to performing actions. It also has a rich set of introspection events. The combination of the two eliminates the need for artificial timeouts - a primary cause of flaky tests.
**Web-first assertions**. Playwright assertions are created specifically for the dynamic web. Checks are automatically retried until the necessary conditions are met.
**Tracing**. Configure test retry strategy, capture execution trace, videos and screenshots to eliminate flakes.
### No trade-offs • No limits
Browsers run web content belonging to different origins in different processes. Playwright is aligned with the architecture of the modern browsers and runs tests out-of-process. This makes Playwright free of the typical in-process test runner limitations.
**Multiple everything**. Test scenarios that span multiple tabs, multiple origins and multiple users. Create scenarios with different contexts for different users and run them against your server, all in one test.
**Trusted events**. Hover elements, interact with dynamic controls and produce trusted events. Playwright uses real browser input pipeline indistinguishable from the real user.
Test frames, pierce Shadow DOM. Playwright selectors pierce shadow DOM and allow entering frames seamlessly.
### Full isolation • Fast execution
**Browser contexts**. Playwright creates a browser context for each test. Browser context is equivalent to a brand new browser profile. This delivers full test isolation with zero overhead. Creating a new browser context only takes a handful of milliseconds.
**Log in once**. Save the authentication state of the context and reuse it in all the tests. This bypasses repetitive log-in operations in each test, yet delivers full isolation of independent tests.
### Powerful Tooling
**[Codegen](https://playwright.dev/docs/codegen)**. Generate tests by recording your actions. Save them into any language.
**[Playwright inspector](https://playwright.dev/docs/inspector)**. Inspect page, generate selectors, step through the test execution, see click points and explore execution logs.
**[Trace Viewer](https://playwright.dev/docs/trace-viewer)**. Capture all the information to investigate the test failure. Playwright trace contains test execution screencast, live DOM snapshots, action explorer, test source and many more.
Looking for Playwright for [TypeScript](https://playwright.dev/docs/intro), [JavaScript](https://playwright.dev/docs/intro), [Python](https://playwright.dev/python/docs/intro), [.NET](https://playwright.dev/dotnet/docs/intro), or [Java](https://playwright.dev/java/docs/intro)?
## Examples
To learn how to run these Playwright Test examples, check out our [getting started docs](https://playwright.dev/docs/intro).
#### Page screenshot
This code snippet navigates to Playwright homepage and saves a screenshot.
```TypeScript
import { test } from '@playwright/test';test('Page Screenshot', async ({ page }) => {
await page.goto('https://playwright.dev/');
await page.screenshot({ path: `example.png` });
});
```#### Mobile and geolocation
This snippet emulates Mobile Safari on a device at given geolocation, navigates to maps.google.com, performs the action and takes a screenshot.
```TypeScript
import { test, devices } from '@playwright/test';test.use({
...devices['iPhone 13 Pro'],
locale: 'en-US',
geolocation: { longitude: 12.492507, latitude: 41.889938 },
permissions: ['geolocation'],
})test('Mobile and geolocation', async ({ page }) => {
await page.goto('https://maps.google.com');
await page.getByText('Your location').click();
await page.waitForRequest(/.*preview\/pwa/);
await page.screenshot({ path: 'colosseum-iphone.png' });
});
```#### Evaluate in browser context
This code snippet navigates to example.com, and executes a script in the page context.
```TypeScript
import { test } from '@playwright/test';test('Evaluate in browser context', async ({ page }) => {
await page.goto('https://www.example.com/');
const dimensions = await page.evaluate(() => {
return {
width: document.documentElement.clientWidth,
height: document.documentElement.clientHeight,
deviceScaleFactor: window.devicePixelRatio
}
});
console.log(dimensions);
});
```#### Intercept network requests
This code snippet sets up request routing for a page to log all network requests.
```TypeScript
import { test } from '@playwright/test';test('Intercept network requests', async ({ page }) => {
// Log and continue all network requests
await page.route('**', route => {
console.log(route.request().url());
route.continue();
});
await page.goto('http://todomvc.com');
});
```## Resources
* [Documentation](https://playwright.dev)
* [API reference](https://playwright.dev/docs/api/class-playwright/)
* [Contribution guide](CONTRIBUTING.md)
* [Changelog](https://github.com/microsoft/playwright/releases)