Dokumentacja konfiguracji

W tym artykule opisano konfigurację dramaturgu używaną przez przykładowe testy i wyjaśniono, jak dostosować ją do własnego środowiska.

playwright.config.ts

Plik konfiguracji znajduje się pod adresem packages/e2e-tests/playwright.config.ts:

import { defineConfig, devices } from '@playwright/test';
import path from 'path';
import { getStorageStatePath } from 'power-platform-playwright-toolkit';
import dotenv from 'dotenv';

dotenv.config();

const storageStatePath = getStorageStatePath(process.env.MS_AUTH_EMAIL!);
const mdaStorageStatePath = path.join(
  path.dirname(storageStatePath),
  `state-mda-${process.env.MS_AUTH_EMAIL}.json`
);

export default defineConfig({
  testDir: './tests',
  fullyParallel: false,         // Power Platform tests share a single org; run serially
  forbidOnly: !!process.env.CI,
  retries: process.env.CI ? 1 : 0,
  workers: 1,                   // Single worker prevents auth conflicts
  reporter: [
    ['html', { outputFolder: 'playwright-report' }],
    ['junit', { outputFile: 'test-results/results.xml' }],
  ],
  use: {
    baseURL: process.env.CANVAS_APP_URL,
    trace: 'on-first-retry',
    screenshot: 'only-on-failure',
    video: 'retain-on-failure',
  },
  projects: [
    {
      name: 'canvas',
      use: {
        ...devices['Desktop Chrome'],
        storageState: storageStatePath,
      },
      testMatch: '**/canvas/**/*.test.ts',
    },
    {
      name: 'mda',
      use: {
        ...devices['Desktop Chrome'],
        storageState: mdaStorageStatePath,
      },
      testMatch: '**/mda/**/*.test.ts',
    },
  ],
  globalSetup: './globals/global-setup',
  globalTeardown: './globals/global-teardown',
});

Kluczowe opcje konfiguracji

W poniższych sekcjach opisano najważniejsze ustawienia w pliku konfiguracji i informacje o tym, kiedy należy je zmienić.

fullyParallel i workers

Testy platformy Power Platform współużytkuje pojedyncze środowisko usługi Dataverse. Równoległe uruchamianie testów powoduje konflikty danych, takie jak dwa testy usuwające ten sam rekord. Ustaw obie opcje na serializacji wykonywania:

fullyParallel: false,
workers: 1,

Note

Jeśli masz wiele środowisk, możesz zwiększyć workers i odizolować każdy projekt do innego środowiska przy użyciu oddzielnych .env plików lub zmiennych na poziomie środowiska.

retries

Ponawianie prób może maskować flakiness w ciągłej integracji. Użyj retries: 1 ciągłej integracji do obsługi przejściowych problemów z siecią. Ustaw retries: 0 lokalnie, aby uzyskać natychmiastową opinię:

retries: process.env.CI ? 1 : 0,

trace, , screenshotvideo

Przechwyć diagnostykę tylko w przypadku niepowodzenia zaoszczędzenia miejsca na dysku:

trace: 'on-first-retry',
screenshot: 'only-on-failure',
video: 'retain-on-failure',

W ciągłej integracji artefakty są przekazywane po uruchomieniu testu. Zobacz Integracja ciągłej integracji/ciągłego wdrażania.

projects

Projekty Playwright umożliwiają oddzielenie zestawów testów opartych na modelu i kanwy. Każdy projekt może używać innego stanu magazynu:

projects: [
  {
    name: 'canvas',
    use: { storageState: storageStatePath },
    testMatch: '**/canvas/**/*.test.ts',
  },
  {
    name: 'mda',
    use: { storageState: mdaStorageStatePath },
    testMatch: '**/mda/**/*.test.ts',
  },
],

Uruchamianie pojedynczego projektu:

npx playwright test --project=canvas
npx playwright test --project=mda

globalSetup

Skrypt konfiguracji globalnej jest uruchamiany raz przed wszystkimi testami. Sprawdza stan uwierzytelniania i uruchamia uwierzytelnianie bezgłówne, jeśli stan magazynu wygasł lub brakuje go:

// global-setup.ts
import { validateAndRefreshAuthState } from './utils/validate-auth-state';

export default async function globalSetup() {
  await validateAndRefreshAuthState();
}

Sprawdzanie poprawności:

  • Plik stanu magazynu istnieje
  • Token dostępu biblioteki MSAL nie wygasł (testy kanwy/środowiska użytkownika usługi Gen)
  • Pliki cookie sesji CRM są obecne i prawidłowe (testy MDA)

tsconfig.json

Plik tsconfig.json steruje ustawieniami kompilacji języka TypeScript dla pakietu testowego:

{
  "compilerOptions": {
    "target": "ES2020",
    "module": "commonjs",
    "strict": true,
    "esModuleInterop": true,
    "resolveJsonModule": true,
    "outDir": "dist",
    "rootDir": "."
  },
  "include": ["**/*.ts"],
  "exclude": ["node_modules", "dist"]
}

Plik .env

Plik .env w lokalizacji packages/e2e-tests/.env ustawia zmienne środowiskowe dla przebiegów lokalnych. Aby uzyskać pełną dokumentację, zobacz Zmienne środowiskowe.

MS_AUTH_EMAIL=testuser@contoso.com
MS_AUTH_CREDENTIAL_TYPE=password
MS_USER_PASSWORD=<your-password>

CANVAS_APP_URL=https://apps.powerapps.com/play/<app-id>?tenantId=<tenant-id>
MODEL_DRIVEN_APP_URL=https://<org>.crm.dynamics.com/main.aspx?appid=<app-id>
CUSTOM_PAGE_NAME=AccountsCustomPage

package.json Skrypty

Następujące skrypty npm są dostępne na packages/e2e-tests/package.json potrzeby uwierzytelniania i wykonywania testów:

Script Komenda Description
auth:headful ts-node auth/auth-maker-portal.ts Interaktywne uwierzytelnianie dla Power Apps (testy kanwy)
auth:mda:headful ts-node auth/auth-mda.ts Interaktywne uwierzytelnianie dla aplikacji opartych na modelu
auth ts-node auth/auth-maker-portal.ts --headless Uwierzytelnianie bezgłowe (CI)
auth:mda ts-node auth/auth-mda.ts --headless Bezgłówne uwierzytelnianie aplikacji opartej na modelu (CI)
test playwright test Uruchamianie wszystkich testów
test:ui playwright test --ui Uruchamianie za pomocą interfejsu użytkownika dramaturgu
test:debug playwright test --debug Uruchamianie za pomocą inspektora debugowania

Następne kroki

Zobacz także