セレン-TestNG

TestNGは、強力なテストフレームワークであり、TestNGが登場する前に長い間使用されていたJUnitの拡張バージョンです。NGは「次世代」の略です。

TestNGフレームワークは以下の機能を提供します-

  • 注釈は、テストを簡単に整理するのに役立ちます。
  • 柔軟なテスト構成。
  • テストケースはより簡単にグループ化できます。
  • テストの並列化は、TestNGを使用して実現できます。
  • データ駆動型テストのサポート。
  • 組み込みのレポート。

TestNG forEclipseのインストール

Step 1 − Eclipseを起動し、「新しいソフトウェアのインストール」を選択します。

Step 2 − URLを「http://beust.com/eclipse」と入力し、「追加」をクリックします。

Step 3−ダイアログボックス「リポジトリの追加」が開きます。名前を「TestNG」と入力し、「OK」をクリックします

Step 4 −「すべて選択」をクリックすると、図に示すように「TestNG」が選択されます。

Step 5 − [次へ]をクリックして続行します。

Step 6 −選択した項目を確認し、「次へ」をクリックします。

Step 7 −「使用許諾契約に同意します」をクリックし、「完了」をクリックします。

Step 8 − TestNGがインストールを開始し、進行状況が次のように表示されます。

Step 9−ソフトウェアの有効性を確立できないため、セキュリティ警告がポップアップ表示されます。[OK]をクリックします。

Step 10−インストーラーは、変更を有効にするためにEclipseを再起動するように求めます。[はい]をクリックします。

TestNGのアノテーション

JDK 5ではJava言語に注釈が正式に追加され、TestNGは注釈を使用してテストクラスに注釈を付けることを選択しました。以下は、注釈を使用する利点の一部です。TestNGの詳細については、here

  • TestNGは、アノテーションを検索することにより、関心のあるメソッドを識別します。したがって、メソッド名はパターンや形式に制限されません。

  • 追加のパラメータを注釈に渡すことができます。

  • 注釈は強く型付けされているため、コンパイラーは間違いがあればすぐにフラグを立てます。

  • テストクラスは何も拡張する必要がなくなりました(JUnit 3のTestCaseなど)。

シニア番号 注釈と説明
1

@BeforeSuite

注釈付きメソッドは、このスイートのすべてのテストが実行される前に1回だけ実行されます。

2

@AfterSuite

注釈付きメソッドは、このスイートのすべてのテストが実行された後に1回だけ実行されます。

3

@BeforeClass

注釈付きメソッドは、現在のクラスの最初のテストメソッドが呼び出される前に1回だけ実行されます。

4

@AfterClass

注釈付きメソッドは、現在のクラスのすべてのテストメソッドが実行された後に1回だけ実行されます。

5

@BeforeTest

注釈付きメソッドは、<test>タグ内のクラスに属するテストメソッドが実行される前に実行されます。

6

@AfterTest

注釈付きメソッドは、<test>タグ内のクラスに属するすべてのテストメソッドが実行された後に実行されます。

7

@BeforeGroups

この構成方法が以前に実行するグ​​ループのリスト。このメソッドは、これらのグループのいずれかに属する最初のテストメソッドが呼び出される直前に実行されることが保証されています。

8

@AfterGroups

この構成メソッドが実行されるグループのリスト。このメソッドは、これらのグループのいずれかに属する最後のテストメソッドが呼び出された直後に実行されることが保証されています。

9

@BeforeMethod

注釈付きメソッドは、各テストメソッドの前に実行されます。

10

@AfterMethod

注釈付きメソッドは、各テストメソッドの後に実行されます。

11

@DataProvider

テストメソッドのデータを提供するものとしてメソッドをマークします。注釈付きメソッドは、各Object []にテストメソッドのパラメータリストを割り当てることができるObject [] []を返す必要があります。このDataProviderからデータを受信する@Testメソッドは、このアノテーションの名前と同じdataProvider名を使用する必要があります。

12

@Factory

TestNGによってテストクラスとして使用されるオブジェクトを返すファクトリとしてメソッドをマークします。メソッドはObject []を返す必要があります。

13

@Listeners

テストクラスのリスナーを定義します。

