クイックスタート: Microsoft Playwright Testing (プレビュー) を使用して、テストのトラブルシューティングを行う
このクイックスタートでは、Microsoft Playwright Testing (プレビュー) 上で発行されるレポートと成果物を使用して、Playwright テストのトラブルシューティングを簡単に行う方法について説明します。 さらに、このガイドでは、サービスによって提供されるクラウドでホストされたブラウザーでテストを実行しているかどうかに関係なく、レポート機能を利用する方法を説明します。
このクイックスタートを完了すると、Microsoft Playwright Testing ワークスペースが作成され、サービス ポータルでテスト結果と成果物を表示できるようになります。
重要
Microsoft Playwright Testing は現在、プレビュー段階です。 ベータ版、プレビュー版、または一般提供としてまだリリースされていない Azure の機能に適用される法律条項については、「Microsoft Azure プレビューの追加使用条件」を参照してください。
背景
Microsoft Playwright Testing サービスを使用すると、以下が行えます。
- クラウドでホストされたブラウザーを使用してテストを並列で実行することで、ビルド パイプラインを高速化します。
- テスト結果と成果物をサービスに発行し、サービス ポータルからアクセスできるようにすることで、トラブルシューティングを簡略化します。
サービスのこれら 2 つの機能は独立して、または一緒に使用でき、それぞれに独自の価格プランがあります。 柔軟に次のことをできます。
- クラウドでホストされたブラウザーでのテストの実行と、サービスへの結果の発行の、両方の機能を使って、テスト実行を迅速化し、トラブルシューティングを効率化します。
- クラウドでホストされたブラウザーでのみテストを実行して、テスト実行を高速化します。
- 効率的なトラブルシューティングのために継続的にテストをローカルで実行しながら、テスト結果をサービスに発行します。
Note
この記事では、クラウドでホストされたブラウザーを使わずに、サービスにテスト結果を発行する方法に焦点を当てます。 テストの実行を高速化する方法についても知りたい場合は、大規模な Playwright テストの実行のクイックスタートに関する記事をご覧ください。
前提条件
- アクティブなサブスクリプションが含まれる Azure アカウント。 Azure サブスクリプションをお持ちでない場合は、始める前に無料アカウントを作成してください。
- Azure アカウントには、所有者、共同作成者、または従来の管理者の役割のいずれかが必要です。
- Playwright プロジェクト。 プロジェクトがない場合は、Playwright 入門ドキュメントを使用してプロジェクトを作成するか、Microsoft Playwright Testing サンプル プロジェクトを使用します。
- Azure CLI。 Azure CLI がインストールされていない場合は、「Azure CLI のインストール」を参照してください。
ワークスペースの作成
Playwright Testing サービスへのテスト結果の発行を開始するには、まず Playwright ポータルで Microsoft Playwright Testing ワークスペースを作成します。
Azure アカウントを使用して、Playwright ポータルにサインインします。
ワークスペースが既にある場合は、既存のワークスペースを選択し、次の手順に進みます。
ヒント
複数のワークスペースがある場合、別のワークスペースに切り替えるには、ページ上部にあるワークスペース名を選択します。その後、[すべてのワークスペースの管理] を選択します。
まだワークスペースがない場合は、[+ 新しいワークスペース] を選択し、次の情報を入力します。
フィールド 説明 ワークスペース名 ワークスペースを識別する一意の名前を入力します。
名前には英数字のみを使用できます。また、3 から 64 文字の間で指定する必要があります。Azure サブスクリプション この Microsoft Playwright Testing ワークスペースに使用する Azure サブスクリプションを選択します。 リージョン ワークスペースをホストする地理的な場所を選択します。
これは、ワークスペースのテストの実行データが保存される場所です。[ワークスペースの作成] を選択して、サブスクリプションにワークスペースを作成します。
ワークスペースの作成時に、新しいリソース グループと Microsoft Playwright Testing Azure リソースが Azure サブスクリプションに作成されます。
ワークスペースの作成が完了すると、セットアップ ガイドにリダイレクトされます。
Microsoft Playwright Testing パッケージをインストールする
サービスを利用するには、Microsoft Playwright Testing パッケージをインストールします。
npm init @azure/microsoft-playwright-testing@latest
Note
プロジェクトで @playwright/test
バージョン 1.47 以降を使用していることをご確認ください。
このコマンドにより、次の処理を行うための playwright.service.config.ts
ファイルが生成されます。
- Playwright クライアントを Microsoft Playwright Testing サービスにアクセスさせて認証する。
- テスト結果と成果物を発行するレポーターを追加する。
このファイルが既にある場合、プロンプトによって上書きするよう求められます。
テスト実行にレポート機能のみを使用するには、useCloudHostedBrowsers
を false に設定してクラウドでホストされたブラウザーを無効化します。
export default defineConfig(
config,
getServiceConfig(config, {
timeout: 30000,
os: ServiceOS.LINUX,
useCloudHostedBrowsers: false // Do not use cloud hosted browsers
}),
{
reporter: [['list'], ['@azure/microsoft-playwright-testing/reporter']], // Reporter for Microsoft Playwright Testing service
}
);
値を false
に設定すると、クラウドでホストされたブラウザーがテストの実行に使用されなくなります。 テストはローカル コンピューターで実行されますが、結果と成果物はサービスに発行されます。
サービスを利用するには、Microsoft Playwright Testing パッケージをインストールします。
dotnet add package Azure.Developer.MicrosoftPlaywrightTesting.NUnit --prerelease
Note
プロジェクトで Microsoft.Playwright.NUnit
バージョン 1.47 以降を使用していることをご確認ください。
レポート機能のみを使用するには、プロジェクトの .runsettings
ファイルで以下を更新します。
useCloudHostedBrowsers
を false に設定して、クラウドでホストされているブラウザーを無効にします。- `Loggers' セクションに Microsoft Playwright Testing ロガーを追加します。
<?xml version="1.0" encoding="utf-8"?>
<RunSettings>
<TestRunParameters>
<!--Select if you want to use cloud-hosted browsers to run your Playwright tests.-->
<Parameter name="UseCloudHostedBrowsers" value="true" />
<!--Select the authentication method you want to use with Entra-->
</TestRunParameters>
.
.
.
<LoggerRunSettings>
<Loggers>
<!--Microsoft Playwright Testing service logger for reporting -->
<Logger friendlyName="microsoft-playwright-testing" enabled="True" />
<!--could enable any logger additionally -->
<Logger friendlyName="trx" enabled="false" />
</Loggers>
</LoggerRunSettings>
</RunSettings>
ヒント
クラウドでホストされたブラウザーを使用してテストの実行を高速化する場合は、useCloudHostedBrowsers
を true に設定できます。 これにより、サービスで管理されるブラウザーでテストを実行できます。
サービス リージョン エンドポイントを構成する
セットアップでは、リージョン固有のサービス エンドポイントを指定する必要があります。 エンドポイントは、ワークスペースの作成時に選択した Azure リージョンによって異なります。
サービス エンドポイント URL を取得するには、次の手順を実行します。
[セットアップのリージョン エンドポイントの追加] で、ワークスペースのリージョン エンドポイントをコピーします。
エンドポイント URL は、ワークスペースの作成時に選択した Azure リージョンと一致します。 この URL が
PLAYWRIGHT_SERVICE_URL
環境変数で利用可能であることを確認してください。
環境を設定する
環境を設定するには、前の手順で取得した値を使用して PLAYWRIGHT_SERVICE_URL
環境変数を構成する必要があります。
dotenv
モジュールを使用して環境を管理することをお勧めします。 dotenv
を使用して、.env
ファイルで環境変数を定義します。
dotenv
モジュールをプロジェクトに追加します。npm i --save-dev dotenv
Playwright プロジェクト内の
playwright.config.ts
ファイルと共に.env
ファイルを作成します。PLAYWRIGHT_SERVICE_URL={MY-REGION-ENDPOINT}
{MY-REGION-ENDPOINT}
テキスト プレースホルダーを、先程コピーした値に置き換えてください。
サービス構成を設定する
ルート ディレクトリで、次のコンテンツを含む PlaywrightServiceSetup.cs
ファイルを作成します。
using Azure.Developer.MicrosoftPlaywrightTesting.NUnit;
namespace PlaywrightTests; // Remember to change this as per your project namespace
[SetUpFixture]
public class PlaywrightServiceSetup : PlaywrightServiceNUnit {};
Note
プロジェクトで Microsoft.Playwright.NUnit
バージョン 1.47 以降を使用していることを確認してください。
認証の設定
Microsoft Playwright Testing ワークスペースでテスト結果と成果物を発行するには、サービスに対してテストを実行している Playwright クライアントを認証する必要があります。 このクライアントはローカル開発マシンまたは CI マシンである可能性があります。
このサービスには、2 つの認証方法 (Microsoft Entra ID とアクセス トークン) が用意されています。
Microsoft Entra ID では Azure 資格情報が使用され、アクセスをセキュリティで保護するためには Azure アカウントへのサインインが必要です。 あるいは、Playwright ワークスペースからアクセス トークンを生成し、セットアップで使用することもできます。
Microsoft Entra ID を使用して認証を設定する
Microsoft Entra ID は、このサービスの既定かつ推奨される認証です。 ローカル開発マシンから、Azure CLI を使用してサインインできます
az login
Note
複数の Microsoft Entra テナントに所属している場合は、ワークスペースが属するテナントにサインインしていることを確認してください。 テナント ID は Azure portal から取得できます。 詳細については、Microsoft Entra テナントを検索するに関するページを参照してください。 ID を取得したら、コマンド az login --tenant <TenantID>
を使用してサインインします
アクセス トークンを使用して認証を設定する
Playwright Testing ワークスペースからアクセス トークンを生成し、セットアップで使用できます。 ただし、セキュリティが強化されているため、認証には Microsoft Entra ID を使用することを強くお勧めします。 アクセス トークンは便利ですが、有効期間が長いパスワードのように機能し、侵害されやすくなります。
アクセス トークンを使用した認証は、既定では無効になっています。 使用するには、アクセス トークン ベースの認証を有効にします
注意事項
サービスへの認証には Microsoft Entra ID を使用することを強くお勧めします。 アクセス トークンを使用する場合は、「アクセストークンの管理方法」を参照してください。
Playwright セットアップでアーティファクトを有効にする
プロジェクトの playwright.config.ts
ファイルで、必要な成果物をすべて収集していることを確認します。
use: {
trace: 'on-first-retry',
video:'retain-on-failure',
screenshot:'on'
}
スクリーンショット、ビデオ、トレースなどのアーティファクトを Playwright でキャプチャできるようにします。
- スクリーンショットについては、スクリーンショットのキャプチャに関するページを参照してください
- ビデオについては、テストのビデオ記録に関するページを参照してください
- トレースについては、トレースの記録に関するページを参照してください
これらのアーティファクトを収集したら、TestContext
に添付し、テスト レポートで使用できるようにします。 詳細については、NUnit のサンプル プロジェクトに関するページを参照してください
テストを実行し、Microsoft Playwright Testing で結果を発行する
これで、Microsoft Playwright Testing を使用してテスト結果と成果物を発行するための構成の準備ができました。 新しく作成した playwright.service.config.ts
ファイルを使用してテストを実行し、サービスにテスト結果と成果物を発行します。
npx playwright test --config=playwright.service.config.ts
Note
Microsoft Playwright Testing のレポート機能に関しては、発行されたテストの数に基づいて請求されます。 初めてのユーザーの場合や無料試用版の使用を開始する場合は、完全なテスト スイートではなく 1 つのテストを発行することで、無料試用版の制限を超えないようにすることができます。
テストが完了したら、ターミナルでテストの状態を表示できます。
Running 6 test using 2 worker
5 passed, 1 failed (20.2s)
Test report: https://playwright.microsoft.com/workspaces/<workspace-id>/runs/<run-id>
これで、Microsoft Playwright Testing を使用してテスト結果と成果物を発行するための構成の準備ができました。 .runsettings
ファイルを使用してテストを実行し、サービスにテスト結果と成果物を発行します。
dotnet test --settings:.runsettings
テスト実行の設定は、.runsettings
ファイルで定義されています。 詳細については、サービス パッケージ オプションの使用方法に関するページを参照してください
Note
Microsoft Playwright Testing のレポート機能に関しては、発行されたテストの数に基づいて請求されます。 初めてのユーザーの場合や無料試用版の使用を開始する場合は、完全なテスト スイートではなく 1 つのテストを発行することで、無料試用版の制限を超えないようにすることができます。
テスト実行が完了したら、ターミナルでテストの状態を表示できます。
Starting test execution, please wait...
Initializing reporting for this test run. You can view the results at: https://playwright.microsoft.com/workspaces/<workspace-id>/runs/<run-id>
A total of 100 test files matched the specified pattern.
Test Report: https://playwright.microsoft.com/workspaces/<workspace-id>/runs/<run-id>
Passed! - Failed: 0, Passed: 100, Skipped: 0, Total: 100, Duration: 10 m - PlaywrightTestsNUnit.dll (net7.0)
Workload updates are available. Run `dotnet workload list` for more information.
注意事項
テスト スイートのサイズによっては、割り当てられた無料のテスト結果数を超えたテスト結果数の追加料金が発生する場合があります。
Playwright ポータルでテストの実行と結果を表示する
これで、Playwright ポータルで失敗したテスト ケースのトラブルシューティングを行うことができます。
テスト実行が完了すると、Playwright ポータルへのリンクが生成されます。 このリンクを開いて、詳細なテスト結果と関連する成果物を表示します。 ポータルには次のような重要な情報が表示されます。
- CI ビルドの詳細
- 全体的なテスト実行の状態
- テスト実行に関連するコミット ID
Playwright ポータルには、トラブルシューティングに必要なすべての情報が表示されます。 次のことを実行できます。
- 再試行を切り替える。
- 詳細なエラー ログ、テスト手順、および添付された成果物 (スクリーンショットやビデオなど) を表示する。
- 詳細な分析のためにトレース ビューアーに直接移動する。
トレース ビューアーを使用すると、テスト実行の手順を視覚的に確認できます。 次のことを実行できます。
- タイムラインを使用して個々の手順にカーソルを合わせて、各アクションの前後のページの状態を確認する。
- 手順の詳細なログ、DOM スナップショット、ネットワーク アクティビティ、エラー、コンソール出力を調べる。
テストの実行が完了すると、ターミナルに Playwright ポータルへのリンクが表示されます。 このリンクを開いて、詳細なテスト結果と関連する成果物を表示します。 ポータルには次のような重要な情報が表示されます。
- CI ビルドの詳細
- 全体的なテスト実行の状態
- テスト実行に関連するコミット ID
Playwright ポータルには、トラブルシューティングに必要なすべての情報が表示されます。 次のことを実行できます。
- 詳細なエラー ログと、アタッチされた成果物 (スクリーンショットやビデオなど) を表示します。
- 詳細な分析のためにトレース ビューアーに直接移動する。
Note
所有者、説明、カテゴリなどの一部のメタデータは、現在のところ、サービス ダッシュボードに表示されません。 表示内容に含めたいその他の情報がある場合は、こちらのリポジトリで GitHub イシューを作成してください。
ヒント
Microsoft Playwright Testing サービスを使用して、クラウドでホストされたブラウザーを使用してテストを並列で実行することもできます。 レポートとクラウドでホストされたブラウザーはどちらも独立した機能であり、個別に請求されます。 このいずれかまたは両方を使用できます。 詳細については、「サービス機能の使用方法」を参照してください。
Note
発行したテスト結果と成果物は、サービスに 90 日間保持されます。 その後、自動的に削除されます。
次のステップ
Playwright ポータルで Microsoft Playwright Testing ワークスペースを正常に作成し、クラウド ブラウザーで Playwright テストを実行しました。
次のクイックスタートでは、CI/CD ワークフローで Playwright テストを実行して、エンドツーエンドの継続的なテストを設定します。