Categories: Python

【Python】docstringを使って関数をテストする方法を解説【doctest】

この記事では、Pythonのdocstringを使ってテストする方法を解説します。

docstringは、説明や概要を書いたりしてドキュメントを作成するためのものですが、doctestモジュールを使うことで実行例を書いてテストさせることもできます。

doctestモジュールは主に以下の目的で使われます。

  • docstringが最新かチェックする
  • 回帰テストする
  • 書いたテストが使い方の例になる

docstringの書き方は以下の記事を参照してください。

ドキュメンテーション文字列の書き方を解説【docstring】

それでは、docstringを使ってテストする方法を見ていきましょう!

docstringでテストを行う手順

まずは、ドキュメンテーション文字列を使ってテストを行う手順を見ていきましょう。

  • STEP1
    対話実行例を書く
    ドキュメンテーション文字列中に対話実行例を記述します。書き方は後述。
    def func():
        '''
        実行例
        '''
  • STEP2
    doctestのチェック
    スクリプトが__main__として実行されたらテストがチェックされるようにしておく。
    if __name__ == "__main__":
        import doctest
        doctest.testmod()
  • STEP3
    テストする
    テストするにはスクリプトファイルをエントリポイントとして実行します。
    $ python3 スクリプトファイル

    テスト結果は後述。

それでは、次に実行例の書き方を見ていきます。

対話実行例の書き方

docstring中に関数の呼び出しと期待される出力を記述します。

def div(a, b):
    """
    >>> div(4, 2)
    2.0
    """
    return a / b

>>>div(4, 2)が呼び出しで、その下の2.0が期待される出力です。

また、期待される出力にエラーを記述することもできます。

def div(a, b):
    """
    >>> div(4, 2)
    2.0
    >>> div(0, 0)
    Traceback (most recent call last):
        ...
    ZeroDivisionError: division by zero
    """
    return a / b

「こういった呼び出し方がされたらこの結果が返る」というパターンを増やしていくことでテストを強固にすることができます。

テストの成否の挙動

テストが成功する場合と失敗する場合の挙動の違いを確認していきましょう。

実行例が成功する例

実行例が正しい場合のdocstringを試してみます。

div.py

def div(a, b):
    """
    >>> div(4, 2)
    2.0
    """
    return a / b


if __name__ == "__main__":
    import doctest
    doctest.testmod()

このコードをコマンドラインから実行します。

$ python div.py

実行例が成功すると特に何も表示されません。

実行例が失敗する例

実行例が間違っている場合のdocstringを試してみます。

div.py

def div(a, b):
    """
    >>> div(4, 2)
    2
    """
    return a / b


if __name__ == "__main__":
    import doctest
    doctest.testmod()

このコードを実行すると以下のような出力がされます。

$ python div.py
**********************************************************************
File "div.py", line 5, in __main__.div
Failed example:
    div(4, 2)
Expected:
    2
Got:
    2.0
**********************************************************************
1 items had failures:
   1 of   1 in __main__.div
***Test Failed*** 1 failures.

docstringに記述した期待される出力がExpectedで、実際に出力された値がGotです。

実行例ではint型の値が返ってくると記述していましたが、実際に返ってきた値はfloat型だったのでテストが失敗して予想した挙動になっていないことがわかりました。

まとめ

この記事では、docstringを使ってコードをテストする方法を解説しました。

色々なテスト方法がありますがdoctestはテストするコードと実行例が同じ場所にあるのでわかりやすい反面、関数などに直接書くことになるのでコードが長くなってしまいます!

テストが長くなってしまう場合はunittestなどを使いましょう!

【Python】unittestを使ってテストを実装する方法テストを実装することで将来コードが複雑になっても、そのコードが期待通りに動作することを保証してくれます。またコードを見直す際にテストを見ることで動作をまとめて見ることができます。ここにわかりやすくコメントを書いておくことでコードを理解するのにも役立ちます。...

それでは今回の内容はここまでです。ではまたどこかで〜( ・∀・)ノ

ゆうまる

独学でプログラミングを勉強しているおじさん。いろんな言語を勉強したが浅く広くなためあまり仕事につながらない。また忘れっぽいため自分のブログを備忘録としても使っている。産まれてこのかたずっとネコを飼ってる生粋のネコ派。最近お腹が出てきて筋トレに奮闘中!

View Comments

Recent Posts

【Dart】コンストラクタのデフォルト引数について

Dartのコンストラクタのデフォルト引数…

2か月 ago

【Unity】有料アセットを無料で手に入れる方法

この記事では、Unityの有料アセットを…

6か月 ago

【Python】任意の秒数だけ処理を一時停止する方法【sleep()関数】

この記事では、Pythonで任意の秒数だ…

1年 ago

【Python】Wordの文書の新規作成と読み書き

この記事では、Pythonを使ってWor…

1年 ago

【Python】メタクラスって結局なんなの?

この記事では、Pythonのメタクラスに…

1年 ago