0
Fork 0
mirror of https://github.com/penpot/penpot-plugins.git synced 2025-01-27 17:18:53 -05:00
penpot-plugins/docs/test-e2e.md

83 lines
1.9 KiB
Markdown
Raw Normal View History

2024-06-13 15:15:10 +02:00
## End-to-End (E2E) Testing Guide
### Setting Up
1. **Configure Environment Variables**
Create and populate the `.env` file with a valid user mail & password:
```env
E2E_LOGIN_EMAIL="test@penpot.app"
E2E_LOGIN_PASSWORD="123123123"
E2E_SCREENSHOTS= "true"
2024-06-13 15:15:10 +02:00
```
2. **Run E2E Tests**
Use the following command to execute the E2E tests:
```bash
npm run test:e2e
```
### Writing Tests
1. **Adding Tests**
Place your test files in the `/apps/e2e/src/**/*.spec.ts` directory. Below is an example of a test file:
```ts
2024-09-16 11:17:18 +02:00
import testingPlugin from './plugins/create-board-text-rect';
2024-06-13 15:15:10 +02:00
import { Agent } from './utils/agent';
describe('Plugins', () => {
2024-09-16 11:17:18 +02:00
it('create board - text - rectangle', async () => {
2024-06-13 15:15:10 +02:00
const agent = await Agent();
const result = await agent.runCode(testingPlugin.toString());
expect(result).toMatchSnapshot();
});
});
```
**Explanation**:
- `Agent` opens a browser, logs into Penpot, and creates a file.
- `runCode` executes the plugin code and returns the file state after execution.
2. **Using `runCode` Method**
The `runCode` method takes the plugin code as a string:
```ts
const result = await agent.runCode(testingPlugin.toString());
```
It can also accept an options object:
```ts
const result = await agent.runCode(testingPlugin.toString(), {
autoFinish: false, // default: true
screenshot: 'test-name', // default: ''
2024-06-13 15:15:10 +02:00
});
// Finish will close the browser & delete the file
agent.finish();
```
3. **Snapshot Testing**
The `toMatchSnapshot` method stores the result and throws an error if the content does not match the previous result:
```ts
expect(result).toMatchSnapshot();
```
Snapshots are stored in the `apps/e2e/src/__snapshots__/*.spec.ts.snap` directory.
If you need to refresh all the snapshopts run the test with the update option:
```bash
npm run test:e2e -- --update
```