TestNG 學習總結 - 參數化測試(十二)

TestNG的另一個有趣的功能是參數測試。在大多數情況下,你會遇到這樣一個場景,業務邏輯需要一個巨大的不同數量的測試。參數測試,允許開發人員運行同樣的測試,一遍又一遍使用不同的值。

TestNG讓你直接傳遞參數測試方法兩種不同的方式:

  • 使用testng.xml

  • 數據提供程序

傳遞參數使用testng.xml





有了這種技術,在testng.xml文件中定義的簡單參數,然後在源文件中引用這些參數。讓我們看看下面的例子中如何使用這種技術來傳遞參數。

創建測試案例類

  • 創建一個Java測試類 ParameterizedTest1.java.

  • 測試方法parameterTest()添加到測試類。此方法需要一個字符串作爲輸入參數。

  • 添加註釋 @Parameters("myName") 到此方法。該參數將被傳遞testng.xml,在下一步我們將看到一個值。







創建Java類文件名 ParameterizedTest1.java 在 C: > TestNG_WORKSPACE

 import org.testng.annotations.Parameters;
import org.testng.annotations.Test;

public class ParameterizedTest1 {
    @Test
    @Parameters("myName")
    public void parameterTest(String myName) {
        System.out.println("Parameterized value is : " + myName);
    }
}

創建 TESTNG.XML



創建 testng.xml C: > TestNG_WORKSPACE 執行測試案例

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite1">
    <test name="test1">
	<parameter name="myName" value="manisha"/> 
	<classes>
	    <class name="ParameterizedTest1" />
	    </classes>
    </test>
</suite>
 我們還可以定義參數在<suite>級別。假設我們已經定義在兩個<suite>和<test>級別myName,在這種情況下,常規的作用域規則適用。這意味着,任何類裏面<test>標籤將查看值參數定義在<test>,而testng.xml文件中的類的其餘部分將看到定義在<suite>中值




編譯使用javac的測試用例類。

 C:TestNG_WORKSPACE>javac ParameterizedTest1.java

現在,運行testng.xml,其中將運行parameterTest方法。TestNG的將試圖找到一個命名myName的第一<test>標籤的參數,然後,如果它不能找到它,它會搜索包圍在的<suit>標籤。

C:TestNG_WORKSPACE>java -cp "C:TestNG_WORKSPACE" org.testng.TestNG testng.xml

驗證輸出。

Parameterized value is : manisha

===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================

TestNG 對testng.xml 的參數的類型指定的值會自動嘗試轉換。下面是支持的類型:

  • String

  • int/Integer

  • boolean/Boolean

  • byte/Byte

  • char/Character

  • double/Double

  • float/Float

  • long/Long

  • short/Short

傳遞參數與數據提供者












當你需要通過複雜的參數或參數需要創建從Java(複雜的對象,對象讀取屬性文件或數據庫等..),在這種情況下,可以將參數傳遞使用數據提供者。數據提供者@DataProvider的批註的方法。這個註解只有一個字符串屬性:它的名字。如果不提供名稱,數據提供者的名稱會自動默認方法的名稱。數據提供者返回一個對象數組。

讓我們看看下面的例子使用數據提供者。第一個例子是@DataProvider的使用Vector,String或Integer 作爲參數,第二個例子是關於@DataProvider 的使用對象作爲參數。

實例 1



在這裏 @DataProvider 通過整數和布爾參數。

創建Java類



創建一個java類PrimeNumberChecker.java。這個類檢查,如果是素數。創建這個類在 C: > TestNG_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測試類 ParamTestWithDataProvider1.java.

  • 定義方法primeNumbers(),其定義爲DataProvider 使用註釋。此方法返回的對象數組的數組。

  • 測試方法testPrimeNumberChecker()添加到測試類中。此方法需要一個整數和布爾值作爲輸入參數。這個方法驗證,如果傳遞的參數是一個素數。

  • 添加註釋 @Test(dataProvider = "test1") 到此方法。dataProvider的屬性被映射到"test1".








創建Java類文件名ParamTestWithDataProvider1.java 在 C: > TestNG_WORKSPACE

import org.testng.Assert;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;

public class ParamTestWithDataProvider1 {
    private PrimeNumberChecker primeNumberChecker;

    @BeforeMethod
    public void initialize() {
        primeNumberChecker = new PrimeNumberChecker();
    }

    @DataProvider(name = "test1")
    public static Object[][] primeNumbers() {
        return 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(dataProvider = "test1")
    public void testPrimeNumberChecker(Integer inputNumber,
        Boolean expectedResult) {
	System.out.println(inputNumber + " " + expectedResult);
	Assert.assertEquals(expectedResult,
        	primeNumberChecker.validate(inputNumber));
    }
}

創建 TESTNG.XML



創建 testng.xml C: > TestNG_WORKSPACE 執行測試案例。

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite1">
    <test name="test1">
	<classes>
	    <class name="ParamTestWithDataProvider1" />
	    </classes>
    </test>
</suite>

編譯使用javac的測試用例類。

C:TestNG_WORKSPACE>.javac ParamTestWithDataProvider1.java PrimeNumberChecker.java

運行testng.xml.

C:TestNG_WORKSPACE>java -cp "C:TestNG_WORKSPACE" org.testng.TestNG testng.xml

驗證輸出。

2 true
6 false
19 true
22 false
23 true

===============================================
Suite1
Total tests run: 5, Failures: 0, Skips: 0
===============================================

實例 2



在這裏,@DataProvider 傳遞對象作爲參數。

創建Java類



創建一個Java類 Bean.java, 對象帶有 get/set 方法, 在 C: > TestNG_WORKSPACE.

public class Bean {
    private String val;
    private int i;
    public Bean(String val, int i){
        this.val=val;
        this.i=i;
    }
    public String getVal() {
	return val;
    }
    public void setVal(String val) {
	this.val = val;
    }
    public int getI() {
	return i;
    }
    public void setI(int i) {
	this.i = i;
    }
}

創建測試案例類

  • 創建一個Java測試類 ParamTestWithDataProvider2.java.

  • 定義方法primeNumbers(),其定義爲DataProvider使用註釋。此方法返回的對象數組的數組。

  • 添加測試類中測試方法TestMethod()。此方法需要對象的bean作爲參數。

  • 添加註釋 @Test(dataProvider = "test1") 到此方法.  dataProvider 屬性被映射到 "test1".







創建Java類文件名 ParamTestWithDataProvider2.java 在 C: > TestNG_WORKSPACE

import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;

public class ParamTestWithDataProvider2 {
    @DataProvider(name = "test1")
    public static Object[][] primeNumbers() {
        return new Object[][] { { new Bean("hi I am the bean", 111) } };
    }

    @Test(dataProvider = "test1")
    public void testMethod(Bean myBean) {
        System.out.println(myBean.getVal() + " " + myBean.getI());
    }
}

創建 TESTNG.XML



創建一個文件 testng.xml C: > TestNG_WORKSPACE 來執行測試用例.

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite1">
    <test name="test1">
	<classes>
	    <class name="ParamTestWithDataProvider2" />
	    </classes>
    </test>
</suite>

編譯使用javac的測試用例類。

C:TestNG_WORKSPACE>javac ParamTestWithDataProvider2.java Bean.java

運行 testng.xml.

C:TestNG_WORKSPACE>java -cp "C:TestNG_WORKSPACE" org.testng.TestNG testng.xml

驗證輸出。

hi I am the bean 111

===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章