Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: improve by adding teardown and examples #23470

Merged
merged 10 commits into from
Jun 9, 2023

Conversation

debs-obrien
Copy link
Contributor

@debs-obrien debs-obrien commented Jun 2, 2023

  • adds teardown explanation to both projects doc and global setup doc
  • adds an example for global setup and teardown with dependencies as previously only had example for global setup
  • added a note to warn people that using dependencies is better than global method

@debs-obrien debs-obrien requested a review from mxschmitt June 2, 2023 15:05
Copy link
Collaborator

@aslushnikov aslushnikov left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So my greatest concern is that the logging in demo will deteriorate quickly and won't work in the long run. What do we think about it?

{
name: 'logged out chromium',
use: { ...devices['Desktop Chrome'] },
testIgnore: ['**/*loggedin.spec.ts', '**/*.setup.ts']
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

no need to ignore setup.ts here

docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved

This example will show you how to use project dependencies to create a global setup that logs into an application and saves the state in storage state. This is useful if you want to run multiple tests that require a sign in state and you want to avoid logging in for each test.

The setup project will write the storage state into an 'auth.json' file in a '.auth' folder inside the playwright folder. By exporting a const of `STORAGE_STATE` we can then easily share the location of the storage file between projects with the [`method: BrowserContext.storageState`] method. This returns the storage state for the browser context and contains the current cookies and a local storage snapshot.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think you want to refer to https://playwright.dev/docs/next/test-use-options#basic-options instead of BorwserContext.storageState() method.

docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
import { test as setup, expect } from '@playwright/test';
import { STORAGE_STATE } from '../playwright.config';

setup('do login', async ({ page }) => {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm generally worried that this won't work in a recent future. Are we fine with this?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we need to create a kitchen sink app that we own so we can fully be confident that everything will always work but right now we dont have this so this is our best option. it gives a good outline of how things should work. we could change the domain to a dummy domain so people dont really test it out but I quite like testing things out in real scenarios and seeing for myself how things work

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

example simplified as per meeting discussion

@@ -206,6 +205,61 @@ Running order:

<img width="70%" style={{display: 'flex', margin: 'auto'}} alt="Browser login project is blue, database is red and e2e tests relies on both" loading="lazy" src="https://user-images.githubusercontent.com/13063165/225938262-33c1b78f-f092-4762-a478-7f8cbc1e3b21.jpg" />

### Teardown

You can also teardown your setup by adding a teardown property to your setup project. This will run after all dependencies have run.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

a link to the teardown would be nice here

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

as in: [property: TestProject.teardown] ??

docs/src/test-projects-js.md Outdated Show resolved Hide resolved
debs-obrien and others added 3 commits June 6, 2023 16:23
Co-authored-by: Andrey Lushnikov <aslushnikov@gmail.com>
Signed-off-by: Debbie O'Brien <debs-obrien@users.noreply.github.com>
@@ -3,13 +3,32 @@ id: test-global-setup-teardown
title: "Global setup and teardown"
---

There are two ways to configure global setup and teardown: using a global setup file and setting it in the config under [`globalSetup`](#configure-globalsetup-and-globalteardown) or using [project dependencies](#project-dependencies). With project dependencies, you define a project that runs before all other projects. This is the recommended way to configure global setup as with Project dependencies your HTML report will show the global setup, trace viewer will record a trace of the setup and fixtures can be used.
There are two ways to configure global setup and teardown: using a global setup file and setting it in the config under [`globalSetup`](#configure-globalsetup-and-globalteardown) or using [project dependencies](#project-dependencies). With project dependencies, you define a project that runs before all other projects and a teardown project that runs after the dependencies. This is the recommended way to configure global setup as with Project dependencies your HTML report will show the global setup, trace viewer will record a trace of the setup and fixtures can be used.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd drop the and a teardown project that runs after the dependencies since it's not really clear.

From the teardown project point of view, it runs after the dependant projects of the associated setup.

It's hard to formulate when the teardown runs from the point of view of some other dependent project.

docs/src/test-global-setup-teardown-js.md Show resolved Hide resolved

### Teardown

You can teardown your setup by adding a [`property: TestProject.teardown`] property to your setup project. This will run after all dependencies have run.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
You can teardown your setup by adding a [`property: TestProject.teardown`] property to your setup project. This will run after all dependencies have run.
You can teardown your setup by adding a [`property: TestProject.teardown`] property to your setup project. This will run after all dependent projects have run.

## Configure globalSetup and globalTeardown

You can use the `globalSetup` option in the [configuration file](#configuration-object) to set something up once before running all tests. The global setup file must export a single function that takes a config object. This function will be run once before all the tests.

Similarly, use `globalTeardown` to run something once after all the tests. Alternatively, let `globalSetup` return a function that will be used as a global teardown. You can pass data such as port number, authentication tokens, etc. from your global setup to your tests using environment variables.

:::note
Using globalSetup and globalTeardown will not produce traces or artifacts. If you want to produce traces and artifacts, use [project dependencies](#project-dependencies).
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Using globalSetup and globalTeardown will not produce traces or artifacts. If you want to produce traces and artifacts, use [project dependencies](#project-dependencies).
Using `globalSetup` and `globalTeardown` will not produce traces or artifacts. If you want to produce traces and artifacts, use [project dependencies](#project-dependencies).

@@ -206,6 +205,61 @@ Running order:

<img width="70%" style={{display: 'flex', margin: 'auto'}} alt="Browser login project is blue, database is red and e2e tests relies on both" loading="lazy" src="https://user-images.githubusercontent.com/13063165/225938262-33c1b78f-f092-4762-a478-7f8cbc1e3b21.jpg" />

### Teardown
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've just read this in docs/src/test-global-setup-teardown-js.md - is this supposed to be this way?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yeh I mean is teardown not also about projects or should it not be included there and only in global setup page??? Not sure

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would do a reference instead of copying the same text in two places

name: 'setup',
testMatch: /global.setup\.ts/,
},
{
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You should comment these curly brackets as well

@@ -26,25 +45,184 @@ export default defineConfig({
dependencies: ['setup'],
},
{
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ditto I think empty project is not valid

docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
debs-obrien and others added 3 commits June 8, 2023 19:02
Co-authored-by: Max Schmitt <max@schmitt.mx>
Signed-off-by: Debbie O'Brien <debs-obrien@users.noreply.github.com>
docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
name: 'cleanup db',
testMatch: /global.teardown\.ts/,
},
{
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

comment style

docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
docs/src/test-global-setup-teardown-js.md Outdated Show resolved Hide resolved
debs-obrien and others added 2 commits June 9, 2023 17:43
Co-authored-by: Max Schmitt <max@schmitt.mx>
Signed-off-by: Debbie O'Brien <debs-obrien@users.noreply.github.com>
@debs-obrien debs-obrien merged commit 0560a73 into microsoft:main Jun 9, 2023
@debs-obrien debs-obrien deleted the teardown-docs branch June 9, 2023 15:57
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants