@playwright/test
Advanced tools
Comparing version 1.30.0 to 1.38.1
@@ -17,2 +17,2 @@ #!/usr/bin/env node | ||
*/ | ||
module.exports = require('playwright-core/cli'); | ||
module.exports = require('playwright/cli'); |
@@ -17,3 +17,3 @@ /** | ||
export * from './types/test'; | ||
export { default } from './types/test'; | ||
export * from 'playwright/test'; | ||
export { default } from 'playwright/test'; |
13
index.js
@@ -17,13 +17,2 @@ /** | ||
const pwt = require('./lib/index'); | ||
const playwright = require('playwright-core'); | ||
const defineConfig = config => config; | ||
const combinedExports = { | ||
...playwright, | ||
...pwt, | ||
defineConfig, | ||
}; | ||
Object.defineProperty(combinedExports, '__esModule', { value: true }); | ||
module.exports = combinedExports; | ||
module.exports = require('playwright/test'); |
{ | ||
"name": "@playwright/test", | ||
"version": "1.30.0", | ||
"version": "1.38.1", | ||
"description": "A high-level API to automate web browsers", | ||
@@ -8,5 +8,8 @@ "repository": "github:Microsoft/playwright", | ||
"engines": { | ||
"node": ">=14" | ||
"node": ">=16" | ||
}, | ||
"main": "index.js", | ||
"author": { | ||
"name": "Microsoft Corporation" | ||
}, | ||
"license": "Apache-2.0", | ||
"exports": { | ||
@@ -21,7 +24,2 @@ ".": { | ||
"./package.json": "./package.json", | ||
"./lib/cli": "./lib/cli.js", | ||
"./lib/experimentalLoader": "./lib/experimentalLoader.js", | ||
"./lib/mount": "./lib/mount.js", | ||
"./lib/plugins": "./lib/plugins/index.js", | ||
"./lib/plugins/vitePlugin": "./lib/plugins/vitePlugin.js", | ||
"./reporter": "./reporter.js" | ||
@@ -32,10 +30,6 @@ }, | ||
}, | ||
"author": { | ||
"name": "Microsoft Corporation" | ||
}, | ||
"license": "Apache-2.0", | ||
"scripts": {}, | ||
"dependencies": { | ||
"@types/node": "*", | ||
"playwright-core": "1.30.0" | ||
"playwright": "1.38.1" | ||
} | ||
} |
170
README.md
@@ -1,3 +0,169 @@ | ||
# @playwright/test | ||
# 🎭 Playwright | ||
This package contains [Playwright Test](https://playwright.dev/docs/test-intro). A test-runner for writing idiomatic and reliable end-to-end tests with [Playwright](http://playwright.dev/). | ||
[![npm version](https://img.shields.io/npm/v/playwright.svg)](https://www.npmjs.com/package/playwright) <!-- GEN:chromium-version-badge -->[![Chromium version](https://img.shields.io/badge/chromium-117.0.5938.62-blue.svg?logo=google-chrome)](https://www.chromium.org/Home)<!-- GEN:stop --> <!-- GEN:firefox-version-badge -->[![Firefox version](https://img.shields.io/badge/firefox-117.0-blue.svg?logo=firefoxbrowser)](https://www.mozilla.org/en-US/firefox/new/)<!-- GEN:stop --> <!-- GEN:webkit-version-badge -->[![WebKit version](https://img.shields.io/badge/webkit-17.0-blue.svg?logo=safari)](https://webkit.org/)<!-- GEN:stop --> | ||
## [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 <!-- GEN:chromium-version -->117.0.5938.62<!-- GEN:stop --> | :white_check_mark: | :white_check_mark: | :white_check_mark: | | ||
| WebKit <!-- GEN:webkit-version -->17.0<!-- GEN:stop --> | :white_check_mark: | :white_check_mark: | :white_check_mark: | | ||
| Firefox <!-- GEN:firefox-version -->117.0<!-- GEN:stop --> | :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) | ||
* [Installation configuration](https://playwright.dev/docs/installation) | ||
* [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/docs/intro) | ||
* [API reference](https://playwright.dev/docs/api/class-playwright/) | ||
* [Contribution guide](CONTRIBUTING.md) | ||
* [Changelog](https://github.com/microsoft/playwright/releases) |
@@ -17,2 +17,2 @@ /** | ||
export * from './types/testReporter'; | ||
export * from 'playwright/types/testReporter'; |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Network access
Supply chain riskThis module accesses the network.
Found 3 instances in 1 package
Shell access
Supply chain riskThis module accesses the system shell. Accessing the system shell increases the risk of executing arbitrary code.
Found 1 instance in 1 package
Uses eval
Supply chain riskPackage uses eval() which is a dangerous function. This prevents the code from running in certain environments and increases the risk that the code may contain exploits or malicious behavior.
Found 2 instances in 1 package
Debug access
Supply chain riskUses debug, reflection and dynamic code execution features.
Found 2 instances in 1 package
Dynamic require
Supply chain riskDynamic require can indicate the package is performing dangerous or unsafe dynamic code execution.
Found 1 instance in 1 package
Environment variable access
Supply chain riskPackage accesses environment variables, which may be a sign of credential stuffing or data theft.
Found 47 instances in 1 package
Filesystem access
Supply chain riskAccesses the file system, and could potentially read sensitive data.
Found 1 instance in 1 package
High entropy strings
Supply chain riskContains high entropy strings. This could be a sign of encrypted data, leaked secrets or obfuscated code.
Found 1 instance in 1 package
Minified code
QualityThis package contains minified code. This may be harmless in some cases where minified code is included in packaged libraries, however packages on npm should not minify code.
Found 1 instance in 1 package
1
0
170
1
0
25262
11
115
+ Addedplaywright@1.38.1
+ Addedfsevents@2.3.2(transitive)
+ Addedplaywright@1.38.1(transitive)
+ Addedplaywright-core@1.38.1(transitive)
- Removed@types/node@*
- Removedplaywright-core@1.30.0
- Removed@types/node@22.5.4(transitive)
- Removedplaywright-core@1.30.0(transitive)
- Removedundici-types@6.19.8(transitive)