26. 開発ツール
**************

この章で紹介されるモジュールはソフトウェアを書くことを支援します。たと
えば、 "pydoc" モジュールはモジュールの内容からドキュメントを生成しま
す。 "doctest" と "unittest" モジュールでは、自動的に実行して予想通り
の出力が生成されるか確認するユニットテストを書くことができます。
**2to3** は Python2.x 用のソースコードを正当な Python 3.x コードに翻訳
できます。

この章で解説されるモジュールのリスト:

* 26.1. "typing" --- 型ヒントのサポート

  * 26.1.1. 型エイリアス

  * 26.1.2. NewType

  * 26.1.3. 呼び出し可能オブジェクト

  * 26.1.4. ジェネリクス

  * 26.1.5. ユーザー定義のジェネリック型

  * 26.1.6. "Any" 型

  * 26.1.7. クラス、関数、およびデコレータ

* 26.2. "pydoc" --- ドキュメント生成とオンラインヘルプシステム

* 26.3. "doctest" --- 対話的な実行例をテストする

  * 26.3.1. 簡単な利用法: docstring 中の実行例をチェックする

  * 26.3.2. 簡単な利用法: テキストファイル中の実行例をチェックする

  * 26.3.3. doctest のからくり

    * 26.3.3.1. どの docstring が検証されるのか?

    * 26.3.3.2. docstring 内の実行例をどのように認識するのか?

    * 26.3.3.3. 実行コンテキストとは何か?

    * 26.3.3.4. 例外はどう扱えばよいか?

    * 26.3.3.5. オプションフラグ

    * 26.3.3.6. ディレクティブ (Directives)

    * 26.3.3.7. 警告

  * 26.3.4. 基本 API

  * 26.3.5. 単体テスト API

  * 26.3.6. 拡張 API

    * 26.3.6.1. DocTest オブジェクト

    * 26.3.6.2. Example オブジェクト

    * 26.3.6.3. DocTestFinder オブジェクト

    * 26.3.6.4. DocTestParser オブジェクト

    * 26.3.6.5. DocTestRunner オブジェクト

    * 26.3.6.6. OutputChecker オブジェクト

  * 26.3.7. デバッグ

  * 26.3.8. アドバイス

* 26.4. "unittest" --- ユニットテストフレームワーク

  * 26.4.1. 基本的な例

  * 26.4.2. コマンドラインインターフェイス

    * 26.4.2.1. コマンドラインオプション

  * 26.4.3. テストディスカバリ

  * 26.4.4. テストコードの構成

  * 26.4.5. 既存テストコードの再利用

  * 26.4.6. テストのスキップと予期された失敗

  * 26.4.7. サブテストを利用して繰り返しテストの区別を付ける

  * 26.4.8. クラスと関数

    * 26.4.8.1. テストクラス

      * 26.4.8.1.1. 非推奨のエイリアス

    * 26.4.8.2. テストのグループ化

    * 26.4.8.3. テストのロードと起動

      * 26.4.8.3.1. load_tests プロトコル

  * 26.4.9. クラスとモジュールのフィクスチャ

    * 26.4.9.1. setUpClass と tearDownClass

    * 26.4.9.2. setUpModule と tearDownModule

  * 26.4.10. シグナルハンドリング

* 26.5. "unittest.mock" --- モックオブジェクトライブラリ

  * 26.5.1. クイックガイド

  * 26.5.2. Mock クラス

    * 26.5.2.1. 呼び出し

    * 26.5.2.2. 属性の削除

    * 26.5.2.3. Mock の名前と name 属性

    * 26.5.2.4. 属性として設定されるモック

  * 26.5.3. patcher

    * 26.5.3.1. patch

    * 26.5.3.2. patch.object

    * 26.5.3.3. patch.dict

    * 26.5.3.4. patch.multiple

    * 26.5.3.5. patch のメソッド: start と stop

    * 26.5.3.6. ビルトインをパッチする

    * 26.5.3.7. TEST_PREFIX

    * 26.5.3.8. patch デコレータをネストする

    * 26.5.3.9. どこにパッチするか

    * 26.5.3.10. デスクリプタやプロキシオブジェクトにパッチする

  * 26.5.4. MagicMock と magic method のサポート

    * 26.5.4.1. magick method をモックする

    * 26.5.4.2. Magic Mock

  * 26.5.5. ヘルパー

    * 26.5.5.1. sentinel

    * 26.5.5.2. DEFAULT

    * 26.5.5.3. call

    * 26.5.5.4. create_autospec

    * 26.5.5.5. ANY

    * 26.5.5.6. FILTER_DIR

    * 26.5.5.7. mock_open

    * 26.5.5.8. autospec を使う

* 26.6. "unittest.mock" --- 入門

  * 26.6.1. Mock を使う

    * 26.6.1.1. Mock のパッチ用メソッド

    * 26.6.1.2. オブジェクトのメソッド呼び出しに対するモック

    * 26.6.1.3. クラスをモックする

    * 26.6.1.4. モックに名前をつける

    * 26.6.1.5. 全ての呼び出しのトラッキング

    * 26.6.1.6. 戻り値や属性を設定する

    * 26.6.1.7. モックから例外を発生させる

    * 26.6.1.8. side_effect の関数と iterable

    * 26.6.1.9. 既存のオブジェクトから Mock を作る

  * 26.6.2. patch デコレータ

  * 26.6.3. さらなる例

    * 26.6.3.1. chained call をモックする

    * 26.6.3.2. 部分的なモック

    * 26.6.3.3. ジェネレータ method をモックする

    * 26.6.3.4. 同じパッチを全てのメソッドに適用する

    * 26.6.3.5. Mocking Unbound Methods

    * 26.6.3.6. モックで複数回の呼び出しをチェックする

    * 26.6.3.7. ミュータブルな引数に対処する

    * 26.6.3.8. patch をネストする

    * 26.6.3.9. MagicMock で辞書をモックする

    * 26.6.3.10. Mock のサブクラスと属性

    * 26.6.3.11. patch.dict で import をモックする

    * 26.6.3.12. Tracking order of calls and less verbose call
      assertions

    * 26.6.3.13. More complex argument matching

* 26.7. 2to3 - Python 2 から 3 への自動コード変換

  * 26.7.1. 2to3 の使用

  * 26.7.2. 変換プログラム

  * 26.7.3. "lib2to3" - 2to3's library

* 26.8. "test" --- Python 用回帰テストパッケージ

  * 26.8.1. "test" パッケージのためのユニットテストを書く

  * 26.8.2. コマンドラインインタフェースを利用してテストを実行する

* 26.9. "test.support" --- テストのためのユーティリティ関数
