1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

PlaywrightとChatGPTで、過去に作った【テスト自動化プログラム】を改良する

Last updated at Posted at 2025-05-11

目次

環境情報

  • OS
    • Windows11
  • 言語
    • Python3.13.3
  • ライブラリ
    • playwright==1.51.0
    • openpyxl==3.1.5

  • ChatGPTモデル
    • GPT-4o
  • 使用サイト

概要

以下記事で作成したプログラムの改良版


改良点は以下

  • 実行速度
    • SeleniumからPlaywrightに変更で、実行時間削減
    • 体感として、実行時間は半分以下になった
  • テスト作成工数
    • ChatGPTにテスト観点考案・テスト手順のexcelファイル出力を任せることで、手動対応時間削減

ChatGPTのファイル出力依頼

依頼文(最終版)

以下文でChatGPTに依頼すると、今回のプログラムで使用するexcelファイルが出力される

依頼文 あなたはテストエンジニアです。 以下の手順に従い、最終成果物として対応済みのExcelファイルを提出してください。

1.ログイン機能のテストケースを網羅的に作成する。

2.各テストケースごとにExcelのシートを作成する。

3.シート名は内容が分かる20文字以内とする。

4.各シートには、以下のフォーマットでB2セルからテスト手順を記載する:
手順No.|手順|Path|入力値|期待値|操作|結果
例:
1|メールアドレス入力|//[@id="email"]|ichiro@example.com||入力|
2|パスワード入力|//
[@id="password"]|pass1234||入力|
3|ログインボタン押下|//[@id="login-button"]|||押下|
4|メールアドレスの比較|//
[@id="email"]||ichiro@example.com|比較|

操作の種類と使い分け:
入力:テキストボックスに入力値を入力する
押下:ボタンを押す
比較:画面上の値を期待値と比較する

5.入力値なしの入力操作を含む手順は削除する

6.正常ログイン時の入力値は以下とし、該当箇所を更新する:
メールアドレス:ichiro@example.com
パスワード:password

7.各手順に使用するXPathを以下で統一する:
メールアドレス入力://[@id="email"]
パスワード入力://
[@id="password"]
ログインボタン://[@id="login-button"]
メールアドレス比較://
[@id="email"]
メールアドレスエラーメッセージ比較://[@id="email-message"]
パスワードエラーメッセージ比較://
[@id="password-message"]

8.エラー発生時の期待値は以下とする:
未登録のメールアドレス:メールアドレスまたはパスワードが違います。
メールアドレス形式誤り:メールアドレスを入力してください。
メールアドレス未入力:このフィールドを入力してください。
不正なパスワード:メールアドレスまたはパスワードが違います。
パスワード未入力:このフィールドを入力してください。

9.未登録メールアドレスまたは不正パスワードの場合は、既存の比較手順を削除し、//[@id="email-message"] および //[@id="password-message"] の比較手順を追加する。

