JUnit-クイックガイド
テストは、アプリケーションの機能をチェックして、要件に従って実行されていることを確認するプロセスです。ユニットテストは、開発者レベルで明らかになります。これは、単一のエンティティ(クラスまたはメソッド)のテストです。単体テストは、ソフトウェア会社が高品質の製品を顧客に提供するのを支援する上で重要な役割を果たします。
単体テストは、手動テストと自動テストの2つの方法で実行できます。
手動テスト | 自動テスト |
---|---|
ツールのサポートなしで手動でテストケースを実行することは、手動テストと呼ばれます。 | 自動化ツールを使用してツールサポートを取得し、テストケースを実行することは、自動化テストと呼ばれます。 |
Time-consuming and tedious −テストケースは人的資源によって実行されるため、非常に時間がかかり、面倒です。 | Fast −自動化は、人的資源よりも大幅に高速にテストケースを実行します。 |
Huge investment in human resources −テストケースは手動で実行する必要があるため、手動テストではより多くのテスターが必要です。 | Less investment in human resources −テストケースは自動化ツールを使用して実行されるため、自動化テストに必要なテスターの数が少なくなります。 |
Less reliable −手動テストは人的エラーを考慮しなければならないため、信頼性が低くなります。 | More reliable −自動化テストは正確で信頼性があります。 |
Non-programmable −隠された情報をフェッチするための高度なテストを作成するためのプログラミングはできません。 | Programmable −テスターは、高度なテストをプログラムして、隠された情報を引き出すことができます。 |
JUnitとは何ですか?
JUnitは、Javaプログラミング言語のユニットテストフレームワークです。これは、テスト駆動開発で重要な役割を果たし、xUnitと総称される単体テストフレームワークのファミリーです。
JUnitは、「最初にテストしてからコーディングする」というアイデアを推進しています。これは、最初にテストしてから実装できるコードのテストデータを設定することに重点を置いています。このアプローチは、「少しテストし、少しコーディングし、少しテストし、少しコーディングする」ようなものです。これにより、プログラマーの生産性とプログラムコードの安定性が向上し、プログラマーへのストレスとデバッグに費やされる時間が削減されます。
JUnitの機能
JUnitはオープンソースのフレームワークであり、テストの作成と実行に使用されます。
テストメソッドを識別するための注釈を提供します。
期待される結果をテストするためのアサーションを提供します。
テストを実行するためのテストランナーを提供します。
JUnitテストを使用すると、コードをより高速に記述できるため、品質が向上します。
JUnitはエレガントでシンプルです。複雑さが少なく、時間もかかりません。
JUnitテストは自動的に実行でき、独自の結果をチェックして即座にフィードバックを提供します。テスト結果のレポートを手動で調べる必要はありません。
JUnitテストは、テストケースやその他のテストスイートを含むテストスイートに編成できます。
JUnitは、テストがスムーズに実行されている場合は緑色のバーにテストの進行状況を表示し、テストが失敗すると赤色に変わります。
ユニットテストケースとは何ですか?
単体テストケースはコードの一部であり、コードの別の部分(メソッド)が期待どおりに機能することを保証します。目的の結果をすばやく達成するには、テストフレームワークが必要です。JUnitは、Javaプログラミング言語に最適な単体テストフレームワークです。
正式な単体テストケースは、既知の入力と期待される出力によって特徴付けられ、テストが実行される前に実行されます。既知の入力は前提条件をテストする必要があり、期待される出力は事後条件をテストする必要があります。
要件ごとに少なくとも2つの単体テストケースが必要です。1つは陽性テスト、もう1つは陰性テストです。要件にサブ要件がある場合、各サブ要件には、ポジティブとネガティブの少なくとも2つのテストケースが必要です。
ローカル環境のセットアップ
JUnitはJavaのフレームワークであるため、最初の要件はJDKをマシンにインストールすることです。
システム要件
JDK | 1.5以上。 |
---|---|
記憶 | 最小要件はありません。 |
ディスクスペース | 最小要件はありません。 |
オペレーティング・システム | 最小要件はありません。 |
ステップ1:マシンへのJavaのインストールを確認する
まず、コンソールを開き、作業しているオペレーティングシステムに基づいてJavaコマンドを実行します。
OS | 仕事 | コマンド |
---|---|---|
ウィンドウズ | コマンドコンソールを開く | c:\> java -version |
Linux | コマンドターミナルを開く | $ java -version |
マック | オープンターミナル | マシン:〜joseph $ java -version |
すべてのオペレーティングシステムの出力を確認しましょう-
OS | 出力 |
---|---|
ウィンドウズ | Javaバージョン「1.8.0_101」 Java(TM)SEランタイム環境(ビルド1.8.0_101) |
Linux | Javaバージョン「1.8.0_101」 Java(TM)SEランタイム環境(ビルド1.8.0_101) |
マック | Javaバージョン「1.8.0_101」 Java(TM)SEランタイム環境(ビルド1.8.0_101) |
システムにJavaがインストールされていない場合は、次のリンクからJavaソフトウェア開発キット(SDK)をダウンロードしてください。 https://www.oracle.com。このチュートリアルのインストールバージョンとして、Java1.8.0_101を想定しています。
ステップ2:JAVA環境を設定する
をセットする JAVA_HOMEJavaがマシンにインストールされているベースディレクトリの場所を指す環境変数。例えば。
OS | 出力 |
---|---|
ウィンドウズ | 環境変数JAVA_HOMEをC:\ Program Files \ Java \ jdk1.8.0_101に設定します |
Linux | export JAVA_HOME = / usr / local / java-current |
マック | export JAVA_HOME = / Library / Java / Home |
Javaコンパイラの場所をシステムパスに追加します。
OS | 出力 |
---|---|
ウィンドウズ | 文字列を追加します C:\Program Files\Java\jdk1.8.0_101\bin システム変数の最後に、 Path。 |
Linux | エクスポートパス= $PATH:$JAVA_HOME / bin / |
マック | 必要ありません |
コマンドを使用してJavaのインストールを確認します java -version 上で説明したように。
ステップ3:JUnitアーカイブをダウンロードする
JUnitjarファイルの最新バージョンをからダウンロードします。 http://www.junit.org。このチュートリアルの執筆時点では、Junit-4.12.jarをダウンロードして、C:\> JUnitフォルダーにコピーしています。
OS | アーカイブ名 |
---|---|
ウィンドウズ | junit4.12.jar |
Linux | junit4.12.jar |
マック | junit4.12.jar |
ステップ4:JUnit環境を設定する
をセットする JUNIT_HOMEJUNITjarがマシンに格納されているベースディレクトリの場所を指す環境変数。junit4.12.jarをJUNITフォルダーに保管したとしましょう。
シニア番号 | OSと説明 |
---|---|
1 | Windows 環境変数JUNIT_HOMEをC:\ JUNITに設定します |
2 | Linux エクスポートJUNIT_HOME = / usr / local / JUNIT |
3 | Mac エクスポートJUNIT_HOME = / Library / JUNIT |
ステップ5:CLASSPATH変数を設定する
をセットする CLASSPATH JUNITjarの場所を指す環境変数。
シニア番号 | OSと説明 |
---|---|
1 | Windows 環境変数CLASSPATHを%CLASSPATH%;%JUNIT_HOME%\ junit4.12.jar;。;に設定します。 |
2 | Linux CLASSPATHのエクスポート= $CLASSPATH:$JUNIT_HOME /junit4.12.jar:。 |
3 | Mac CLASSPATHのエクスポート= $CLASSPATH:$JUNIT_HOME /junit4.12.jar:。 |
ステップ6:JUnitセットアップをテストする
でJavaクラスファイル名TestJunitを作成します C:\>JUNIT_WORKSPACE
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
@Test
public void testAdd() {
String str = "Junit is working fine";
assertEquals("Junit is working fine",str);
}
}
でJavaクラスファイル名TestRunnerを作成します C:\>JUNIT_WORKSPACE テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
ステップ7:結果を確認する
を使用してクラスをコンパイルします javac 次のようにコンパイラ-
C:\JUNIT_WORKSPACE>javac TestJunit.java TestRunner.java
次に、テストランナーを実行して、次のような結果を確認します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
true
JUnitは Regression Testing Framework開発者がJavaで単体テストを実装し、プログラミング速度を加速してコードの品質を向上させるために使用します。JUnit Frameworkは、次のいずれかと簡単に統合できます。
- Eclipse
- Ant
- Maven
JUnitテストフレームワークの機能
JUnitテストフレームワークは次の重要な機能を提供します-
- Fixtures
- テストスイート
- テストランナー
- JUnitクラス
備品
Fixturesテストを実行するためのベースラインとして使用されるオブジェクトのセットの固定状態です。テストフィクスチャの目的は、テストが実行されるよく知られた固定環境が存在することを確認して、結果を再現できるようにすることです。含まれています-
- setUp()メソッド。すべてのテスト呼び出しの前に実行されます。
- すべてのテストメソッドの後に実行されるtearDown()メソッド。
一例を見てみましょう-
import junit.framework.*;
public class JavaTest extends TestCase {
protected int value1, value2;
// assigning the values
protected void setUp(){
value1 = 3;
value2 = 3;
}
// test method to add two values
public void testAdd(){
double result = value1 + value2;
assertTrue(result == 6);
}
}
テストスイート
テストスイートは、いくつかの単体テストケースをバンドルし、それらを一緒に実行します。JUnitでは、@ RunWithアノテーションと@Suiteアノテーションの両方を使用してスイートテストを実行します。以下に、TestJunit1およびTestJunit2テストクラスを使用する例を示します。
import org.junit.runner.RunWith;
import org.junit.runners.Suite;
//JUnit Suite Test
@RunWith(Suite.class)
@Suite.SuiteClasses({
TestJunit1.class ,TestJunit2.class
})
public class JunitTestSuite {
}
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestJunit1 {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
assertEquals(message, messageUtil.printMessage());
}
}
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestJunit2 {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Robert";
assertEquals(message,messageUtil.salutationMessage());
}
}
テストランナー
テストランナーは、テストケースの実行に使用されます。これは、テストクラスを想定した例です。TestJunit もう存在している。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
JUnitクラス
JUnitクラスは重要なクラスであり、JUnitの作成とテストに使用されます。重要なクラスのいくつかは次のとおりです。
Assert −一連のassertメソッドが含まれています。
TestCase −複数のテストを実行するためのフィクスチャを定義するテストケースが含まれています。
TestResult −テストケースの実行結果を収集するためのメソッドが含まれています。
ここで、JUnitを使用するステップバイステップのプロセスを示す基本的な例を示します。
クラスを作成する
テストするJavaクラスを作成します。たとえば、MessageUtil.javaを C:\>JUNIT_WORKSPACE
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public String printMessage(){
System.out.println(message);
return message;
}
}
テストケースクラスを作成する
- TestJunit.javaなどのJavaテストクラスを作成します。
- テストメソッドtestPrintMessage()をテストクラスに追加します。
- Annotaion @TestをメソッドtestPrintMessage()に追加します。
- テスト条件を実装し、JUnitのassertEqualsAPIを使用して条件を確認します。
でJavaクラスファイル名TestJunit.javaを作成します C:\>JUNIT_WORKSPACE。
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
assertEquals(message,messageUtil.printMessage());
}
}
テストランナークラスを作成する
- TestRunnerJavaクラスを作成します。
- JUnitのJUnitCoreクラスのrunClassesメソッドを使用して、上記で作成したテストクラスのテストケースを実行します。
- 結果オブジェクトで実行されたテストケースの結果を取得します。
- ResultオブジェクトのgetFailures()メソッドを使用して失敗を取得します。
- ResultオブジェクトのwasSuccessful()メソッドを使用して成功結果を取得します。
TestRunner.javaという名前のJavaクラスファイルをで作成します。 C:\>JUNIT_WORKSPACE テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用して、MessageUtil、テストケース、およびテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
Hello World
true
次に、TestJunitを更新します C:\>JUNIT_WORKSPACEテストが失敗するように。メッセージ文字列を変更します。
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
message = "New Word";
assertEquals(message,messageUtil.printMessage());
}
}
残りのクラスはそのままにして、同じテストランナーを実行してみましょう。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
Hello World
testPrintMessage(TestJunit): expected:<[New Wor]d> but was:<[Hello Worl]d>
false
JUnitで最も重要なパッケージは junit.framework、すべてのコアクラスが含まれています。重要なクラスのいくつかは次のとおりです-
シニア番号 | クラス名 | 機能性 |
---|---|---|
1 | 主張する | 一連のassertメソッド。 |
2 | テストケース | テストケースは、複数のテストを実行するためのフィクスチャを定義します。 |
3 | テスト結果 | TestResultは、テストケースの実行結果を収集します。 |
4 | TestSuite | TestSuiteは、テストを組み合わせたものです。 |
クラスをアサートする
以下はの宣言です org.junit.Assert クラス-
public class Assert extends java.lang.Object
このクラスは、テストの作成に役立つ一連のアサーションメソッドを提供します。失敗したアサーションのみが記録されます。Assertクラスの重要なメソッドのいくつかは次のとおりです-
シニア番号 | 方法と説明 |
---|---|
1 | void assertEquals(boolean expected, boolean actual) 2つのプリミティブ/オブジェクトが等しいことを確認します。 |
2 | void assertFalse(boolean condition) 条件が偽であることを確認します。 |
3 | void assertNotNull(Object object) オブジェクトがnullでないことを確認します。 |
4 | void assertNull(Object object) オブジェクトがnullであることを確認します。 |
5 | void assertTrue(boolean condition) 条件が真であることを確認します。 |
6 | void fail() メッセージなしでテストに失敗します。 |
例では、上記の方法のいくつかを使用してみましょう。TestJunit1.javaという名前のJavaクラスファイルをで作成します。C:\>JUNIT_WORKSPACE。
import org.junit.Test;
import static org.junit.Assert.*;
public class TestJunit1 {
@Test
public void testAdd() {
//test data
int num = 5;
String temp = null;
String str = "Junit is working fine";
//check for equality
assertEquals("Junit is working fine", str);
//check for false condition
assertFalse(num > 6);
//check for not null value
assertNotNull(temp);
}
}
次に、という名前のJavaクラスファイルを作成します TestRunner1.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner1 {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit1.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してテストケースとテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac TestJunit1.java TestRunner1.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner1
出力を確認します。
true
TestCaseクラス
以下はの宣言です org.junit.TestCase クラス-
public abstract class TestCase extends Assert implements Test
テストケースは、複数のテストを実行するためのフィクスチャを定義します。の重要な方法のいくつかTestCase クラスは以下の通りです−
シニア番号 | 方法と説明 |
---|---|
1 | int countTestCases() run(TestResult result)によって実行されたテストケースの数をカウントします。 |
2 | TestResult createResult() デフォルトのTestResultオブジェクトを作成します。 |
3 | String getName() TestCaseの名前を取得します。 |
4 | TestResult run() このテストを実行するための便利なメソッドで、デフォルトのTestResultオブジェクトを使用して結果を収集します。 |
5 | void run(TestResult result) テストケースを実行し、結果をTestResultに収集します。 |
6 | void setName(String name) TestCaseの名前を設定します。 |
7 | void setUp() フィクスチャを設定します。たとえば、ネットワーク接続を開きます。 |
8 | void tearDown() たとえば、フィクスチャを切り離して、ネットワーク接続を閉じます。 |
9 | String toString() テストケースの文字列表現を返します。 |
例では、上記の方法のいくつかを使用してみましょう。名前の付いたJavaクラスファイルを作成しますTestJunit2.java C:\> JUNIT_WORKSPACEで。
import junit.framework.TestCase;
import org.junit.Before;
import org.junit.Test;
public class TestJunit2 extends TestCase {
protected double fValue1;
protected double fValue2;
@Before
public void setUp() {
fValue1 = 2.0;
fValue2 = 3.0;
}
@Test
public void testAdd() {
//count the number of test cases
System.out.println("No of Test Case = "+ this.countTestCases());
//test getName
String name = this.getName();
System.out.println("Test Case Name = "+ name);
//test setName
this.setName("testNewAdd");
String newName = this.getName();
System.out.println("Updated Test Case Name = "+ newName);
}
//tearDown used to close the connection or clean up activities
public void tearDown( ) {
}
}
次に、という名前のJavaクラスファイルを作成します TestRunner2.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner2 {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit2.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してテストケースとテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac TestJunit2.java TestRunner2.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner2
出力を確認します。
No of Test Case = 1
Test Case Name = testAdd
Updated Test Case Name = testNewAdd
true
TestResultクラス
以下はの宣言です org.junit.TestResult クラス-
public class TestResult extends Object
TestResultは、テストケースの実行結果を収集します。これは、CollectingParameterパターンのインスタンスです。テストフレームワークは、失敗とエラーを区別します。障害が予想され、アサーションでチェックされます。エラーは、ArrayIndexOutOfBoundsExceptionのような予期しない問題です。の重要な方法のいくつかTestResult クラスは以下の通りです−
シニア番号 | 方法と説明 |
---|---|
1 | void addError(Test test, Throwable t) エラーのリストにエラーを追加します。 |
2 | void addFailure(Test test, AssertionFailedError t) 失敗のリストに失敗を追加します。 |
3 | void endTest(Test test) テストが完了したことを結果に通知します。 |
4 | int errorCount() 検出されたエラーの数を取得します。 |
5 | Enumeration<TestFailure> errors() エラーの列挙型を返します。 |
6 | int failureCount() 検出された障害の数を取得します。 |
7 | void run(TestCase test) TestCaseを実行します。 |
8 | int runCount() 実行テストの数を取得します。 |
9 | void startTest(Test test) テストが開始されることを結果に通知します。 |
10 | void stop() テストの実行を停止する必要があることを示します。 |
名前の付いたJavaクラスファイルを作成します TestJunit3.java C:\> JUNIT_WORKSPACEで。
import org.junit.Test;
import junit.framework.AssertionFailedError;
import junit.framework.TestResult;
public class TestJunit3 extends TestResult {
// add the error
public synchronized void addError(Test test, Throwable t) {
super.addError((junit.framework.Test) test, t);
}
// add the failure
public synchronized void addFailure(Test test, AssertionFailedError t) {
super.addFailure((junit.framework.Test) test, t);
}
@Test
public void testAdd() {
// add any test
}
// Marks that the test run should stop.
public synchronized void stop() {
//stop the test here
}
}
次に、という名前のJavaクラスファイルを作成します TestRunner3.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner3 {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit3.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してテストケースとテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac TestJunit3.java TestRunner3.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner3
出力を確認します。
true
TestSuiteクラス
以下はの宣言です org.junit.TestSuite クラス:
public class TestSuite extends Object implements Test
TestSuiteは、テストを組み合わせたものです。テストケースのコレクションを実行します。の重要な方法のいくつかTestSuite クラスは以下の通りです−
シニア番号 | 方法と説明 |
---|---|
1 | void addTest(Test test) スイートにテストを追加します。 |
2 | void addTestSuite(Class<? extends TestCase> testClass) 指定されたクラスのテストをスイートに追加します。 |
3 | int countTestCases() このテストによって実行されるテストケースの数をカウントします。 |
4 | String getName() スイートの名前を返します。 |
5 | void run(TestResult result) テストを実行し、その結果をTestResultに収集します。 |
6 | void setName(String name) スイートの名前を設定します。 |
7 | Test testAt(int index) 指定されたインデックスでのテストを返します。 |
8 | int testCount() このスイートのテストの数を返します。 |
9 | static Test warning(String message) 失敗するテストを返し、警告メッセージをログに記録します。 |
名前の付いたJavaクラスファイルを作成します JunitTestSuite.java C:\> JUNIT_WORKSPACEで、テストスイートを作成します。
import junit.framework.*;
public class JunitTestSuite {
public static void main(String[] a) {
// add the test's in the suite
TestSuite suite = new TestSuite(TestJunit1.class, TestJunit2.class, TestJunit3.class );
TestResult result = new TestResult();
suite.run(result);
System.out.println("Number of test cases = " + result.runCount());
}
}
javacを使用してテストスイートクラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac JunitTestSuite.java
次に、テストスイートを実行します。
C:\JUNIT_WORKSPACE>java JunitTestSuite
出力を確認します。
No of Test Case = 1
Test Case Name = testAdd
Updated Test Case Name = testNewAdd
Number of test cases = 3
ここでは、POJOクラス、ビジネスロジッククラス、およびテストランナーによって実行されるテストクラスを使用したJUnitテストの1つの完全な例を示します。
作成する EmployeeDetails.java POJOクラスであるC:\> JUNIT_WORKSPACE内。
public class EmployeeDetails {
private String name;
private double monthlySalary;
private int age;
/**
* @return the name
*/
public String getName() {
return name;
}
/**
* @param name the name to set
*/
public void setName(String name) {
this.name = name;
}
/**
* @return the monthlySalary
*/
public double getMonthlySalary() {
return monthlySalary;
}
/**
* @param monthlySalary the monthlySalary to set
*/
public void setMonthlySalary(double monthlySalary) {
this.monthlySalary = monthlySalary;
}
/**
* @return the age
*/
public int getAge() {
return age;
}
/**
* @param age the age to set
*/
public void setAge(int age) {
this.age = age;
}
}
EmployeeDetails クラスはに使用されます-
- 従業員の名前の値を取得/設定します。
- 従業員の月給の値を取得/設定します。
- 従業員の年齢の値を取得/設定します。
というファイルを作成します EmpBusinessLogic.java C:\> JUNIT_WORKSPACEで、ビジネスロジックが含まれています。
public class EmpBusinessLogic {
// Calculate the yearly salary of employee
public double calculateYearlySalary(EmployeeDetails employeeDetails) {
double yearlySalary = 0;
yearlySalary = employeeDetails.getMonthlySalary() * 12;
return yearlySalary;
}
// Calculate the appraisal amount of employee
public double calculateAppraisal(EmployeeDetails employeeDetails) {
double appraisal = 0;
if(employeeDetails.getMonthlySalary() < 10000){
appraisal = 500;
}else{
appraisal = 1000;
}
return appraisal;
}
}
EmpBusinessLogic クラスは計算に使用されます-
- 従業員の年俸。
- 従業員の評価額。
というファイルを作成します TestEmployeeDetails.java C:\> JUNIT_WORKSPACEにあります。これには、テストするテストケースが含まれています。
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestEmployeeDetails {
EmpBusinessLogic empBusinessLogic = new EmpBusinessLogic();
EmployeeDetails employee = new EmployeeDetails();
//test to check appraisal
@Test
public void testCalculateAppriasal() {
employee.setName("Rajeev");
employee.setAge(25);
employee.setMonthlySalary(8000);
double appraisal = empBusinessLogic.calculateAppraisal(employee);
assertEquals(500, appraisal, 0.0);
}
// test to check yearly salary
@Test
public void testCalculateYearlySalary() {
employee.setName("Rajeev");
employee.setAge(25);
employee.setMonthlySalary(8000);
double salary = empBusinessLogic.calculateYearlySalary(employee);
assertEquals(96000, salary, 0.0);
}
}
TestEmployeeDetails クラスは、のメソッドをテストするために使用されます EmpBusinessLogicクラス。それ
- 従業員の年俸をテストします。
- 従業員の評価額をテストします。
次に、という名前のJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestEmployeeDetails.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してテストケースとテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac EmployeeDetails.java
EmpBusinessLogic.java TestEmployeeDetails.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
true
アサーション
すべてのアサーションはAssertクラスにあります。
public class Assert extends java.lang.Object
このクラスは、テストの作成に役立つ一連のアサーションメソッドを提供します。失敗したアサーションのみが記録されます。Assertクラスの重要なメソッドのいくつかは次のとおりです-
シニア番号 | 方法と説明 |
---|---|
1 | void assertEquals(boolean expected, boolean actual) 2つのプリミティブ/オブジェクトが等しいことを確認します。 |
2 | void assertTrue(boolean condition) 条件が真であることを確認します。 |
3 | void assertFalse(boolean condition) 条件が偽であることを確認します。 |
4 | void assertNotNull(Object object) オブジェクトがnullでないことを確認します。 |
5 | void assertNull(Object object) オブジェクトがnullであることを確認します。 |
6 | void assertSame(object1, object2) assertSame()メソッドは、2つのオブジェクト参照が同じオブジェクトを指しているかどうかをテストします。 |
7 | void assertNotSame(object1, object2) assertNotSame()メソッドは、2つのオブジェクト参照が同じオブジェクトを指していないかどうかをテストします。 |
8 | void assertArrayEquals(expectedArray, resultArray); assertArrayEquals()メソッドは、2つの配列が互いに等しいかどうかをテストします。 |
例では、上記の方法のいくつかを使用してみましょう。名前の付いたJavaクラスファイルを作成しますTestAssertions.java C:\> JUNIT_WORKSPACEで。
import org.junit.Test;
import static org.junit.Assert.*;
public class TestAssertions {
@Test
public void testAssertions() {
//test data
String str1 = new String ("abc");
String str2 = new String ("abc");
String str3 = null;
String str4 = "abc";
String str5 = "abc";
int val1 = 5;
int val2 = 6;
String[] expectedArray = {"one", "two", "three"};
String[] resultArray = {"one", "two", "three"};
//Check that two objects are equal
assertEquals(str1, str2);
//Check that a condition is true
assertTrue (val1 < val2);
//Check that a condition is false
assertFalse(val1 > val2);
//Check that an object isn't null
assertNotNull(str1);
//Check that an object is null
assertNull(str3);
//Check if two object references point to the same object
assertSame(str4,str5);
//Check if two object references not point to the same object
assertNotSame(str1,str3);
//Check whether two arrays are equal to each other.
assertArrayEquals(expectedArray, resultArray);
}
}
次に、という名前のJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner2 {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestAssertions.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してテストケースクラスとテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac TestAssertions.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
true
注釈
アノテーションは、コードに追加してメソッドやクラスに適用できるメタタグのようなものです。JUnitのこれらのアノテーションは、テストメソッドに関する次の情報を提供します-
- テストメソッドの前後にどのメソッドを実行するか。
- すべてのメソッドの前後に実行されるメソッド、および。
- 実行中に無視されるメソッドまたはクラス。
次の表に、JUnitでの注釈とその意味のリストを示します。
シニア番号 | 注釈と説明 |
---|---|
1 | @Test Testアノテーションは、それがアタッチされているpublicvoidメソッドをテストケースとして実行できることをJUnitに通知します。 |
2 | @Before いくつかのテストでは、実行する前に同様のオブジェクトを作成する必要があります。public voidメソッドに@Beforeアノテーションを付けると、そのメソッドが各Testメソッドの前に実行されます。 |
3 | @After Beforeメソッドで外部リソースを割り当てる場合は、テストの実行後にそれらを解放する必要があります。public voidメソッドに@Afterアノテーションを付けると、そのメソッドはTestメソッドの後に実行されます。 |
4 | @BeforeClass public static voidメソッドに@BeforeClassアノテーションを付けると、クラス内のテストメソッドの前に1回実行されます。 |
5 | @AfterClass これにより、すべてのテストが終了した後にメソッドが実行されます。これは、クリーンアップアクティビティを実行するために使用できます。 |
6 | @Ignore Ignoreアノテーションは、テストを無視するために使用され、そのテストは実行されません。 |
名前の付いたJavaクラスファイルを作成します JunitAnnotation.java C:\> JUNIT_WORKSPACEで、注釈をテストします。
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test;
public class JunitAnnotation {
//execute before class
@BeforeClass
public static void beforeClass() {
System.out.println("in before class");
}
//execute after class
@AfterClass
public static void afterClass() {
System.out.println("in after class");
}
//execute before test
@Before
public void before() {
System.out.println("in before");
}
//execute after test
@After
public void after() {
System.out.println("in after");
}
//test case
@Test
public void test() {
System.out.println("in test");
}
//test case ignore and will not execute
@Ignore
public void ignoreTest() {
System.out.println("in ignore test");
}
}
次に、という名前のJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、注釈を実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(JunitAnnotation.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してテストケースクラスとテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac JunitAnnotation.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
in before class
in before
in test
in after
in after class
true
この章では、呼び出されるメソッドの順序を定義するJUnitでのメソッドの実行手順について説明します。以下では、JUnitテストAPIメソッドの実行手順を例とともに説明します。
アノテーションをテストするには、C:\> JUNIT_WORKSPACEにExecutionProcedureJunit.javaという名前のJavaクラスファイルを作成します。
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test;
public class ExecutionProcedureJunit {
//execute only once, in the starting
@BeforeClass
public static void beforeClass() {
System.out.println("in before class");
}
//execute only once, in the end
@AfterClass
public static void afterClass() {
System.out.println("in after class");
}
//execute for each test, before executing test
@Before
public void before() {
System.out.println("in before");
}
//execute for each test, after executing test
@After
public void after() {
System.out.println("in after");
}
//test case 1
@Test
public void testCase1() {
System.out.println("in test case 1");
}
//test case 2
@Test
public void testCase2() {
System.out.println("in test case 2");
}
}
次に、という名前のJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、注釈を実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(ExecutionProcedureJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してテストケースクラスとテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac ExecutionProcedureJunit.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
in before class
in before
in test case 1
in after
in before
in test case 2
in after
in after class
上記の出力を参照してください。実行手順は以下のとおりです。
- まず、beforeClass()メソッドは1回だけ実行されます。
- afterClass()メソッドは1回だけ実行されます。
- before()メソッドは、テストケースごとに実行されますが、テストケースを実行する前に実行されます。
- after()メソッドは、テストケースごとに実行されますが、テストケースの実行後に実行されます。
- before()とafter()の間に、各テストケースが実行されます。
テストケースは、 JUnitCoreクラス。JUnitCoreは、テストを実行するためのファサードです。JUnit 4テスト、JUnit 3.8.xテスト、および混合の実行をサポートします。コマンドラインからテストを実行するには、java org.junit.runner.JUnitCore <TestClass>を実行します。ワンショットテストの実行には、静的メソッドrunClasses(Class [])を使用します。
以下はの宣言です org.junit.runner.JUnitCore クラス:
public class JUnitCore extends java.lang.Object
ここでは、JUnitCoreを使用してテストを実行する方法を説明します。
クラスを作成する
テストするJavaクラスを作成します。たとえば、 MessageUtil.java、C:\> JUNIT_WORKSPACEで。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public String printMessage(){
System.out.println(message);
return message;
}
}
テストケースクラスを作成する
TestJunit.javaなどのJavaテストクラスを作成します。
テストメソッドtestPrintMessage()をテストクラスに追加します。
annotaion @TestをメソッドtestPrintMessage()に追加します。
テスト条件を実装し、JUnitのassertEqualsAPIを使用して条件を確認します。
名前の付いたJavaクラスファイルを作成します TestJunit.java C:\> JUNIT_WORKSPACEで。
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
assertEquals(message,messageUtil.printMessage());
}
}
テストランナークラスを作成する
次に、という名前のJavaクラスファイルを作成します TestRunner.javaC:\> JUNIT_WORKSPACEで、テストケースを実行します。JUnitCoreクラスをインポートし、テストクラス名をパラメーターとして受け取るrunClasses()メソッドを使用します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してテストケースクラスとテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
Hello World
true
Test suiteいくつかの単体テストケースをバンドルして一緒に実行するために使用されます。JUnitでは、両方@RunWith そして @Suiteアノテーションは、スイートテストを実行するために使用されます。この章では、2つのテストクラスを持つ例を取り上げます。TestJunit1 & TestJunit2、TestSuiteを使用して一緒に実行されます。
クラスを作成する
テストするJavaクラスを作成します。たとえば、 MessageUtil.java C:\> JUNIT_WORKSPACEで。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public String printMessage(){
System.out.println(message);
return message;
}
// add "Hi!" to the message
public String salutationMessage(){
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
テストケースクラスを作成する
名前の付いたJavaクラスファイルを作成します TestJunit1.java C:\> JUNIT_WORKSPACEで。
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestJunit1 {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
assertEquals(message, messageUtil.printMessage());
}
}
名前の付いたJavaクラスファイルを作成します TestJunit2.java C:\> JUNIT_WORKSPACEで。
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestJunit2 {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Robert";
assertEquals(message,messageUtil.salutationMessage());
}
}
テストスイートクラスを作成する
- Javaクラスを作成します。
- @RunWith(Suite.class)アノテーションをクラスにアタッチします。
- @ Suite.SuiteClassesアノテーションを使用して、JUnitテストクラスへの参照を追加します。
名前の付いたJavaクラスファイルを作成します TestSuite.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.RunWith;
import org.junit.runners.Suite;
@RunWith(Suite.class)
@Suite.SuiteClasses({
TestJunit1.class,
TestJunit2.class
})
public class JunitTestSuite {
}
テストランナークラスを作成する
名前の付いたJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(JunitTestSuite.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用してすべてのJavaクラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit1.java
TestJunit2.java JunitTestSuite.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
Inside testPrintMessage()
Robert
Inside testSalutationMessage()
Hi Robert
true
テストケースの実行中にコードの準備が完全に整っていない場合があります。その結果、テストケースは失敗します。ザ・@Ignore このシナリオでは、注釈が役立ちます。
@Ignoreアノテーションが付けられたテストメソッドは実行されません。
テストクラスに@Ignoreアノテーションが付けられている場合、そのテストメソッドは実行されません。
それでは、@ Ignoreの動作を見てみましょう。
クラスを作成する
テストするJavaクラスを作成します。たとえば、 MessageUtil.java C:\> JUNIT_WORKSPACEで。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public String printMessage(){
System.out.println(message);
return message;
}
// add "Hi!" to the message
public String salutationMessage(){
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
テストケースクラスを作成する
TestJunit.javaなどのJavaテストクラスを作成します。
テストメソッドtestPrintMessage()またはtestSalutationMessage()をテストクラスに追加します。
メソッドtestPrintMessage()にアノテーション@Ignoreを追加します。
名前の付いたJavaクラスファイルを作成します TestJunit.java C:\ JUNIT_WORKSPACEにあります。
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Ignore
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
message = "Robert";
assertEquals(message,messageUtil.printMessage());
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Robert";
assertEquals(message,messageUtil.salutationMessage());
}
}
テストランナークラスを作成する
名前の付いたJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用して、MessageUtil、テストケース、およびテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
次に、提供されたテストケースクラスで定義されたtestPrintMessage()テストケースを実行しないテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。testPrintMessage()テストケースはテストされていません。
Inside testSalutationMessage()
Hi!Robert
true
ここで、C:\> JUNIT_WORKSPACEのTestJunitを更新して、すべてのテストケースを無視します。クラスレベルで@Ignoreを追加します。
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
@Ignore
public class TestJunit {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
message = "Robert";
assertEquals(message,messageUtil.printMessage());
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Robert";
assertEquals(message,messageUtil.salutationMessage());
}
}
javacを使用してテストケースをコンパイルします。
C:\JUNIT_WORKSPACE>javac TestJunit.java
次のように、テストランナーを変更しないでください。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
次に、提供されたテストケースクラスで定義されたテストケースを実行しないテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。テストケースはテストされていません。
true
JUnitは、タイムアウトの便利なオプションを提供します。テストケースに指定されたミリ秒数よりも時間がかかる場合、JUnitは自動的にテストケースを失敗としてマークします。ザ・timeoutパラメータは@Testアノテーションとともに使用されます。@Test(timeout)の動作を見てみましょう。
クラスを作成する
テストするJavaクラスを作成します。たとえば、 MessageUtil.java C:\> JUNIT_WORKSPACEで。
printMessage()メソッド内に無限のwhileループを追加します。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public void printMessage(){
System.out.println(message);
while(true);
}
// add "Hi!" to the message
public String salutationMessage(){
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
テストケースクラスを作成する
たとえば、Javaテストクラスを作成します。 TestJunit.java。testPrintMessage()テストケースに1000のタイムアウトを追加します。
名前の付いたJavaクラスファイルを作成します TestJunit.java C:\> JUNIT_WORKSPACEで。
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test(timeout = 1000)
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
messageUtil.printMessage();
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Robert";
assertEquals(message,messageUtil.salutationMessage());
}
}
テストランナークラスを作成する
名前の付いたJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用して、MessageUtil、テストケース、およびテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。testPrintMessage()テストケースは、単体テストが失敗したことを示します。
Inside testPrintMessage()
Robert
Inside testSalutationMessage()
Hi!Robert
testPrintMessage(TestJunit): test timed out after 1000 milliseconds
false
JUnitには、コードの例外処理をトレースするオプションがあります。コードが目的の例外をスローするかどうかをテストできます。ザ・expectedパラメータは@Testアノテーションとともに使用されます。@Test(expected)の動作を見てみましょう。
クラスを作成する
テストするJavaクラスを作成します。たとえば、 MessageUtil.java C:\> JUNIT_WORKSPACEで。
printMessage()メソッド内にエラー条件を追加します。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public void printMessage(){
System.out.println(message);
int a = 0;
int b = 1/a;
}
// add "Hi!" to the message
public String salutationMessage(){
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
テストケースクラスを作成する
と呼ばれるJavaテストクラスを作成します TestJunit.java。予期される例外ArithmeticExceptionをtestPrintMessage()テストケースに追加します。
名前の付いたJavaクラスファイルを作成します TestJunit.java C:\> JUNIT_WORKSPACEで。
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test(expected = ArithmeticException.class)
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
messageUtil.printMessage();
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Robert";
assertEquals(message,messageUtil.salutationMessage());
}
}
テストランナークラスを作成する
名前の付いたJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用して、MessageUtil、テストケース、およびテストランナークラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。testPrintMessage()テストケースに合格します。
Inside testPrintMessage()
Robert
Inside testSalutationMessage()
Hi!Robert
true
JUnit4はと呼ばれる新機能を導入しました parameterized tests。パラメータ化されたテストにより、開発者は異なる値を使用して同じテストを何度も実行できます。パラメータ化されたテストを作成するために従う必要がある5つのステップがあります。
テストクラスに@RunWith(Parameterized.class)アノテーションを付けます。
オブジェクトのコレクション(配列として)をテストデータセットとして返す、@ Parametersアノテーションが付けられたパブリック静的メソッドを作成します。
テストデータの1つの「行」に相当するものを取り込むパブリックコンストラクターを作成します。
テストデータの「列」ごとにインスタンス変数を作成します。
テストデータのソースとしてインスタンス変数を使用して、テストケースを作成します。
テストケースは、データの行ごとに1回呼び出されます。パラメータ化されたテストの動作を見てみましょう。
クラスを作成する
テストするJavaクラスを作成します。たとえば、 PrimeNumberChecker.java C:\> JUNIT_WORKSPACEで。
public class PrimeNumberChecker {
public Boolean validate(final Integer primeNumber) {
for (int i = 2; i < (primeNumber / 2); i++) {
if (primeNumber % i == 0) {
return false;
}
}
return true;
}
}
パラメータ化されたテストケースクラスを作成する
たとえば、Javaテストクラスを作成します。 PrimeNumberCheckerTest.java。名前の付いたJavaクラスファイルを作成しますPrimeNumberCheckerTest.java C:\> JUNIT_WORKSPACEで。
import java.util.Arrays;
import java.util.Collection;
import org.junit.Test;
import org.junit.Before;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import org.junit.runner.RunWith;
import static org.junit.Assert.assertEquals;
@RunWith(Parameterized.class)
public class PrimeNumberCheckerTest {
private Integer inputNumber;
private Boolean expectedResult;
private PrimeNumberChecker primeNumberChecker;
@Before
public void initialize() {
primeNumberChecker = new PrimeNumberChecker();
}
// Each parameter should be placed as an argument here
// Every time runner triggers, it will pass the arguments
// from parameters we defined in primeNumbers() method
public PrimeNumberCheckerTest(Integer inputNumber, Boolean expectedResult) {
this.inputNumber = inputNumber;
this.expectedResult = expectedResult;
}
@Parameterized.Parameters
public static Collection primeNumbers() {
return Arrays.asList(new Object[][] {
{ 2, true },
{ 6, false },
{ 19, true },
{ 22, false },
{ 23, true }
});
}
// This test will run 4 times since we have 5 parameters defined
@Test
public void testPrimeNumberChecker() {
System.out.println("Parameterized Number is : " + inputNumber);
assertEquals(expectedResult,
primeNumberChecker.validate(inputNumber));
}
}
テストランナークラスを作成する
名前の付いたJavaクラスファイルを作成します TestRunner.java C:\> JUNIT_WORKSPACEで、テストケースを実行します。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(PrimeNumberCheckerTest.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
javacを使用して、PrimeNumberChecker、PrimeNumberCheckerTest、およびTestRunnerクラスをコンパイルします。
C:\JUNIT_WORKSPACE>javac PrimeNumberChecker.java PrimeNumberCheckerTest.java
TestRunner.java
次に、提供されたテストケースクラスで定義されたテストケースを実行するテストランナーを実行します。
C:\JUNIT_WORKSPACE>java TestRunner
出力を確認します。
Parameterized Number is : 2
Parameterized Number is : 6
Parameterized Number is : 19
Parameterized Number is : 22
Parameterized Number is : 23
true
ANTを使用してJUnitを実行する方法を示す例があります。以下の手順に従ってください。
ステップ1:ApacheAntをダウンロードする
使用しているオペレーティングシステムに基づいてApacheAntをダウンロードします。
OS | アーカイブ名 |
---|---|
ウィンドウズ | apache-ant-1.8.4-bin.zip |
Linux | apache-ant-1.8.4-bin.tar.gz |
マック | apache-ant-1.8.4-bin.tar.gz |
ステップ2:Ant環境を設定する
をセットする ANT_HOMEANTライブラリがマシンに保存されているベースディレクトリの場所を指す環境変数。Antライブラリがapache-ant-1.8.4フォルダーに格納されていると仮定します。
シニア番号 | OSと説明 |
---|---|
1 | Windows 環境変数ANT_HOMEをC:\ Program Files \ Apache Software Foundation \ apache-ant-1.8.4に設定します |
2 | Linux export ANT_HOME = /usr/local/apache-ant-1.8.4 |
3 | Mac export ANT_HOME = /Library/apache-ant-1.8.4 |
次のように、Antコンパイラの場所をシステムパスに追加します-
OS | 出力 |
---|---|
ウィンドウズ | 文字列を追加します %ANT_HOME\bin システム変数の最後に、 Path。 |
Linux | エクスポートパス= $PATH:$ANT_HOME / bin / |
マック | 必要ありません |
ステップ3:JUnitアーカイブをダウンロードする
オペレーティングシステムに適したJUnitアーカイブをダウンロードします。
OS | アーカイブ名 |
---|---|
ウィンドウズ | junit4.10.jar |
Linux | junit4.10.jar |
マック | junit4.10.jar |
ステップ4:プロジェクト構造を作成する
フォルダを作成する TestJunitWithAnt C:\> JUNIT_WORKSPACEで。
フォルダを作成する src C:\> JUNIT_WORKSPACE> TestJunitWithAntで。
フォルダを作成する test C:\> JUNIT_WORKSPACE> TestJunitWithAntで。
フォルダを作成する lib C:\> JUNIT_WORKSPACE> TestJunitWithAntで。
作成する MessageUtil C:\> JUNIT_WORKSPACE> TestJunitWithAnt> srcfolderのクラス。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public String printMessage(){
System.out.println(message);
return message;
}
// add "Hi!" to the message
public String salutationMessage(){
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
作成する TestMessageUtil C:\> JUNIT_WORKSPACE> TestJunitWithAnt> srcフォルダー内のクラス。
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestMessageUtil {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
assertEquals(message,messageUtil.printMessage());
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Robert";
assertEquals(message,messageUtil.salutationMessage());
}
}
junit-4.10.jarをフォルダーC:\> JUNIT_WORKSPACE> TestJunitWithAnt> libにコピーします。
ANTBuild.xmlを作成します
使用します <junit> JUnitテストケースを実行するためのAntのタスク。
<project name = "JunitTest" default = "test" basedir = ".">
<property name = "testdir" location = "test" />
<property name = "srcdir" location = "src" />
<property name = "full-compile" value = "true" />
<path id = "classpath.base"/>
<path id = "classpath.test">
<pathelement location = "lib/junit-4.10.jar" />
<pathelement location = "${testdir}" /> <pathelement location = "${srcdir}" />
<path refid = "classpath.base" />
</path>
<target name = "clean" >
<delete verbose = "${full-compile}"> <fileset dir = "${testdir}" includes = "**/*.class" />
</delete>
</target>
<target name = "compile" depends = "clean">
<javac srcdir = "${srcdir}" destdir = "${testdir}"
verbose = "${full-compile}">
<classpath refid = "classpath.test"/>
</javac>
</target>
<target name = "test" depends = "compile">
<junit>
<classpath refid = "classpath.test" />
<formatter type = "brief" usefile = "false" />
<test name = "TestMessageUtil" />
</junit>
</target>
</project>
次のAntコマンドを実行します。
C:\JUNIT_WORKSPACE\TestJunitWithAnt>ant
出力を確認します。
Buildfile: C:\JUNIT_WORKSPACE\TestJunitWithAnt\build.xml
clean:
compile:
[javac] Compiling 2 source files to C:\JUNIT_WORKSPACE\TestJunitWithAnt\test
[javac] [parsing started C:\JUNIT_WORKSPACE\TestJunitWithAnt\src\
MessageUtil.java]
[javac] [parsing completed 18ms]
[javac] [parsing started C:\JUNIT_WORKSPACE\TestJunitWithAnt\src\
TestMessageUtil.java]
[javac] [parsing completed 2ms]
[javac] [search path for source files: C:\JUNIT_WORKSPACE\
TestJunitWithAnt\src]
[javac] [loading java\lang\Object.class(java\lang:Object.class)]
[javac] [loading java\lang\String.class(java\lang:String.class)]
[javac] [loading org\junit\Test.class(org\junit:Test.class)]
[javac] [loading org\junit\Ignore.class(org\junit:Ignore.class)]
[javac] [loading org\junit\Assert.class(org\junit:Assert.class)]
[javac] [loading java\lang\annotation\Retention.class
(java\lang\annotation:Retention.class)]
[javac] [loading java\lang\annotation\RetentionPolicy.class
(java\lang\annotation:RetentionPolicy.class)]
[javac] [loading java\lang\annotation\Target.class
(java\lang\annotation:Target.class)]
[javac] [loading java\lang\annotation\ElementType.class
(java\lang\annotation:ElementType.class)]
[javac] [loading java\lang\annotation\Annotation.class
(java\lang\annotation:Annotation.class)]
[javac] [checking MessageUtil]
[javac] [loading java\lang\System.class(java\lang:System.class)]
[javac] [loading java\io\PrintStream.class(java\io:PrintStream.class)]
[javac] [loading java\io\FilterOutputStream.class
(java\io:FilterOutputStream.class)]
[javac] [loading java\io\OutputStream.class(java\io:OutputStream.class)]
[javac] [loading java\lang\StringBuilder.class
(java\lang:StringBuilder.class)]
[javac] [loading java\lang\AbstractStringBuilder.class
(java\lang:AbstractStringBuilder.class)]
[javac] [loading java\lang\CharSequence.class(java\lang:CharSequence.class)]
[javac] [loading java\io\Serializable.class(java\io:Serializable.class)]
[javac] [loading java\lang\Comparable.class(java\lang:Comparable.class)]
[javac] [loading java\lang\StringBuffer.class(java\lang:StringBuffer.class)]
[javac] [wrote C:\JUNIT_WORKSPACE\TestJunitWithAnt\test\MessageUtil.class]
[javac] [checking TestMessageUtil]
[javac] [wrote C:\JUNIT_WORKSPACE\TestJunitWithAnt\test\TestMessageUtil.class]
[javac] [total 281ms]
test:
[junit] Testsuite: TestMessageUtil
[junit] Tests run: 2, Failures: 0, Errors: 0, Time elapsed: 0.008 sec
[junit]
[junit] ------------- Standard Output ---------------
[junit] Inside testPrintMessage()
[junit] Robert
[junit] Inside testSalutationMessage()
[junit] Hi!Robert
[junit] ------------- ---------------- ---------------
BUILD SUCCESSFUL
Total time: 0 seconds
Eclipseを使用してJUnitをセットアップするには、以下の手順に従います。
ステップ1:JUnitアーカイブをダウンロードする
システムにインストールされているオペレーティングシステムに基づいて、JUnitjarをダウンロードします。
OS | アーカイブ名 |
---|---|
ウィンドウズ | junit4.10.jar |
Linux | junit4.10.jar |
マック | junit4.10.jar |
上記のJARファイルをフォルダーC:\> JUnitにコピーしたとします。
ステップ2:Eclipse環境を設定する
日食を開き、プロジェクトを右クリックし、プロパティ>ビルドパス>ビルドパスの構成をクリックし、[外部Jarの追加]ボタンを使用してライブラリにjunit-4.10.jarを追加します。
EclipseにはJUnitプラグインが組み込まれていることを前提としています。C:\> eclipse \ pluginsディレクトリで利用できない場合は、からダウンロードできます。JUnit Plugin。ダウンロードしたzipファイルをEclipseのプラグインフォルダーに解凍します。最後にEclipseを再起動します。
これで、EclipseでJUnitテストケースを開発する準備が整いました。
ステップ3:EclipseでのJUnitのインストールを確認する
プロジェクトを作成する TestJunitEclipseの任意の場所で。次に、クラスを作成しますMessageUtil プロジェクトでテストします。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public String printMessage(){
System.out.println(message);
return message;
}
}
テストクラスを作成する TestJunit プロジェクトで。
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
assertEquals(message,messageUtil.printMessage());
}
}
以下はプロジェクトの構造である必要があります-
最後に、プログラムを右クリックし、JUnitとして実行して、プログラムの出力を確認します。
結果を確認します。
以下はJUnit拡張機能です-
- Cactus
- JWebUnit
- XMLUnit
- MockObject
カクタス
Cactusは、サーバー側のJavaコード(サーブレット、EJB、タグライブラリ、フィルター)を単体テストするためのシンプルなテストフレームワークです。Cactusの目的は、サーバー側コードのテストを作成するコストを削減することです。JUnitを使用して拡張します。Cactusは、コンテナー内でテストを実行するコンテナー内戦略を実装します。
サボテンの生態系はいくつかの要素で構成されています-
Cactus Frameworkサボテンの心臓部です。これは、Cactusテストを作成するためのAPIを提供するエンジンです。
Cactus Integration Modules Cactus Framework(Antスクリプト、Eclipseプラグイン、およびMavenプラグイン)を簡単に使用する方法を提供するフロントエンドおよびフレームワークです。
次のコードは、Cactusの使用方法を示しています。
import org.apache.cactus.*;
import junit.framework.*;
public class TestSampleServlet extends ServletTestCase {
@Test
public void testServlet() {
// Initialize class to test
SampleServlet servlet = new SampleServlet();
// Set a variable in session as the doSomething()
// method that we are testing
session.setAttribute("name", "value");
// Call the method to test, passing an
// HttpServletRequest object (for example)
String result = servlet.doSomething(request);
// Perform verification that test was successful
assertEquals("something", result);
assertEquals("otherValue", session.getAttribute("otherName"));
}
}
JWebUnit
JWebUnitは、Webアプリケーション用のJavaベースのテストフレームワークです。HtmlUnitやSeleniumなどの既存のテストフレームワークを統合されたシンプルなテストインターフェイスでラップして、Webアプリケーションの正確性をテストします。
JWebUnitは、一連のアサーションと組み合わせてWebアプリケーションをナビゲートし、アプリケーションの正当性を検証するための高レベルのJavaAPIを提供します。これには、リンクを介したナビゲーション、フォームの入力と送信、テーブルコンテンツの検証、およびその他の一般的なビジネスWebアプリケーション機能が含まれます。
シンプルなナビゲーションメソッドとすぐに使用できるアサーションにより、JUnitまたはHtmlUnitのみを使用するよりも迅速なテスト作成が可能になります。また、HtmlUnitからSelenium(まもなく利用可能)などの他のプラグインに切り替えたい場合は、テストを書き直す必要はありません。
これがサンプルコードです。
import junit.framework.TestCase;
import net.sourceforge.jwebunit.WebTester;
public class ExampleWebTestCase extends TestCase {
private WebTester tester;
public ExampleWebTestCase(String name) {
super(name);
tester = new WebTester();
}
//set base url
public void setUp() throws Exception {
getTestContext().setBaseUrl("http://myserver:8080/myapp");
}
// test base info
@Test
public void testInfoPage() {
beginAt("/info.html");
}
}
XMLUnit
XMLUnitは、単一のJUnit拡張クラスXMLTestCaseと、アサーションを実行できるようにする一連のサポートクラスを提供します。
2つのXMLの違い(DiffクラスとDetailedDiffクラスを介して)。
XMLの一部の有効性(Validatorクラスを介して)。
XSLTを使用して(Transformクラスを介して)XMLの一部を変換した結果。
XMLの一部でのXPath式の評価(XpathEngineインターフェイスを実装するクラスを介して)。
(NodeTestクラスを介して)DOMトラバーサルによって公開されるXMLの一部の個々のノード。
比較したいXMLが2つあり、それらが等しいと主張するとします。このような簡単なテストクラスを書くことができます-
import org.custommonkey.xmlunit.XMLTestCase;
public class MyXMLTestCase extends XMLTestCase {
// this test method compare two pieces of the XML
@Test
public void testForXMLEquality() throws Exception {
String myControlXML = "<msg><uuid>0x00435A8C</uuid></msg>";
String myTestXML = "<msg><localId>2376</localId></msg>";
assertXMLEqual("Comparing test xml to control xml", myControlXML, myTestXML);
}
}
MockObject
単体テストでは、モックオブジェクトは複雑な実際の(非モック)オブジェクトの動作をシミュレートできるため、実際のオブジェクトを単体テストに組み込むことが実用的でないか不可能な場合に役立ちます。
モックオブジェクトでテストするための一般的なコーディングスタイルは次のとおりです。
- モックオブジェクトのインスタンスを作成します。
- モックオブジェクトに状態と期待値を設定します。
- パラメータとしてモックオブジェクトを使用してドメインコードを呼び出します。
- モックオブジェクトの整合性を確認します。
以下に、Jmockを使用したMockObjectの例を示します。
import org.jmock.Mockery;
import org.jmock.Expectations;
class PubTest extends TestCase {
Mockery context = new Mockery();
public void testSubReceivesMessage() {
// set up
final Sub sub = context.mock(Sub.class);
Pub pub = new Pub();
pub.add(sub);
final String message = "message";
// expectations
context.checking(new Expectations() {
oneOf (sub).receive(message);
});
// execute
pub.publish(message);
// verify
context.assertIsSatisfied();
}
}