ホームページ Java &#&チュートリアル JUnit と Mockito を使用した Spring Boot でのテストの自動化

JUnit と Mockito を使用した Spring Boot でのテストの自動化

Sep 09, 2024 pm 08:30 PM

Automating Tests in Spring Boot with JUnit and Mockito

ソフトウェア開発では、特にシステムが複雑になるにつれて、高品質のコードを維持することが重要です。自動テストは、新機能が既存の機能を壊さず、長期にわたってコードの堅牢性と信頼性が維持されることを保証する上で極めて重要な役割を果たします。 Spring Boot アプリケーションの場合、JUnit と Mockito は、それぞれ単体テストと依存関係のモック用の 2 つの最も人気のあるツールです。この投稿では、これらのツールを活用して Spring Boot で効果的な自動テストを作成し、アプリケーションの安定性と保守性を確保する方法を検討します。

JUnit は、広く使用されている Java のテスト フレームワークであり、テストの構造化と効率的な実行に役立つアノテーションとアサーションを提供します。これにより、開発者は反復可能なテストを作成でき、単体テストと統合テストの両方がサポートされます。一方、Mockito は、テスト目的でモック オブジェクトを作成できる強力なモック フレームワークです。これにより、開発者は複雑な依存関係の動作をシミュレートし、テスト対象の機能を分離できます。 JUnit を Mockito と組み合わせて使用​​することで、実際のデータベース接続、外部サービス、複雑な構成に依存することなく、Spring Boot アプリケーションのビジネス ロジックを徹底的にテストできます。

実際の例を見て、Spring Boot アプリケーションで JUnit と Mockito をどのように併用できるかを見てみましょう。単純なサービス クラスを作成し、JUnit と Mockito を使用してそのテストを作成します。

ユーザー データを取得するために UserRepository に依存する UserService クラスがあるとします。

@Service
public class UserService {

    private final UserRepository userRepository;

    @Autowired
    public UserService(UserRepository userRepository) {
        this.userRepository = userRepository;
    }

    public User getUserById(Long id) {
        return userRepository.findById(id)
                .orElseThrow(() -> new UserNotFoundException("User not found"));
    }
}

ここで、UserService は Spring Data JPA リポジトリ インターフェイスである UserRepository に依存しています。データベースにアクセスせずに getUserById メソッドをテストするには、Mockito を使用して UserRepository をモックし、JUnit を使用して UserService の動作をアサートします。

UserService のテストを作成する方法は次のとおりです。

@SpringBootTest
public class UserServiceTest {

    @Mock
    private UserRepository userRepository;

    @InjectMocks
    private UserService userService;

    @BeforeEach
    public void setUp() {
        MockitoAnnotations.openMocks(this);
    }

    @Test
    public void testGetUserById_Success() {
        // Arrange
        User user = new User(1L, "John Doe", "john.doe@example.com");
        when(userRepository.findById(1L)).thenReturn(Optional.of(user));

        // Act
        User result = userService.getUserById(1L);

        // Assert
        assertEquals("John Doe", result.getName());
        assertEquals("john.doe@example.com", result.getEmail());
    }

    @Test
    public void testGetUserById_UserNotFound() {
        // Arrange
        when(userRepository.findById(1L)).thenReturn(Optional.empty());

        // Act & Assert
        assertThrows(UserNotFoundException.class, () -> userService.getUserById(1L));
    }
}

UserServiceTest クラスでは、@Mock アノテーションを使用して UserRepository のモック インスタンスを作成し、@InjectMocks アノテーションを使用してこのモックを UserService に注入します。 setUp メソッドは、各テストの前にモックを初期化します。

次に 2 つのテストを定義します。

testGetUserById_Success: このテストは、UserRepository によってユーザーが見つかったときに、UserService が正しいユーザーを返すことを検証します。
testGetUserById_UserNotFound: このテストは、UserRepository が空の結果を返したときに、UserService が UserNotFoundException をスローすることを確認します。
これらのテストにより、実際のデータベースに依存せずに UserService の動作を検証できるため、より高速かつ信頼性が高くなります。

Spring Boot アプリケーションで JUnit と Mockito を使用してテストを自動化すると、コードの品質とアプリケーションの安定性を確保する強力な方法が提供されます。包括的な単体テストを作成することで、開発者は開発プロセスの早い段階でバグを発見できるため、コードのリファクタリングが容易になり、自信を持って新機能を追加できるようになります。 JUnit と Mockito を組み合わせることで、外部依存関係の複雑さから解放され、アプリケーションのビジネス ロジックに焦点を当てた明確で簡潔なテストが可能になります。

自動テストを中心的な実践として採用すると、コードベースの信頼性が向上するだけでなく、全体的な開発ワークフローも強化されます。これらのテストを CI/CD パイプラインに統合することで、品質チェックが自動化され、一貫性が保たれるようになり、より機敏で回復力のある開発プロセスへの道が開かれます。したがって、新しいプロジェクトを開始する場合でも、既存のプロジェクトを拡張する場合でも、JUnit と Mockito を使用した自動テストを開発戦略の一部にしてください。

以上がJUnit と Mockito を使用した Spring Boot でのテストの自動化の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

なぜラッパークラスが必要なのですか? なぜラッパークラスが必要なのですか? Jun 28, 2025 am 01:01 AM