14

@Parameters

@Testメソッドにパラメーターを渡す方法について説明します。

15

@Test

テストの一部としてクラスまたはメソッドをマークします。

TestNG-Eclipseセットアップ

Step 1 − Eclipseを起動し、以下に示すように「新しいJavaプロジェクト」を作成します。

Step 2 −プロジェクト名を入力し、「次へ」をクリックします。

Step 3 −以下に示すように、[ライブラリ]タブに移動し、[外部JARの追加]をクリックしてSelenium Remote Control ServerJARファイルを追加します。

Step 4−追加されたJARファイルはここに表示されます。[ライブラリの追加]をクリックします。

Step 5− [ライブラリの追加]ダイアログが開きます。[TestNG]を選択し、[ライブラリの追加]ダイアログボックスで[次へ]をクリックします。

Step 6 −追加された「TestNG」ライブラリが追加され、以下のように表示されます。

Step 7 −プロジェクトを作成すると、プロジェクトの構造は次のようになります。

Step 8 −「src」フォルダを右クリックして「新規」>>「その他」を選択します。

Step 9 −「TestNG」を選択し、「次へ」をクリックします。

Step 10 −「ソースフォルダ」名を選択し、「OK」をクリックします。

Step 11 −「パッケージ名」、「クラス名」を選択し、「完了」をクリックします。

Step 12 −パッケージエクスプローラーと作成されたクラスが表示されます。

TestNGでの最初のテスト

それでは、TestNGを使用してスクリプトを開始しましょう。WebDriverを理解するために使用したのと同じ例のスクリプトを作成しましょう。デモアプリケーションwww.calculator.netを使用して、パーセント計算を実行します。

次のテストでは、testNGがプログラムの実行フローを駆動するため、mainメソッドがないことに気付くでしょう。ドライバを初期化した後、「@ BeforeTest」メソッド、「@ Test」、「@ AfterTest」の順に実行されます。クラスには「@Test」アノテーションをいくつでも含めることができますが、「@ BeforeTest」と「@AfterTest」は1回しか表示できないことに注意してください。

package TestNG;

import java.util.concurrent.TimeUnit;

import org.openqa.selenium.*;
import org.openqa.selenium.firefox.FirefoxDriver;

import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;

public class TestNGClass {
   WebDriver driver = new FirefoxDriver();
   
   @BeforeTest
   public void launchapp() {
      // Puts an Implicit wait, Will wait for 10 seconds before throwing exception
      driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
      
      // Launch website
      driver.navigate().to("http://www.calculator.net");
      driver.manage().window().maximize();
   }
   
   @Test
   public void calculatepercent() {
      // Click on Math Calculators
      driver.findElement(By.xpath(".//*[@id='menu']/div[3]/a")).click();
      
      // Click on Percent Calculators
      driver.findElement(By.xpath(".//*[@id='menu']/div[4]/div[3]/a")).click();
      
      // Enter value 10 in the first number of the percent Calculator
      driver.findElement(By.id("cpar1")).sendKeys("10");
      
      // Enter value 50 in the second number of the percent Calculator
      driver.findElement(By.id("cpar2")).sendKeys("50");
      
      // Click Calculate Button
      driver.findElement(By.xpath(".//*[@id='content']/table/tbody/tr/td[2]/input")).click();
      
      // Get the Result Text based on its xpath
      String result =
         driver.findElement(By.xpath(".//*[@id='content']/p[2]/span/font/b")).getText();
      
      // Print a Log In message to the screen
      System.out.println(" The Result is " + result);
      
      if(result.equals("5")) {
         System.out.println(" The Result is Pass");
      } else {
         System.out.println(" The Result is Fail");
      }
   }
   
   @AfterTest
   public void terminatetest() {
      driver.close();
   }
}

実行

実行するには、作成したXMLを右クリックし、[実行] >> [TestNGスイート]を選択します。

結果分析

出力はコンソールにスローされ、次のように表示されます。コンソール出力には、実行の概要も含まれています。

TestNGの結果は、別のタブでも確認できます。以下に示すように、[HTMLレポートビュー]ボタンをクリックします。

HTMLの結果は次のように表示されます。