我观察下面的错误,当我通过TestNG的XML执行TestNG的套件。
重度:org.apache.commons.exec.ExecuteException:过程返回一个错误:-1073741502(退出值:-1073741502)失败配置:@BeforeMethod initializetest org.openqa.selenium.WebDriverException:超时等待司机服务器启动。 构建信息:版本: '3.141.59',修订版: 'e82be7d358',时间: '2018-11-14T08:17:03' 系统信息:主机: 'PDC2LAP-7173253',IP:'10 .170.10.178' ,OS 。名称: '视窗10',os.arch: 'AMD64',os.version:'10 0.0' ,java.version: '1.8.0_162' 驱动程序信息:driver.version:ChromeDriver在org.openqa.selenium.remote。 service.DriverService.waitUntilAvailable(DriverService.java:202)在org.openqa.selenium.remote.service.DriverService.start(DriverService.java:188)在org.openqa.selenium.remote.service.DriverCommandExecutor.execute(DriverCommandExecutor。的java:79)在org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:552)在org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:213)在org.openqa.selenium.remote .RemoteWebDriver。(RemoteWebDriver.java:131)在org.openqa.selenium.chrome.ChromeDriver。(ChromeDriver.java:181)在org.openqa.selenium.chrome.ChromeDriver。(ChromeDriver.java:168)在org.openqa .selenium.chrome.ChromeDriver。(ChromeDriver.java:123)在识别TestClass es.BaseClass.initializetest(BaseClass.java:25)在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)在sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl。的java:43)在java.lang.reflect.Method.invoke(Method.java:498)在org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:85)在org.testng.internal.Invoker.invokeConfigurationMethod(祈求的.java:510)处org.testng.internal.Invoker.invokeMethod(Invoker.java:585)在org.testng.internal.Invoker.invokeTestMethod(org.testng.internal.Invoker.invokeConfigurations(Invoker.java:211) Invoker.java:816)在org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1124)在org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:125)在org.testng.internal.TestMethodWorker.run (TestMethodWorker.java:108)在org.testng.TestRunner.privateRun(TestRunner.java:774)在org.testng.TestRunne r.run(TestRunner.java:624)在org.testng.SuiteRunner.runTest(SuiteRunner.java:359)在org.testng.SuiteRunner.runSequentially(SuiteRunner.java:354)在org.testng.SuiteRunner.privateRun(SuiteRunner的.java:312)在org.testng.SuiteRunner.run(SuiteRunner.java:261)在org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)在org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)在org.testng.TestNG.runSuitesSequentially(TestNG.java:1191)在org.testng.TestNG.runSuitesLocally(TestNG.java:1116)在org.testng.TestNG.run(TestNG.java:1024)在org.testng。 remote.AbstractRemoteTestNG.run(AbstractRemoteTestNG.java:115)在org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:251)在org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:77)引起的:有机.openqa.selenium.net.UrlChecker $ TimeoutException异常:超时等待[ HTTP://本地主机:33768 /状态]是后org.openqa.selenium.net.UrlChecker.waitUntilAvailable 20001个毫秒可用(UrlChecker.java:100 )在org.openqa.sel java.util.concurrent.TimeoutException在java.util.concurrent.FutureTask.get(FutureTask.java:205)在COM:enium.remote.service.DriverService.waitUntilAvailable(DriverService.java:197)...... 35多所致.google.common.util.concurrent.SimpleTimeLimiter.callWithTimeout(SimpleTimeLimiter.java:156)在org.openqa.selenium.net.UrlChecker.waitUntilAvailable(UrlChecker.java:75)... 36多个
试验平稳运行最初10-12测试,但与上述错误消息后失败。 我希望这是一些问题与配置的版本,但我无法找到它。
项目具有以下POM:
<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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>PageObjects</groupId>
<artifactId>CustomerPortal</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>CustomerPortal</name>
<url>http://maven.apache.org</url>
<dependencies>
<!-- https://mvnrepository.com/artifact/com.aventstack/extentreports -->
<dependency>
<groupId>com.aventstack</groupId>
<artifactId>extentreports</artifactId>
<version>4.0.9</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.relevantcodes/extentreports -->
<dependency>
<groupId>com.relevantcodes</groupId>
<artifactId>extentreports</artifactId>
<version>2.41.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.6</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-java -->
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-java</artifactId>
<version>3.141.59</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-api -->
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-api</artifactId>
<version>3.141.59</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.poi/poi -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.0.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.0.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.testng/testng -->
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.14.3</version>
<scope>test</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-lang/commons-lang -->
<dependency>
<groupId>commons-lang</groupId>
<artifactId>commons-lang</artifactId>
<version>2.6</version>
</dependency>
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.9.8</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
Java版本是java版的 “1.8.0_201”。 ChromeDriver 2.43.600210。 请帮我这个问题作为测试失败突然离开全自动化脚本不稳定。
TestNG的的组织结构如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="CustomerPortalTestSuite-SIT2">
<test thread-count="5" name="CustomerPortalTestExecution">
<classes>
<class name="testclasses.CustomerPortalSupportTest"/>
<class name="testclasses.CustomerPortalAccountTest"/>
<class name="testclasses.CustomerPortalBillingTest"/>
<class name="testclasses.CustomerPortalHomeTest"/>
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->
下面是写在@BeforeMethod和@AfterMethod代码,
@BeforeMethod
public void initializetest() {
System.setProperty("webdriver.chrome.driver", "C:\\Downloads\\ChromeDriverLatest\\chromedriver.exe");
driver =new ChromeDriver();
wait = new WebDriverWait(driver,10);
}
@AfterMethod
public void endTest() throws IOException, Exception {
File scrFile = ((TakesScreenshot)driver).getScreenshotAs(OutputType.FILE);
FileUtils.copyFile(scrFile, new File("c:\\SeleniumScreenshots\\" + count +".jpg"));
count++;
Thread.sleep(5000);
driver.quit();
driver=null;
}
测试类样品下面:
@DataProvider(name="editAccDetails")
public Object[][] logincreds(){
Object[][] data = new Object[1][2];
data[0][0] = "test";
data[0][1] = "test";
return data;
}
@Test(priority=1, dataProvider="editAccDetails")
public void Details(String UsernameDP, String PasswordDP) throws Exception {
Login TS1 = new Login(driver,wait);
TS1.test(UsernameDP, PasswordDP);
HomePage TS2 = new HomePage(driver,wait);
TS2.test();
AccountPages TS3 = new AccountPages(driver,wait);
TS3.Details();
}