第9章. Spring Bootアプリケーションをテストして本番環境への対応力を高める
この作品はAIを使って翻訳されている。ご意見、ご感想をお待ちしている:translation-feedback@oreilly.com
この章では、Spring Bootアプリケーションのテストの核となる側面について説明し、実演する。テストには多くの側面があるが、Spring Bootアプリケーションをテストする基本的な要素に焦点を当て、各アプリケーションの本番環境への対応力を劇的に向上させる。トピックには、単体テスト、@SpringBootTest を使用した全体的なアプリケーションテスト、JUnitを使用した効果的な単体テストの書き方、テスト対象を分離してテストを効率化するためのSpring Bootテストスライスの使用などが含まれる。
コード・チェックアウト
まずは、コード・リポジトリからブランチchapter9beginをチェックしてほしい。
単体テスト
単体テストは、他のタイプのアプリケーションテストの先駆けとして機能するが、これには理由がある。単体テストによって、開発者は、開発+デプロイサイクルの可能な限り早い段階でバグを発見し、修正することができ、その結果、可能な限り低いコストでバグを修正することができる。
簡単に言うと、単体テストは、定義されたコード単位を、可能な限り、そして常識的な範囲で分離して検証することである。各単体テスト内の機能量を減らすことで、各単体テストがより管理しやすくなり、その結果、可能性の高い、あるいは可能性のある結果がすべて考慮される可能性が高まる。
単体テストが成功し、十分に実装されたら、統合テストやUI/UXテストなどをミックスに加えるべきだ。幸いなことに、SpringBootには単体テストを簡素化し効率化する機能が組み込まれており、Spring Initializrを使ってビルドされたすべてのプロジェクトにデフォルトでそれらの機能が含まれている。
SpringBootTestの紹介
これまで、Spring Initializrで作成されたプロジェクトのsrc/main/java以下のコードに注目してきた。しかし、Initializrで作成されたSpring Bootアプリケーションには、対応するsrc/test/javaディレクトリ構造があり、1つのテストがあらかじめ作成されている(しかしまだ空)。
メインのアプリケーションクラスと対応するように名前を付ける。例えば、メインのアプリクラスの名前がMyApplication であれば、メインのテストクラスはMyApplicationTestとなる。このデフォルトの1対1の相関関係は、整理整頓と一貫性の両方に役立つ。テストクラス内では、Initializrは1つのテストメソッドを作成する。これは、クリーンなビルドで開発が開始できるように、クリーンなスタートを提供するためである。さらにテストメソッドを追加することもできるし、他のアプリケーションクラスと並行してテストクラスを作成し、それぞれに1つ以上のテストメソッドを作成することもできる。
通常、私はテスト駆動開発(TDD)を推奨しており、テストが最初に書かれ、テストがパスするように(そしてテストがパスするようにのみ)コードが書かれる。私はSpring Bootの重要な側面は、Bootがテストを処理する方法を紹介する前に理解することが重要であると確信しているので、読者は基礎的なトピックが取り上げられるまで、この章の資料を紹介するのが遅れたことを甘んじて受け入れると信じている。 ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Read now
Unlock full access