Android 単体テスト フレームワーク JUnit 4

Java で広く使用されている単体テスト フレームワークの 1 つである JUnit 4 テスト フレームワークを使用すると、開発者は反復可能、保守可能、検証可能なテストを作成できます。

単体テストの意味

単体テストは、コード内の個々のユニットまたはコンポーネントをテストすることであり、次のものが含まれます。

  1. 機能テスト: コードのユニットが期待どおりに機能を実行するかどうかをテストします。

  2. 境界テスト: コードのユニットがさまざまな境界条件に正しく応答するかどうかをテストします。

  3. 例外テスト: コード単位が予期しない状況に遭遇したときに適切な例外をスローするかどうかをテストします。

  4. パフォーマンス テスト: コード ユニットのパフォーマンス、応答時間、メモリ使用量などのパフォーマンス指標が期待を満たしているかどうかをテストします。

  5. 互換性テスト: コードユニットが異なる環境 (異なるオペレーティング システム、異なるモデルなど) で一貫して動作するかどうかをテストします。

  6. セキュリティ テスト: 潜在的なセキュリティ脆弱性についてコード ユニットをテストします。

  7. 保守性テスト: コードの可読性、拡張性など、コード単位が保守しやすいかどうかをテストします。

単体テストの目的は、コード単位のさまざまな状況をできるだけ包括的にカバーし、それによってコードの品質と安定性を向上させることです。

JUnit 4 テスト フレームワークの詳細な使用法

  1. JUnit 4 ライブラリをダウンロードして構成する

次の依存関係を Gradle に追加します。

testImplementation 'junit:junit:4.13.2'
  1. 基本的なテストを作成する

テスト クラスは次の要件を満たす必要があります。

  • Test で終わるクラス名 (または @RunWith(JUnit4.class) アノテーションを付けて JUnit 4 テスト クラスとして宣言)
  • 各テストメソッドには@Test注釈
  • 各テスト メソッドの前に @Before、@After、@BeforeClass、@AfterClass アノテーションを追加すると、テスト メソッドの前または後に実行される一部の操作をそれぞれ定義できます。

Java プロジェクトで、テスト パッケージを作成し、テスト クラスを追加します。このクラスでは、Java クラス メソッドのさまざまな側面をテストするテスト メソッドを作成できます。たとえば、簡単な例を次に示します。

import org.junit.Test;
import static org.junit.Assert.assertEquals;
 
public class MyTest {
    
    
   
   @Test
   public void testAdd() {
    
    
      int sum = 1 + 2;
      assertEquals(3, sum);
   }
}

上の例では、アサーション用の JUnit ライブラリによって提供されるassertEquals()メソッドを。

  1. テストを実行する

JUnit のさまざまなツールを使用してテストを実行できます。これらの中で最も単純なものは JUnitRunnerクラス。テスト クラスに@RunWithアノテーションを、その値を設定してJUnit4.class、そのテスト クラスでどのメソッドをテストするかを JUnit ランナーに指示できます。例えば:

import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
 
@RunWith(JUnit4.class)
public class MyTest {
    
    
   @Test
   public void testAdd() {
    
    
      int sum = 1 + 2;
      assertEquals(3, sum);
   }
}
  1. 複数のテストを実行する

複数のテストメソッドを定義した場合、テストスイート(Test Suite)を使用してそれらを組み合わせて実行できます。@SuiteClassesこれらのテスト クラスの名前を JUnit に伝えるには、テスト スイート クラスを作成し、それにテスト クラスを追加し、JUnit アノテーションを使用します。例えば:

import org.junit.runner.RunWith;
import org.junit.runners.Suite;
 
@RunWith(Suite.class)
@Suite.SuiteClasses({
    
     MyTest.class, AnotherTest.class })
public class AllTests {
    
    
}

ここで示されているのは、テスト クラスのテスト メソッドをスイート内で編成して実行するMyTestことです。AnotherTest

  1. 他の注釈を使用する

JUnit 4 は、テストの動作を制御するためのさまざまなアノテーションを提供します。これらの注釈には@Before、、、、、およびが含ま@Afterれます。たとえば、次の例では、アノテーションをテスト クラスの実行時に 1 回だけ実行されるメソッド内でデータベース接続とその他の初期化操作を開きます。@BeforeClass@AfterClass@Ignore@Test(expected=…)@BeforeClasssetUp()

import org.junit.BeforeClass;
import org.junit.Test;
 
public class MyTest {
    
    
   private static DatabaseConnection connection;
 
   @BeforeClass
   public static void setUp() {
    
    
      // Open database connection and other initialization
   }
   
   @Test
   public void testAdd() {
    
    
      // Test addition
   }
   
   @Test
   public void testSubtract() {
    
    
      // Test subtraction
   }
}

結論として、JUnit 4 は、テスト ケースの作成と実行をより簡単かつ便利にする強力な Java テスト フレームワークです。上記の使用方法の詳細を通じて、JUnit 4 テスト フレームワークについての理解をさらに深めていただければ幸いです。

JUnit 4のアノテーションとメソッド

JUnit 4 は多くの便利なメソッドとアノテーションを提供しており、それらはすべて開発者がより信頼性が高く堅牢なテスト ケースを作成するのに役立ちます。

  • @Test- テストメソッドを示します。このアノテーションを使用するメソッドはテストケースとみなされます。
  • @Before- 各テスト メソッドの前に実行する必要があるメソッドを示します。
  • @After- 各テスト メソッドの後に実行する必要があるメソッドを示します。
  • @BeforeClass- すべてのテスト メソッドの前に 1 回だけ実行されるメソッドを示します。
  • @AfterClass- すべてのテスト メソッドの後に 1 回だけ実行されるメソッドを示します。
  • @Ignore- テスト スイートでこのテスト メソッドをスキップすることを示します
  • @Test(expected = exception.class)- テスト メソッドが例外をスローする必要があることを示します。これは、異常な状況が捕捉されて処理されるかどうかをテストするのに役立ちます。

JUnit 4 は、Assertテスト中に予想される動作を検証するためのクラスを提供します。Assertクラスには次のような複数のメソッドがあります。

  • assertEquals()- 2つの値が等しいかどうかをチェックします
  • assertTrue()/ assertFalse()- 条件が真か偽かをチェックします
  • assertNotNull()/ assertNull()- オブジェクトが null かどうかをチェックする
  • assertSame()/assertNotSame()- 2 つのオブジェクト参照が等しいかどうかを検証するために使用されます。
  • assertThat()- メソッドは、式が「より大きい」、「より小さい」などの特定の条件を満たすかどうかを検証するために使用されます。

おすすめ

転載: blog.csdn.net/weixin_44008788/article/details/130995025