10.正常ログイン時は、最後にログアウト操作(//*[@id="logout-form"]/button)を追加する。

最終版作成までの道のり

道のり 1.以下のように個別で質問して、ファイル出力まで誘導

スクリーンショット 2025-05-11 171543.png
スクリーンショット 2025-05-11 171720.png

2.思い通りのファイルが出力されたタイミングで、個別の質問をまとめて投稿する形に変更
スクリーンショット 2025-05-11 172423.png

3.ChatGPTにプロンプトの修正を依頼
スクリーンショット 2025-05-11 172701.png

他機能・サイトでの応用

まだ試していないが、以下変更で他機能やサイトでも応用できると考えている。(今後確認予定)

  • 手順1で対象機能を変更する
  • 手順6以降で対象サイトに合った情報を入力する
    • 以下2つの情報を変更
      • xpath
      • IDやPassword

出力ファイル

スクリーンショット 2025-05-11 191056.png

構成は以下

  • シート名
    • ログイン観点
  • シート内の内容
    • 手順No.
    • 手順
      • 手順の具体説明の記載列
    • Path
      • 該当手順をテスト自動実行する際に使用するxpathの記載列
      • コードの以下部分で使用する値が記載される
      try:
          if action_type == "押下":
              click_button(page, xpath)
          elif action_type == "入力":
              input_value(page, xpath, value)
          elif action_type == "比較":
              compare_value(page, xpath, expect)
      
    • 入力値
      • 操作:入力の際に使用するテキストの記載列
      • コードの以下部分で使用する値が記載される
          elif action_type == "入力":
              input_value(page, xpath, value)
      
    • 期待値
      • 操作:比較の際に使用するテキストの記載列
      • コードの以下部分で使用する値が記載される
          elif action_type == "比較":
              compare_value(page, xpath, expect)
      
    • 操作
      • テスト自動実行で実行してほしい操作の記載列
      • 現在は「押下」「入力」「比較」のみ
    • 結果
      • 各手順の自動実行結果がOKかNGか記載される列
      • コードの以下部分で使用する値が記載される
      except:
          print(traceback.format_exc())
          result_list.append('NG')
      else:
          result_list.append('OK')
      

プログラム

test_automation.py
from playwright.sync_api import sync_playwright
import openpyxl as excel
import traceback

# 押下の定義
def click_button(page, xpath):
    page.wait_for_selector(xpath, state="visible", timeout=5000)
    page.click(xpath)

# 入力の定義
def input_value(page, xpath, value):
    page.wait_for_selector(xpath, state="visible", timeout=5000)
    page.fill(xpath, value)

# 比較の定義
def compare_value(page, xpath, expect):
    page.wait_for_selector(xpath, state="visible", timeout=5000)
    raw_text = page.locator(xpath).inner_text()
    assert raw_text == expect

# テストケース実行の定義
def run_testcase(browser, sheet_name):
    context = browser.new_context()
    page = context.new_page()

    page.goto('https://hotel-example-site.takeyaqa.dev/ja/login.html')
    page.wait_for_load_state("networkidle")

    ws_case_1 = book1[sheet_name]
    testcase = []
    column_list = []
    row_list = []
    result_list = []

    # 最大行数は必要に応じて調整
    for data_number, raw_row in enumerate(ws_case_1['B2':'H100']):
        temp = {}
        if data_number == 0:
            for column_cell in raw_row:
                column_list.append(column_cell.value)
            continue

        for column_name, cell in zip(column_list, raw_row):
            temp[column_name] = cell.value

        # 空行チェック:すべての値が空ならスキップ
        if all(value is None for value in temp.values()):
            continue

        testcase.append(temp)
        # 実際のExcelの行番号(2行目開始)
        row_list.append(data_number + 2)

    for fixed_row in testcase:
        xpath = fixed_row['Path']
        value = fixed_row['入力値']
        expect = fixed_row['期待値']
        action_type = fixed_row['操作']

        try:
            if action_type == "押下":
                click_button(page, xpath)
            elif action_type == "入力":
                input_value(page, xpath, value)
            elif action_type == "比較":
                compare_value(page, xpath, expect)
        except:
            print(traceback.format_exc())
            result_list.append('NG')
        else:
            result_list.append('OK')

    # 結果をExcelに書き込み
    for row_num, result in zip(row_list, result_list):
        ws_case_1.cell(row=row_num, column=8).value = result

    context.close()

# 実行本体
with sync_playwright() as p:
    browser = p.chromium.launch(headless=False)
    # [ファイル名].xlsxにChatGPTで出力したファイルのpathを記載
    book1 = excel.load_workbook(r"C:[ファイル名].xlsx")
    for sheet_name in book1.sheetnames:
        run_testcase(browser, sheet_name)
    book1.save(r"C:[ファイル名].xlsx")
    book1.close()

    browser.close()

学び

  • ChatGPTのテスト観点
    • 一般的なテスト観点の提案はできる
    • サイト特有のテスト観点や仕様などは細かく伝えれば、作成してくれる
      • ChatGPTに細かく伝える工数>手動作成の工数となる場合は、その部分だけ手動で作成するのはあり
      • 今回だと、以下の仕様部分(ChatGPTへの依頼文から抜粋)が上記状況に近い

      9.未登録メールアドレスまたは不正パスワードの場合は、既存の比較手順を削除し、//[@id="email-message"] および //[@id="password-message"] の比較手順を追加する。

  • ChatGPTのファイル出力
    • テスト自動化ひいては手動検証でも使用できるファイルの出力は可能
      • ただし、フォーマットは作成依頼時に細かく指定する必要あり
  • プログラム
    • プログラムの書き方(使用するライブラリなど)で工数がかなり変わる
      • 新規のライブラリや書き方が登場したときは、とりあえず試してみる精神が重要
    • どうしても書き方が分からない場合やコードレビューはChatGPTに相談
      • プログラムの完成度が段違いになる
1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?