【发布时间】:2019-08-10 00:28:30
【问题描述】:
我想使用 selenium 网格在两个设备上进行并行执行。从建立 JSON,为每个设备运行 Appium 桌面开始,一切都已顺利完成。
与 appium 建立连接:
public class ApplicationHandling {
public static AndroidDriver driver;
public static ExtentTest test;
public static ExtentReports extent;
//public static boolean waitForPresenceOfElelment;
public static ConfigFileReader cfg;
public ApplicationHandling()
{
cfg = new ConfigFileReader();
System.out.println("Inside application handling constructor");
Date date=new Date();
SimpleDateFormat dateFormatFolder = new SimpleDateFormat("dd_MMM_yyyy");
File ResultDir = new File(System.getProperty("user.dir")+File.separator+"/FrameworkReports/"+dateFormatFolder.format(date));
System.out.println(ResultDir);
// Defining Directory/Folder Name
if (!ResultDir.exists()){ // Checks that Directory/Folder Doesn't Exists!
ResultDir.mkdir();
}
SimpleDateFormat dateFormat=new SimpleDateFormat("dd_MMM_yyyy_hh_mm_ssaa");
extent=new ExtentReports(ResultDir +"/" +"Report"+""+dateFormat.format(date)+".html",false);
}
public static RemoteWebDriver getInstance()
{
System.out.println("remote webdriver");
return driver;
}
@Parameters({"device","version"})
@BeforeTest(alwaysRun = true)
public static void setUp(String device,String version) throws MalformedURLException, InterruptedException {
DesiredCapabilities cap = new DesiredCapabilities();
cap.setCapability("platformName", "Android");
cap.setCapability("deviceName", device);
cap.setCapability("noReset", true);
cap.setCapability(CapabilityType.VERSION,version);
cap.setCapability("automationName", cfg.getAutomationName());
cap.setCapability ("appPackage", cfg.getAppPackage());
cap.setCapability ("appActivity", cfg.getAppActivity());
System.out.println("Before Suite Execution started");
System.out.println("Driver:"+driver);
System.out.println("URL:"+cfg.getApplicationUrl());
System.out.println("cap: "+cap);
driver = new AndroidDriver<MobileElement>(new URL(cfg.getApplicationUrl()), cap);
System.out.println(driver);
}
JSON:
{
"capabilities":
[
{
"deviceName": "Redmi",
"platformName": "Windows",
"browserName":"Android",
"platformVersion": "7.0",
"maxInstances": 1
}
],
"configuration":
{
"cleanUpCycle":2000,
"timeout":30000,
"proxy": "org.openqa.grid.selenium.proxy.DefaultRemoteProxy",
"url":"http://0.0.0.0:4723/wd/hub",
"host": "0.0.0.0",
"port": 4723
"maxSession": 1,
"register": true,
"registerCycle": 5000,
"hubPort": "4444",
"hubHost": "127.0.0.1"
}
}
Testng.xml
<test name="test_redmi">
<parameter name="device" value="Redmi"/>
<parameter name="version" value="7.0"/>
<classes>
<class name="Tests.LoginTest">
<methods>
<include name="loginOTP"/>
</methods>
</class>
</classes>
错误日志
org.openqa.selenium.remote.ProtocolHandshake createSession 信息:回退到直接 W3C 远程端连接
org.openqa.selenium.SessionNotCreatedException:无法创建新的远程会话。所需功能 = 功能 [{appPackage="com.amhi.healthjinn", appActivity="com.amhi.healthjinn.MainActivity", noReset=true, automationName=uiautomator2, platformName=Android, deviceName=Moto E, version=7.1.2 }],所需能力 = 能力 [{}] 构建信息:版本:'未知',修订:'1969d75',时间:'2016-10-18 09:43:45 -0700'
-> 它给了我创建驱动程序实例的错误。
【问题讨论】:
-
您也可以分享这个
ApplicationHandling课程代码吗?在这一行中,它显示了capabilities = Capabilities [{}]空功能。初始化可能有问题 -
可以贴一下appium服务器的日志吗?
-
在appium上,没有生成日志。说明appium成功注册到grid。应用的主要活动没有被调用
-
Appium 日志:[Appium] 欢迎使用 Appium v1.9.0 [Appium] 非默认服务器参数:[Appium] 端口:5001 [Appium] bootstrapPort:4725 [Appium] sessionOverride:true
-
nodeconfig: C:\Users\ab.chauhan\AndroidStudioProjects\grid_Server\device2.json [Appium] 启动网格的自动注册线程。将尝试每 5000 毫秒注册一次。 [Appium] Appium REST http 接口监听器开始于 0.0.0.0:5001 [HTTP] --> GET /wd/hub/status [HTTP] {} [MJSONWP] 使用 args 调用 AppiumDriver.getStatus(): [] [MJSONWP]使用 driver.getStatus() 结果响应客户端:{"build":{"version":"1.9.0"}} [HTTP] 10.10.23.99:4444网格上成功注册
标签: java selenium appium appium-android