サイトアイコン 【TechGrowUp】

Python開発入門70 pytest入門!Pythonテストを効率化する最強ツールの使い方を解説

はじめに

ソフトウェア開発では、コードの動作確認や品質保証のためにテストが不可欠です。その中でも、Pythonで最も人気のあるテストフレームワークの1つがpytestです。

pytestは、簡潔で分かりやすい構文を提供し、シンプルなテストから高度なテストまで幅広く対応します。本記事では、pytestの基本的な使い方から、高度な機能の活用方法までをわかりやすく解説します。

pytestとは

pytestの概要

pytestは、Pythonのテストフレームワークで、次のような特徴があります:

  1. シンプルな構文
    複雑なテストケースも簡潔に記述可能。
  2. 強力なプラグインシステム
    プラグインを追加して機能を拡張可能。
  3. 自動テストディスカバリー
    テスト関数やクラスを自動で検出して実行。

pytestの主なメリット

pytestのインストールとセットアップ

pytestのインストール

以下のコマンドでpytestをインストールします:

pip install pytest
インストール確認

インストールが成功したかを確認するには、次のコマンドを実行します:

pytest --version

最初のテストの作成

以下はpytestで書いたシンプルなテストの例です。

テストスクリプト:test_example.py
def test_addition():
    assert 1 + 1 == 2

def test_subtraction():
    assert 5 - 3 == 2

テストの実行

以下のコマンドでテストを実行します:

pytest
出力例
======================== test session starts ========================
collected 2 items

test_example.py ..                                          [100%]

========================= 2 passed in 0.01s =========================

pytestの基本的な機能

フィクスチャの活用

フィクスチャは、テスト関数にデータやリソースを提供する仕組みです。

例:フィクスチャの使用
import pytest

@pytest.fixture
def sample_data():
    return {"key": "value"}

def test_sample_data(sample_data):
    assert sample_data["key"] == "value"

アサーションの強力なサポート

pytestは、詳細なエラー情報を提供します。

例:アサーションのエラーメッセージ
def test_failure():
    assert 1 + 1 == 3

出力例:

assert 2 == 3
 +  where 2 = 1 + 1

テストのパラメータ化

複数の入力データでテストを実行するには、@pytest.mark.parametrizeを使用します。

例:パラメータ化されたテスト
import pytest

@pytest.mark.parametrize("a, b, expected", [
    (1, 1, 2),
    (2, 3, 5),
    (10, 20, 30),
])
def test_add(a, b, expected):
    assert a + b == expected

pytestの応用

テストカバレッジの確認

pytest-covプラグインを使用してテストカバレッジを確認できます。

インストール
pip install pytest-cov
実行
pytest --cov=my_project

テストのスキップ

特定の条件でテストをスキップするには、@pytest.mark.skipifを使用します。

例:テストのスキップ
import pytest
import sys

@pytest.mark.skipif(sys.version_info < (3, 10), reason="Python 3.10以上で必要")
def test_feature():
    assert True

CI/CDとの統合

pytestは、GitHub ActionsやJenkinsなどのCI/CDツールと簡単に統合できます。

GitHub Actionsの設定例

.github/workflows/ci.yml

name: CI

on:
  push:
    branches:
      - main

jobs:
  test:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v2
      - uses: actions/setup-python@v2
        with:
          python-version: 3.x
      - run: pip install pytest
      - run: pytest

pytestを使う際の注意点

  1. 明確なテスト構造
    テストケースは明確で分かりやすい名前を付けましょう。
  2. モジュールのスコープに注意
    フィクスチャやテストデータが他のテストと干渉しないように管理することが重要です。
  3. 適切なプラグインの活用
    必要な機能に応じてプラグインを選択し、効率的なテストを実現しましょう。

まとめ

pytestは、Pythonプロジェクトのテストを効率化するための強力なツールです。この記事で紹介した基本操作や応用例を参考に、pytestを活用してテストプロセスを最適化しましょう!

モバイルバージョンを終了