实际上,我正在创建一个框架,但在创建它时,我只想要它用于串行执行,但现在我想要对方法进行并行测试。问题是,我已经将驱动程序实例声明为静态的,并且由于静态的,第二个线程无法更改它的值。
我在一个单独的类中创建驱动程序,并使用getter方法获取它。
现在的问题是,如果我让Webdrive变成非静态的,那么我就无法在其他类中使用驱动程序。
即使我尝试扩展类(在这里创建驱动程序实例),它也会传递一个空值。
所以,基本上,我想隔离所有的实例,但我不能使实例本地到类。我尝试删除静态变量,但在并行执行时,打开了两个浏览器实例,但在一个浏览器中执行所有的测试用例,这太并行了
我怎样才能做到这一点呢?
您必须为应用程序创建类似驱动程序池的东西。您可以从这个池中为您的测试用例启动一组驱动程序。
另外,考虑一下如何取消驱动程序实例的静态化。
我过去也尝试过类似的方法:
public class DriverPool {
public static final int MAX_NUMBER = 5;
private static final Object waitObj = new Object();
private static AtomicInteger counter = new AtomicInteger(0);
private static Logger log = Logger.getLogger(DriverPool.class);
private static volatile ThreadLocal<WebDriver> instance = ThreadLocal
.withInitial(DriverManager::getInstance);
public static synchronized WebDriver getDriver() {
try {
while (counter.get() > MAX_NUMBER) {
synchronized (waitObj) {
waitObj.wait();
}
}
counter.getAndIncrement();
} catch (InterruptedException e) {
log.error(e);
}
return instance.get();
}
public static synchronized void closeDriver() {
WebDriver driver = instance.get();
driver.close();
driver.quit();
instance.remove();
counter.decrementAndGet();
synchronized (waitObj) {
waitObj.notifyAll();
}
}
}
我希望这会有帮助。
问题内容: 首先,对不起我的英语,它不是那么完美:) 因此,我面临以下问题:我正在尝试使用Selenium Grid和TestNg在不同的浏览器中运行并行测试,并在@BeforeTest方法中传递参数。我的问题是,在初始化每个测试时,似乎它们将使用最后一个测试的参数。因此,在此示例中,当我运行测试时,它将打开两个Chrome,而不是一个Firefox和一个Chrome。 (browser.getD
注: 在testng xml中,如果我将parallel=更改为类或方法,那么它可以很好地运行测试,但它不是并行地一个接一个地运行测试。 如果我保持parallel=“tests”,那么它会并行运行,但它会在同一个VM中打开同一个浏览器三次,这是不正确的。 我的设置: 我设置了11个虚拟机,每个盒子上的每个浏览器都初始化了Selenium网格节点。我已经创建了testng xml,以便在每个框上运
我发现Junit5从5.3版本开始就支持并行性,但我找不到任何关于如何使用csv源代码运行并行测试的参考。你有什么建议吗?
我正在尝试使用2个xml文件与Maven并行运行我的测试,但似乎不起作用。我已经尝试了Maven留档中的步骤/参数:http://maven.apache.org/surefire/maven-surefire-plugin/examples/testng.html 以下是我的pom.xml文件: 这是功能1.xml文件: 我应该做哪些参数/更改才能使其生效? 谢谢你
使用Browserstack教程(https://www.browserstack.com/app-automate/appium-junit)和样本项目(https://github.com/browserstack/junit-appium-app-browserstack)我正在努力设置并行测试。 具体来说,我需要运行suirte与Cucumber.class()我的测试从场景中读取,而Br
我对Spring的靴子是陌生的,在它们到来的时候学习。我有一个关于并行API调用的快速问题。 我有一个ID数组,我将把它附加到第三方APIendpoint,发出GET请求,聚合数据,并在所有3000个调用完成后从中生成一个文件。 这里的问题是Array的大小为3000,即我预计会进行3000次调用。我觉得使用for循环并迭代超过3000次没有任何意义,而且效率较低。 有谁能给我建议一个最好、最有效