1.6.59 • Published 3 years ago

@amazeelabs/silverback-playwright v1.6.59

Weekly downloads
-
License
MIT
Repository
-
Last release
3 years ago

⚠️ Deprecated

We will switch to Turborepo+Playwright same as we did in silverback-template. This package will be removed afterward.

Silverback Playwright

Playwright tests runner for Silverback setups.

At the moment it can be used only with Silverback monorepo packages.

Usage

In your package:

  • Add this package with pnpm add @amazeelabs/silverback-playwright -D
  • Add test-results to .gitignore
  • Create playwright-tests directory
    • Create config.json (see Config type in src/types/ts)
    • Create some test files following *.spec.ts name pattern
  • Run pnpm sp-test

(Consider making tests a separate package. In this case you can depend it on several other packages without ruining their dependencies.)

Example test

playwright-tests/my-tests.spec.ts

import {
  drupal,
  drupalLogin,
  drupalLogout,
  gatsby,
  resetState,
  waitForGatsby,
} from '@amazeelabs/silverback-playwright';
import { expect, test } from '@playwright/test';

test.beforeAll(async () => {
  await resetState();
});

test('@gatsby-both test gatsby', async ({ page }) => {
  await drupalLogin(page);
  await page.goto(`${drupal.baseUrl}/en/node/add/page`);
  // Do stuff in Drupal, e.g. create a new page.
  await drupalLogout(page);

  await waitForGatsby();

  await page.goto(`${gatsby.baseUrl}/en/my-page`);
  // Check changes on Gatsby side.
});

test('@drupal-only test drupal', async ({ page }) => {
  // Here we only have Drupal.
});

For more examples see packages/tests/silverback-iframe.

Test types

The runner will run tests in different modes. Each mode has own context.

  • drupal-only has Drupal started
  • gatsby-develop has Drupal and gatsby develop started
  • gatsby-build has Drupal and Gatsby Fast Builds started

Test tags

You can add these tags to the test names to run them in desired test modes: @drupal-only, @gatsby-develop, @gatsby-build, @gatsby-both.

Tests marked with @gatsby-both will be executed in both gatsby-develop and @gatsby-build modes.

Exports to use in tests

  • resetState restored the Drupal/Gatsby state. It can be added to beforeAll or beforeEach hooks. It MUST be called at least once.
  • waitForGatsby will resolve once Gatsby is updated with recent Drupal changes.
  • drupalLogin and drupalLogout use test_session to set the auth state.
  • drupal and gatsby provide various constants (ports, URLs, credentials, etc.)

Debugging tests

There are few options.

To debug a particular test

Mark it with .only and use page.pause()

test.only('my test', async ({ page }) => {
  // ...
  await page.pause();
  // ...
});

Run the tests with --headed (-h) and --re-run (-r) flags.

To see all logs

Start tests with --verbose (-v) flag.

This will print

  • executed commands
  • Gatsby and Drupal logs
  • debug messages from the test runner

Traces

Sometimes it can happen that a test works in the headed mode, but fails in the headless one. Traces help a lot here.

To record traces, run the tests with --trace (-t) flag.

To see the traces, go to your package dir and run

pnpm playwright show-trace ./test-results/path/to/trace.zip

Tips

To speedup tests, Drupal state is restored from the test snapshot. If you did some Drupal changes, remove apps/silverback-drupal/.silverback-snapshots/test.

1.6.59

3 years ago

1.6.49

3 years ago

1.6.51

3 years ago

1.6.50

3 years ago

1.6.53

3 years ago

1.6.52

3 years ago

1.6.55

3 years ago

1.6.54

3 years ago

1.6.57

3 years ago

1.6.56

3 years ago

1.6.58

3 years ago

1.6.44

3 years ago

1.6.46

3 years ago

1.6.45

3 years ago

1.6.48

3 years ago

1.6.47

3 years ago

1.6.42

3 years ago

1.6.43

3 years ago

1.6.40

3 years ago

1.6.41

3 years ago

1.6.35

3 years ago

1.6.34

3 years ago

1.6.37

3 years ago

1.6.36

3 years ago

1.6.39

3 years ago

1.6.38

3 years ago

1.6.31

3 years ago

1.6.30

3 years ago

1.6.33

3 years ago

1.6.32

3 years ago

1.6.29

3 years ago

1.6.22

4 years ago

1.6.21

4 years ago

1.6.24

4 years ago

1.6.23

4 years ago

1.6.26

4 years ago

1.6.25

4 years ago

1.6.28

4 years ago

1.6.27

4 years ago

1.6.20

4 years ago

1.6.9

4 years ago

1.6.11

4 years ago

1.6.8

4 years ago

1.6.10

4 years ago

1.6.7

4 years ago

1.6.13

4 years ago

1.6.6

4 years ago

1.6.12

4 years ago

1.6.15

4 years ago

1.6.14

4 years ago

1.6.17

4 years ago

1.6.16

4 years ago

1.6.19

4 years ago

1.6.18

4 years ago

1.6.5

4 years ago

1.6.4

4 years ago

1.6.3

4 years ago

1.6.2

4 years ago

1.6.1

4 years ago

1.6.0

4 years ago

1.5.1

4 years ago