EclipseにおけるJUnit5を使ったテストの実施方法


はじめに

こんばんわ、きりです。
本記事はNablarchを使ってみようのサブ記事として作成しております。

JavaにはJUnitという、テストの仕組みがあります。
クラスの追加やクラスの編集を行った際は、JUnitのテストを追加が1セットのようです(多分)。
今回はテストの作成方法や実施方法などについて整理したいと思います。

なお、本記事ではJUnit5を利用します。

本記事以外のコンテンツはこちらから閲覧可能です。

なるべく、初心者目線で作成するつもりですが、分かりづらい部分ありましたら、コメント頂きたいです。

動作環境

種類 バージョン
OS Windows Professional 20H2
Eclipse 2022 Full Edition

※Eclipseのダウンロードについては、こちらの記事をご確認ください。

JUnitのインストール

「Pleiades All in One Eclipse」にはJUnitが既に内包されているようで、インストールは不要です。

JUnitテストケース作成の準備

プロジェクトの作成

こちらを参考に新規でプロジェクトを作成します。

テスト対象のメソッドを作成する

以下のようなテスト用のメソッドを作成します

package helloworld;

public class HelloWorld {

  public static void main(String[] args) {
    // TODO 自動生成されたメソッド・スタブ

  }

  // 引数を加算して返却する
  public int add(int p1, int p2) {
    return p1 + p2;
  }

}

JUnitテストケースの作成

プロパティー>新規>その他をクリックします。

ウィザードを選択ダイアログでJava>JUnit>JUnitテスト・ケースを選択し、次へボタンをクリックします。

「新規JUnit Jupiterテスト」を選択し、名前に「HelloWorldTest」と入力し完了ボタンをクリックします。

JUnit5の追加確認ダイアログでOKボタンをクリックします。

helloworld/src/helloworld/HelloWorldTest.javaが作成されている。
※別記事のEclipseにおけるMavenを使ったシンプルプロジェクトの作成と実行で記載した通り、mavenでプロジェクトを作成するとtest用のjavaファイルは別フォルダに配置するようですが、今回はあまり気にせず同階層に作成しています。

HelloWorldTest.javaを以下のように編集します。

HelloWorldTest.java
package helloworld;

import static org.junit.jupiter.api.Assertions.*;
import org.junit.jupiter.api.Test;

class HelloWorldTest {

  @Test
  void Addメソッドの動作確認() {
    HelloWorld obj = new HelloWorld();
    int addResult = obj.add(3, 5);
    assertEquals(8, addResult);
  }
}

コードの補足をします。

  • 関数名は日本語で指定・・・テスト一覧にテスト関数名が表示されるので、視覚的にわかりやすくするためです
  • テスト対象のメソッドを呼び出します(今回はaddメソッド)
  • 検証方法として、addメソッドの結果と期待値(3+5で8となることを期待してるので、期待値は8)が一致するかをassertEqualsメソッドで確認します。

これで準備完了です。

JUnitテストの実行

プロジェクト名を右クリック>実行>JUnitテストをクリックします。

JUnitテスト結果の確認

JUnitのテストケース一覧とテスト結果はJUnitビューに表示されます。

エラーも失敗も0なので、成功したようです。

次に、ソースを変更してわざと失敗するようにして実行します。
※テストの再実行はJUnitビューからも行えます。

HelloWorldTest.java
package helloworld;

import static org.junit.jupiter.api.Assertions.*;
import org.junit.jupiter.api.Test;

class HelloWorldTest {

  @Test
  void Addメソッドの動作確認() {
    HelloWorld obj = new HelloWorld();
    int addResult = obj.add(3, 5);
    //わざと失敗させる
    //assertEquals(8, addResult);
    assertEquals(9, addResult);
  }
}

今回は期待してるのは9だけど、実行結果は8だったよ。というメッセージと共にテストが失敗しました。

テスト用のコードのデバッグ

中断したいコード行にブレークポイントを作成します。
その後、プロジェクト名を右クリック>デバッグ>JUnitテストをクリックします。

最後に

今回はEclipseにおけるJUnitの基本的な利用方法について整理しました。

一度テストを作成することで、その場限りのテストではなく、今後ソースを変更した際にデグレート(変更により、既存の機能が期待通り動作しなくなること)を起こしていないかの確認にも利用できます。

なお、実用性を考えると、テスト対象のクラスやメソッドに合わせてテスト前準備や後処理、検証方法などが必要となるのですが、
そちらの整理については別の記事にて整理できればと思います。

他の記事についてはこちらから御覧ください。