Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vitalets/playwright-magic-steps
Auto-transform JavaScript comments into Playwright steps
https://github.com/vitalets/playwright-magic-steps
playwright step test-automation testing
Last synced: 3 days ago
JSON representation
Auto-transform JavaScript comments into Playwright steps
- Host: GitHub
- URL: https://github.com/vitalets/playwright-magic-steps
- Owner: vitalets
- License: mit
- Created: 2024-07-16T09:19:48.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-12-18T10:04:42.000Z (about 1 month ago)
- Last Synced: 2025-01-16T03:11:54.174Z (10 days ago)
- Topics: playwright, step, test-automation, testing
- Language: TypeScript
- Homepage:
- Size: 982 KB
- Stars: 35
- Watchers: 1
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-playwright - playwright-magic-steps - Auto-transform JavaScript comments into Playwright steps. (Utils)
README
# playwright-magic-steps
[![lint](https://github.com/vitalets/playwright-magic-steps/actions/workflows/lint.yaml/badge.svg)](https://github.com/vitalets/playwright-magic-steps/actions/workflows/lint.yaml)
[![test](https://github.com/vitalets/playwright-magic-steps/actions/workflows/test.yaml/badge.svg)](https://github.com/vitalets/playwright-magic-steps/actions/workflows/test.yaml)
[![npm version](https://img.shields.io/npm/v/playwright-magic-steps)](https://www.npmjs.com/package/playwright-magic-steps)
[![license](https://img.shields.io/npm/l/playwright-magic-steps)](https://github.com/vitalets/playwright-magic-steps/blob/main/LICENSE)Auto-transform JavaScript comments into [Playwright](https://playwright.dev/) steps.
- [Example](#example)
- [With AI](#with-ai)
- [Installation](#installation)
- [Activation](#activation)
- [CommonJS](#commonjs)
- [ESM](#esm)
- [Usage](#usage)
- [Step start](#step-start)
- [Step end](#step-end)
- [Nested steps](#nested-steps)
- [Variables](#variables)
- [Motivation](#motivation)
- [Caveats](#caveats)
- [Changelog](#changelog)
- [0.4.0](#040)
- [License](#license)## Example
Test code:
```ts
test('Check home page', async ({ page }) => {
// step: Open home page
await page.goto('https://playwright.dev');
// step: Click "Get started" link
await page.getByRole('link', { name: 'Get started' }).click();
// step: Check page title
await expect(page).toHaveTitle('Installation | Playwright');
});
```Playwright report:
![image](https://github.com/user-attachments/assets/3e11f029-a456-4009-ba75-2357c5f74b63)
Test code actually executed:
```ts
test('Check home page', async ({ page }) => {
await test.step('Open home page', async () => {
await page.goto('https://playwright.dev');
});
await test.step('Click "Get started" link', async () => {
await page.getByRole('link', { name: 'Get started' }).click();
});
await test.step('Check page title', async () => {
await expect(page).toHaveTitle('Installation | Playwright');
});
});
```### With AI
You can utilize AI to generate tests with appropriate comments and get nice reports. Example prompt for [ChatGPT](https://chatgpt.com/):
```
Write playwright test in typescript:
- open playwright homepage
- navigate to get started section
- check that page title contains InstallationAdd comment to each step in the format // step: {comment}
```Generated test:
Playwright report:
## Installation
Install from npm:
```
npm install -D playwright-magic-steps
```## Activation
To enable magic steps transformation, you'll need to run Playwright with a pre-required module. You can include this module using the `NODE_OPTIONS` environment variable. The exact value will depend on whether your project uses CommonJS or ESM:### CommonJS
Run Playwright with the following `-r` flag in `NODE_OPTIONS`:
```
npx cross-env NODE_OPTIONS="-r playwright-magic-steps" playwright test
```### ESM
Run Playwright with the following `--import` flag in `NODE_OPTIONS`:
```
npx cross-env NODE_OPTIONS="--import playwright-magic-steps/esm" playwright test
```## Usage
You can define steps with special comments.### Step start
Step start is defined by the comment:
```js
// step: {title}
```### Step end
Step end is defined by one of the following rules (indent matters):* start of another step with the same indent:
```ts
test('my test', async () => {
// step: Open home page
await page.goto('/');
// step: Click button
});
```* explicit comment `// stepend` with the same indent:
```ts
test('my test', async () => {
// step: Open home page
await page.goto('/');
// stepend
});
```* line indent is lower than indent of step start:
```ts
test('my test', async () => {
// step: Open home page
await page.goto('/');
});
```### Nested steps
Steps can be nested:
```ts
test('my test', async () => {
// step: Open home page
await page.goto('/');
if (noAuth) {
// step: Perform auth
await page.goto('/login');
}
});
```> [!IMPORTANT]
> Code **indentation** is important! Consider using [Prettier](https://prettier.io/) or other auto-formatting tools.If you need the same level steps to be nested - use anonymous `{}` block:
```ts
test('my test', async () => {
// step: login
{
// step: Open home page
await page.goto('/');
// step: Perform auth
await page.goto('/login');
}
});
```### Variables
You can use variables in step text like in template literals:```js
const searchTerm = 'foo';
// step: Enter search term ${searchTerm}
await page.getByRole('search').fill(searchTerm);
```Be careful with variables in comments, as it can be not obvious for other team members.
Alternatively, you can always use regular `test.step()` for such cases:
```js
const searchTerm = 'foo';
await test.step(`Enter search term ${searchTerm}`, async () => {
await page.getByRole('search').fill(searchTerm);
});
```## Motivation
According to [Golden Rule](https://github.com/goldbergyoni/javascript-testing-best-practices?tab=readme-ov-file#section-0%EF%B8%8F⃣-the-golden-rule) of testing, I try to keep my Playwright tests flat and simple. Wrapping code into `test.step()` adds extra visual complexity and nesting. Creating steps by comments makes test code more readable.## Caveats
This library performs string replacements in your code and can potentially break it. This is a price we pay for convenience.If something gets broken, you can always opt-out magic steps. Your tests will run, because all instructions are plain JavaScript comments. Feel free to report any problems in [issues](https://github.com/vitalets/playwright-magic-steps/issues).
Example of broken code:
```ts
test('Check home page', async ({ page }) => {
// step: Open home page
await page.goto('https://playwright.dev');
const link = page.getByRole('link', { name: 'Get started' });// step: Click link
await link.click();
});
```Error:
```
ReferenceError: link is not defined
```
There is an error, because in the transformed code `link` variable is wrapped into the scope of the first step and not accessible in the second step:
```ts
test('Check home page', async ({ page }) => {
await test.step('Open home page', async () => {
await page.goto('https://playwright.dev');
const link = page.getByRole('link', { name: 'Get started' });
});await test.step('Click link', async () => {
await link.click();
});
});
```How to fix:
* Move `link` variable to the second step (that is more logical):
```ts
test('Check home page', async ({ page }) => {
// step: Open home page
await page.goto('https://playwright.dev');// step: Click link
const link = page.getByRole('link', { name: 'Get started' });
await link.click();
});
```* Close first step earlier (if link variable is shared between several steps):
```ts
test('Check home page', async ({ page }) => {
// step: Open home page
await page.goto('https://playwright.dev');
// stependconst link = page.getByRole('link', { name: 'Get started' });
// step: Click link
await link.click();
});
```## Changelog
### 0.4.0
* allow blank lines inside steps ([#3](https://github.com/vitalets/playwright-magic-steps/issues/3))
* dropped support of magic steps activation via `playwright.config.js` as it does not work in Playwright 1.47## License
[MIT](https://github.com/vitalets/playwright-magic-steps/blob/main/LICENSE)