我正在使用TestNG运行自动Selenium测试。当我作为TestNG套件运行时,一切都很好。但是当我作为Maven Test运行时,它们失败了。我非常困惑为什么他们会在一种情况下工作而不是另一种情况下。以下是测试的总体布局:
base.java
public class Base {
public WebDriver driver = null;
public WebDriver getLocalDriver() {
driver = new FirefoxDriver();
return driver;
}
testbase.java
public class TestBase extends Base {
@BeforeTest
public void beforeTest() {
Base b = new Base();
driver = b.getLocalDriver();
}
@AfterTest
public void afterTest() {
driver.quit();
}
public class LoginTests extends TestBase {
@Test
public void TestOne() {
driver.get("http://www.company.com");
// ^^^ driver == null right here (line 28)
}
java.lang.NullPointerException
at com.company.automation.ecom.tests.LoginTests.TestOne(LoginTests.java:28)
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.19.1</version>
<configuration>
<suiteXmlFiles>
<suiteXmlFile>testng.xml</suiteXmlFile>
</suiteXmlFiles>
</configuration>
</plugin>
</plugins>
</build>
<groupId>com.company.automation</groupId>
<artifactId>ecom</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>ecom</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.8</version>
<!--<scope>test</scope> -->
</dependency>
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-java</artifactId>
<version>3.0.1</version>
</dependency>
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-java</artifactId>
<version>3.0.1</version>
</dependency>
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-chrome-driver</artifactId>
<version>3.0.1</version>
</dependency>
<dependency>
<groupId>io.github.bonigarcia</groupId>
<artifactId>webdrivermanager</artifactId>
<version>1.5.0</version>
</dependency>
</dependencies>
</project>
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="ECOM Suite" parallel="tests" thread-count="2">
<test verbose="2" name="Chrome">
<parameter name="browserName" value="chrome"/>
<parameter name="nodeURL" value="http://10.11.25.170:5552/wd/hub"/>
<packages>
<package name="com.company.*"></package>
</packages>
</test>
<test verbose="2" name="Firefox">
<parameter name="browserName" value="firefox"/>
<parameter name="nodeURL" value="http://10.11.25.170:5551/wd/hub"/>
<packages>
<package name="com.company.*"></package>
</packages>
</test>
</suite>
我非常困惑为什么他们会在一种情况下工作而不是另一种情况下。
当我第一次发现TestNG很好地利用了多线程时,我也是如此。
尝试将@beforetest
和@aftertest
注释更改为@beforeMethod
和@afterMethod
。这将是最简单的解决办法。
除了将WebDriver
持久化为静态ThreadLocal
之外,可能是成功的关键。
考虑一下:
public class TestBase {
protected static ThreadLocal<WebDriver> webDriver = new ThreadLocal<WebDriver>();
protected String abc;
@BeforeMethod
public void setUp(){
System.out.println("I am in setUp method.");
//WebDriver instantiation etc.
System.setProperty("webdriver.chrome.driver", "/path/to/chromedriver");
ChromeOptions options = new ChromeOptions();
options.addArguments("--start-maximized", "--disable-cache");
webDriver.set(new ChromeDriver(options));
webDriver.get().manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
}
@AfterMethod
public void tearDown(){
System.out.println("I am in tearDown method.");
//You can clean up after tests.
//webDriver.get().quit();
webDriver.get().quit();
}
}
在两个单独的文件中:
public class Test1 extends TestBase {
@Test
public void goToGoogle() {
System.out.println("Google");
String googleURL = "http://google.com/";
webDriver.get().get(googleURL);
assertTrue(webDriver.get().getCurrentUrl().contains("google"), "We are on Google!");
}
}
public class Test2 extends TestBase {
@Test
public void goToStackOverflow() {
System.out.println("SO!");
String stackOverflowAddress = "http://stackoverflow.com/";
webDriver.get().get(stackOverflowAddress);
assertTrue(webDriver.get().getCurrentUrl().contains("stack"), "We are on SO!");
}
}
问题内容: 我有两个运行Windows Server 2012的虚拟机。一个运行Jenkins,另一个运行Jenkins的构建作业之一。作业从Subversion中检出测试代码,然后在Windows批处理脚本中运行。该测试可以编译并运行,但是会失败,并显示。这些是使用Selenium和Firefox驱动程序的TestNG测试。 如果我使用完全相同的命令并从Windows命令行运行它,则测试成功。我
这是我的整个测试课程: 有3个单元测试,它们在单独运行时都通过了,但当我运行整个测试类时,我的第2个和第3个测试失败,错误如下: 我已经想尽一切办法来解决这个问题: 我将测试实例化下的类移动到@Before函数中 我尝试创建@After函数并调用Mockito。重置我的模拟 我应该提到的是,我正在使用nhaarman。mockitokotlin2库和argumentCaptor。 关于为什么这些测
我有几个JUnit测试,都使用运行。我可以从我的SpringSource工具套件(EclipseJuno)IDE中按类单独运行它们,它们通过了。如果我尝试按模块运行它们(“运行所选项目中的所有测试”),则它们将失败,并出现以下初始化错误: 有什么办法解决吗?甚至故障排除。 吉文斯: JUnit 4.11版
我有一堆JUnit测试,它们都单独运行。每一个都是一个真正的独立单元测试--被测试的单个类。不需要上下文。我可以在Eclipse中或通过maven/surefire-plugin单独或一起运行它们。 此后,我添加了一个新的集成测试,它利用了Spring上下文等,并使用了SpringJUnit4ClassRunner。一旦我将这个测试添加到我的套件中,任何测试用例都会在这个类失败后运行。 我不确定这
不要与之前提出的问题混淆“为什么我的测试在一起运行时失败,但单独通过?” 我有一个任务,我需要修改JUnit测试类来处理多个数据库测试。在实现之前,我需要确保所有测试都在运行,没有失败。令我困惑的是,现在当我一起运行所有的类时,它显示它运行时没有失败。当我运行一个特定的类时,它突然失败了,如果我重复它,结果仍然存在。 这可能是什么原因造成的? 我自己没有写测试,因此我对测试内容的了解是有限的。不过
空手道afterFeature函数在本地运行时运行正常,但在Jenkins中运行时失败,我得到。而应为。 代码片段 主要的功能片段 cleanup.feature Jenkins的日志:的断言失败,但它没有记录响应状态的实际值。 此外,我没有看到在Jenkins中执行postFeature的日志,也不是我要做进一步分析的cucumber报告的一部分。