26

一連のデータ値に対してそれぞれいくつかのテストを実行し、同じ条件がそれぞれに当てはまることを確認したいと思います。データは現在、フラット ファイルまたは単純な Excel スプレッドシートに保存されています。

私が最初に考えたのは、ファイルからデータをロードし、データ値ごとに 1 回テスト メソッドを呼び出すために使用される TestNG DataProvider を作成することでした。私の問題は、さまざまなテストがさまざまなファイルからデータをロードする必要があり、パラメーターを DataProvider に送信する方法がないように見えることです。 これが可能かどうか誰にもわかりますか?

理想的には、コードを次のようにしたいと思います (簡略化された例)。

public class OddTest {
    @DataProvider(name = "excelLoader")
    public Iterator<Object[]> loadExcelData(String fileName) {
        ...
    }

    @Test(dataProvider = "excelLoader" dataProviderParameters = { "data.xls" })
    public void checkIsOddWorks(int num)
        assertTrue(isOdd(num));
    }
}
4

5 に答える 5

18

TestNGの依存性注入機能を使用して、DataProviderで定義されているすべてのパラメーターにアクセスできます。これは、「test_param」パラメーターを必要とするDataProviderの例です。

@DataProvider(name = "usesParameter")
public Object[][] provideTestParam(ITestContext context) {
    String testParam = context.getCurrentXmlTest().getParameter("test_param");
    return new Object[][] {{ testParam }};
}

これには、「test_param」を定義する必要がありますsuite.xml

<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="suite">
    <parameter name="test_param" value="foo" />
    <test name="tests">
        <classes>
            ...
        </classes>
    </test>
</suite>

ITestContextクラスの詳細については、TestNGJavaDocを参照してください

于 2011-01-17T15:56:38.850 に答える
7

これを行うより一般的な方法は、groups注釈を使用して値のカスタム リストを作成することです。

@DataProvider(name = "excelLoader")
public Object[][] createData(Method m) {
    ArrayList<Object[]> excelFiles = new ArrayList<Object[]>;
    // iterate over all the groups listed in the annotation
    for (String excelFile : ((Test) m.getAnnotation(Test.class)).groups()) {
        // add each to the list
        excelFiles.add(new Object[] { excelFile });
    }
    // convert the list to an array
    return excelFiles.toArray(new Object[excelFiles.size()]);
}

@Test(dataProvider = "excelLoader", groups = { "data1", "data2" })
public void test1(String excelFile) {
    // we will test "data1.xls" and "data2.xls" in this test
    String testExcelFile = excelFile + ".xls";
}

@Test(dataProvider = "excelLoader", groups = { "data2", "data3" })
public void test2(String excelFile) {
    // we will test "data2.xls" and "data3.xls" in this test
    String testExcelFile = excelFile + ".xls";
}

または、カスタム要素を取り込む独自の注釈クラスを作成して、次のようなことを行うこともできます。

@Retention(java.lang.annotation.RetentionPolicy.RUNTIME)
@Target({METHOD, TYPE, CONSTRUCTOR})
public @interface FilesToTest {
    public String[] value() default {};
}

@DataProvider(name = "excelLoader")
public Object[][] createData(Method m) {
    ArrayList<Object[]> excelFiles = new ArrayList<Object[]>;
    // iterate over all the groups listed in the annotation
    for (String excelFile : ((FilesToTest) m.getAnnotation(FilesToTest.class)).value()) {
        // add each to the list
        excelFiles.add(new Object[] { excelFile });
    }
    // convert the list to an array
    return excelFiles.toArray(new Object[excelFiles.size()]);
}

@Test(dataProvider = "excelLoader")
@FilesToTest({ "data1.xls", "data2.xls" })
public void myTest(String excelFile) {
    // we will test "data1.xls" and "data2.xls" in this test
}
于 2016-01-30T00:31:53.443 に答える
1

yshua からの回答は、データ プロバイダー内でファイルパスをハードコーディングする必要があるため、少し制限があります。これは、ソース コードを変更してから再コンパイルして、テストを再実行する必要があることを意味します。これは、XML ファイルを使用してテストの実行を構成する目的に反します。

より良い、間違いなくよりハックな解決策は、スイートの前に実行されるダミーの @test メソッドを作成し、ファイルパスをパラメーターとして受け取り、これらのテスト メソッドを格納するクラス内にこの情報を保存することです。

このソリューションは完璧ではありませんが、TestNG がより適切なパラメーターの受け渡しを許可するまで (おそらくこれは変更されています)、これはニーズに対応できる可能性があります。

于 2010-03-02T17:11:21.200 に答える
0

上記の私の回答に追加するために、EasyTest フレームワークを使用してそれを行う方法の完全なコードを次に示します。

@RunWith(DataDrivenTestRunner.class)
public class MyTestClass {

@Test
@DataLoader(filePaths={myTestFile.xls}, loaderType=LoaderType.EXCEL)
public void testFirstMethod(@Param()
Map<String, Object> inputData) {
    System.out.print("Executing testFirstMethod:");
    System.out.println("library Id : " + inputData.get("LibraryId"));

}

@Test
@DataLoader(filePaths={mySecondTestFile.xls}, loaderType=LoaderType.EXCEL)
public void testSecondMethod(@Param(name="input")
MyClassObject inputData) {
    System.out.print("Executing testSecondMethod:");
    System.out.println("library Id : " + inputData.get("LibraryId"));

}

等々。@DataLoader アノテーションが EasyTest でどのように機能するかについて詳しく知りたい場合は、次を参照してください: https://github.com/EaseTech/easytest/wiki/EasyTest-:-Loading-Data-using-Excel

次の例に示すように、XML、Excel、CSV、または独自のカスタム ローダーを使用してデータをロードし、すべてを同じテスト クラスで一度に使用できることに注意してください: https://github.com/EaseTech/easytest/blob /master/src/test/java/org/easetech/easytest/example/TestCombinedLoadingAndWriting.java

お役に立てば幸いです。

于 2012-11-08T17:43:53.577 に答える