Javaは、基本的なデータ型がオブジェクト指向の操作に直接参加できないため、ラッパークラスを使用し、実際のニーズでオブジェクトフォームが必要になることが多いためです。 1.コレクションクラスは、リストが自動ボクシングを使用して数値を保存するなど、オブジェクトのみを保存できます。 2。ジェネリックは基本的なタイプをサポートしておらず、パッケージングクラスはタイプパラメーターとして使用する必要があります。 3.パッケージングクラスは、null値を表して、データまたは欠落データを区別できます。 4.パッケージングクラスは、データの解析と処理を容易にするための文字列変換などの実用的な方法を提供するため、これらの特性が必要なシナリオでは、パッケージングクラスは不可欠です。

ハッシュマップとハッシュテーブルの違いは? ハッシュマップとハッシュテーブルの違いは? Jun 24, 2025 pm 09:41 PM

ハッシュマップとハッシュテーブルの違いは、主にスレッドの安全性、ヌル価値のサポート、パフォーマンスに反映されます。 1.スレッドの安全性の観点から、ハッシュテーブルはスレッドセーフであり、その方法はほとんど同期メソッドであり、ハッシュマップはスレッドセーフではない同期処理を実行しません。 2。ヌル値のサポートに関しては、ハッシュマップは1つのnullキーと複数のヌル値を許可しますが、ハッシュテーブルはnullキーや値を許可しません。 3.パフォーマンスの観点から、ハッシュマップは同期メカニズムがないため、より効率的です。ハッシュテーブルは、各操作のロックパフォーマンスが低いです。代わりにconcurrenthashmapを使用することをお勧めします。

インターフェイスの静的メソッドとは何ですか? インターフェイスの静的メソッドとは何ですか? Jun 24, 2025 pm 10:57 PM

StaticMethodsinInterfaceswereIntroducatedinjava8toalowutilityは、interfaceitself.beforejava8、そのような導入のために導入されたコード、rediveTodisorgedCode.now、statecmethodssprovidreebenefits:1)彼らの可能性のある測定di

JITコンパイラはどのようにコードを最適化しますか? JITコンパイラはどのようにコードを最適化しますか? Jun 24, 2025 pm 10:45 PM

JITコンパイラは、メソッドインライン、ホットスポット検出とコンピレーション、タイプの投機と偏見、冗長操作の排除の4つの方法を通じてコードを最適化します。 1。メソッドインラインで呼び出しのオーバーヘッドを減らし、頻繁に小さな方法と呼ばれる挿入をコールに直接直接挿入します。 2。ホットスポットの検出と高周波コードの実行とそれを中央に最適化して、リソースを節約します。 3。タイプ投機は、敬v的な呼び出しを達成するためにランタイムタイプ情報を収集し、効率を向上させます。 4.冗長操作は、運用データの削除に基づいて役に立たない計算と検査を排除し、パフォーマンスを向上させます。

インスタンスイニシャルイザーブロックとは何ですか? インスタンスイニシャルイザーブロックとは何ですか? Jun 25, 2025 pm 12:21 PM

インスタンス初期化ブロックは、Javaで使用され、コンストラクターの前に実行されるオブジェクトを作成するときに初期化ロジックを実行します。複数のコンストラクターが初期化コード、複雑なフィールド初期化、または匿名のクラス初期化シナリオを共有するシナリオに適しています。静的初期化ブロックとは異なり、インスタンス化されるたびに実行されますが、静的初期化ブロックはクラスがロードされたときに1回のみ実行されます。

変数の「ファイナル」キーワードは何ですか? 変数の「ファイナル」キーワードは何ですか? Jun 24, 2025 pm 07:29 PM

Injava、thefinalkeywordpreventsavariaibleのValue frombeingededafterassignment、ButiTsbehiviordiffersforprimitivesandobjectReferences

タイプキャストとは何ですか? タイプキャストとは何ですか? Jun 24, 2025 pm 11:09 PM

変換には、暗黙的で明示的な変換には2つのタイプがあります。 1.暗黙的な変換は、INTを2倍に変換するなど、自動的に発生します。 2。明示的な変換には、(int)mydoubleの使用など、手動操作が必要です。タイプ変換が必要な場合には、ユーザー入力の処理、数学操作、または関数間のさまざまなタイプの値の渡されます。注意する必要がある問題は次のとおりです。浮動小数点数を整数に変換すると、分数部分が切り捨てられ、大きなタイプを小さなタイプに変えるとデータの損失につながる可能性があり、一部の言語では特定のタイプの直接変換ができません。言語変換ルールを適切に理解することは、エラーを回避するのに役立ちます。

工場のパターンとは何ですか? 工場のパターンとは何ですか? Jun 24, 2025 pm 11:29 PM

ファクトリーモードは、オブジェクトの作成ロジックをカプセル化するために使用され、コードをより柔軟でメンテナンスしやすく、ゆるく結合します。コアの答えは、オブジェクトの作成ロジックを一元的に管理し、実装の詳細を隠し、複数の関連オブジェクトの作成をサポートすることです。特定の説明は次のとおりです。工場モードは、NewClass()の使用を直接回避し、処理のための特別な工場クラスまたは方法にオブジェクトの作成を手渡します。複数のタイプの関連オブジェクトが作成され、作成ロジックが変更され、実装の詳細を非表示にする必要があるシナリオに適しています。たとえば、支払いプロセッサでは、Stripe、PayPal、その他のインスタンスが工場を通じて作成されます。その実装には、入力パラメーターに基づいて工場クラスによって返されるオブジェクトが含まれ、すべてのオブジェクトは共通のインターフェイスを実現します。一般的なバリアントには、単純な工場、工場法、抽象的な工場が含まれます。これらは異なる複雑さに適しています。

See all articles