0

我正在尝试使用 selenium 网格和 TestNG 运行 chrome 和 Firefox 的并行测试。

我正在使用 @DataProvider 使其数据由单个 excel 文件驱动

但是,每次我尝试运行我的套件时,其中一个浏览器都会关闭并抛出以下错误堆栈,而其中一个浏览器仍然可以正常运行测试脚本:

java.lang.IllegalStateException: Cannot get a STRING value from a NUMERIC cell
at org.apache.poi.xssf.usermodel.XSSFCell.typeMismatch(XSSFCell.java:1062)
at org.apache.poi.xssf.usermodel.XSSFCell.getRichStringCellValue(XSSFCell.java:395)
at org.apache.poi.xssf.usermodel.XSSFCell.getStringCellValue(XSSFCell.java:347)
at com.opta.ccf.helper.ExcelUtil.getCellData(ExcelUtil.java:90)
at com.opta.ccf.helper.ExcelUtil.getTableArray(ExcelUtil.java:56)
at com.opta.iclarify.test.TDAttTest.osbData(TDAttTest.java:141)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:86)
at org.testng.internal.MethodInvocationHelper.invokeDataProvider(MethodInvocationHelper.java:137)
at org.testng.internal.Parameters.handleParameters(Parameters.java:430)
at org.testng.internal.Invoker.handleParameters(Invoker.java:1274)
at org.testng.internal.Invoker.createParameters(Invoker.java:989)
at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1079)
at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:129)
at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:112)
at org.testng.TestRunner.privateRun(TestRunner.java:782)
at org.testng.TestRunner.run(TestRunner.java:632)
at org.testng.SuiteRunner.runTest(SuiteRunner.java:366)
at org.testng.SuiteRunner.access$000(SuiteRunner.java:39)
at org.testng.SuiteRunner$SuiteWorker.run(SuiteRunner.java:400)
at org.testng.internal.thread.ThreadUtil$2.call(ThreadUtil.java:64)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:748)

我在 testng.xml 中有以下项目

<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="suite1" verbose="1"  parallel="tests">
    <test name="firefoxTest">
    <parameter name="browser" value="firefox" />
    <classes>
        <class name="TestAll" />
    </classes>
    </test>
    <test name="chrometest">
        <parameter name="browser" value="chrome" />
        <classes>
            <class name="TestAll" />
        </classes>
    </test>
</suite>

对于之前的测试,我有以下内容,该测试位于名为 Framework 的类中,由名为 TestAll 的子类继承:

@Parameters({"browser"})
@BeforeTest(alwaysRun = true)
public  void setup(String browser) throws MalformedURLException {
    //Set the desired capabilities
    DesiredCapabilities caps = new DesiredCapabilities();
    //Setting Desired Capabilities
    if(browser.equalsIgnoreCase("Internet Explorer")){
        caps = DesiredCapabilities.internetExplorer();
        caps.setBrowserName("IE");
    }
    if(browser.equalsIgnoreCase("firefox")){
        caps = DesiredCapabilities.firefox();
        caps.setCapability("marionette", true);
        caps.setBrowserName("firefox");
    }
    if(browser.equalsIgnoreCase("chrome")){

        caps = DesiredCapabilities.chrome();
        caps.setBrowserName("chrome");

    }
    //Setting Browser

    try {
        driver = new RemoteWebDriver(new 
        URL(parentPropFile.getProperty("ServerHubUrl")), caps);
    } catch (MalformedURLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
        driver = null;
    }
}

我的数据提供者方法如下,它在继承框架类的子类 TestAll 中:

@DataProvider(name = "tdData")
public static Object[][] osbData(){
    Object[][] testObjArray = null;
    try {
        testObjArray = ExcelUtil.getTableArray("data-2.xlsx");
    } catch (Exception e) {
        e.printStackTrace();
    }
    return testObjArray;
}

我的测试方法包括以下子类 TestAll 继承框架类:

@Test(dataProvider = "tdData", threadPoolSize = 2)
public  void testTD(String streetName, String SteetNo,.......){
        try {
            //TEST SCRIPT
        }catch (Exception e) {
            e.printStackTrace();
        }

}

4

2 回答 2

0

不确定问题是什么,但基于使用数据提供程序执行并行 TestNG selenium 测试的驱动程序行为

为了解决这个问题,我做了以下事情:

我创建了一个带有数据工厂和数据提供者的单独类,它使用通过数据提供者提供的参数调用具有测试方法的类的构造函数。

该解决方案类似于以下链接中证明的解决方案。

于 2017-08-04T17:43:26.390 回答
0

@DataProvider(name = "dataPro")@Test(dataProvider = "tdData", threadPoolSize = 2)

传递给测试的数据提供者是不同的,因此会导致问题。通常,如果我们使用getStringCellValue数字单元格,则会抛出该异常。

于 2017-08-04T15:40:44.093 回答