TestNG并行执行行为与预期的

时间:2016-04-18 09:01:13

标签: java testng

我目前正面临一个我无法识别的问题。

我试图使用testNG并行运行测试。我没有问题并行运行不同的测试,但是当我尝试在不同的线程中多次运行单个测试时,我有一个奇怪的行为。

所以,我尝试调试以找出问题所在。当我尝试从TestNG XML配置文件中获取值时发生错误:

public class LocalWebDriverListener implements IInvokedMethodListener {

    static Logger log = Logger.getLogger(LocalWebDriverListener.class);

    public void beforeInvocation(IInvokedMethod method, ITestResult testResult) {
        log.debug("BEGINNING: LocalWebDriverListener.beforeInvocation");
        if (method.isTestMethod()) {
            //Error on this line
            String browserName = method.getTestMethod().getXmlTest().getLocalParameters().get("browserName");
            //getXmlTest() returns null
            WebDriver driver = LocalDriverFactory.createInstance(browserName);
            DriverManager.setWebDriver(driver);
        } else {
            log.warn("Not a TestNG test");
        }
        log.debug("END: LocalWebDriverListener.beforeInvocation");
    }
}

我不明白为什么getXmlTest()仅在threadPoolSize>时返回null。 @Test参数中的1。

public class TestClass {

    static Logger log = Logger.getLogger(TestClass.class);

    @Test(invocationCount = 5, threadPoolSize = 5)
    public void testMethod1() {
        invokeBrowser("http://www.google.com/");
    }
}

XML:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="Test executed using WebDriver" parallel="tests" thread-count="5">
    <listeners>
        <listener class-name="my.organization.WebDriverListener" />
    </listeners>
    <test name="Tests run in Chrome">
        <parameter name="browserName" value="chrome" />
        <packages>
            <package name="my.organization.tests" />
        </packages>
    </test>
</suite>

你可以帮我解决这个问题吗?

由于

1 个答案:

答案 0 :(得分:1)

问题是IInvokedMethod不知道testng.xml 更换 String browserName = method.getTestMethod().getXmlTest().getLocalParameters().get("browserName");String browserName = testResult.getTestContext().getCurrentXmlTest().getLocalParameters().get("browserName");