org.openqa.selenium.SessionNotCreatedException:无法创建新会话。 (原始错误:请求新会话,但会话正在进行中)

问题描述 投票:0回答:8

我正在使用 iOS 版 Appium 1.4.8。我已经使用 xcode 在模拟器中构建了代码,并成功启动了服务器以及 Appium Inspector。但是在运行我的代码时,它抛出以下错误。

我的能力是 @方法之前 public void setUp() 抛出 MalformedURLException{

DesiredCapabilities capabilities = new DesiredCapabilities();
capabilities.setCapability("appium-version", "1.0");
capabilities.setCapability("platformName", "iOS");
capabilities.setCapability("platformVersion", "8.4");
capabilities.setCapability("deviceName", "iPad 2");
capabilities.setCapability("app", "/Users/arunhs/Desktop/AppiumReq/SRC/build/Debug-iphonesimulator/ComplianceWire.app");
driver = new AppiumDriver(new URL("http://127.0.0.1:4723/wd/hub"), capabilities);
driver.manage().timeouts().implicitlyWait(60, TimeUnit.SECONDS);

}

Error is: 
FAILED CONFIGURATION: @BeforeMethod setUp
org.openqa.selenium.SessionNotCreatedException: A new session could not be created. (Original error: Requested a new session but one was in progress) (WARNING: The server did not provide any stacktrace information)
Command duration or timeout: 447 milliseconds
Build info: version: '2.47.1', revision: '411b314', time: '2015-07-30 03:03:16'
System info: host: 'N/A', ip: 'N/A', os.name: 'Mac OS X', os.arch: 'x86_64', os.version: '10.10.4', java.version: '1.7.0_79'
Driver info: io.appium.java_client.AppiumDriver
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:526)
at org.openqa.selenium.remote.ErrorHandler.createThrowable(ErrorHandler.java:206)
at org.openqa.selenium.remote.ErrorHandler.throwIfResponseFailed(ErrorHandler.java:158)
at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:595)
at io.appium.java_client.AppiumDriver.execute(AppiumDriver.java:88)
at org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:242)
at org.openqa.selenium.remote.RemoteWebDriver.(RemoteWebDriver.java:128)
at org.openqa.selenium.remote.RemoteWebDriver.(RemoteWebDriver.java:155)
at io.appium.java_client.AppiumDriver.(AppiumDriver.java:44)
at com.selenium.test.DriverScript.setUp(DriverScript.java:68)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:85)
at org.testng.internal.Invoker.invokeConfigurationMethod(Invoker.java:515)
at org.testng.internal.Invoker.invokeConfigurations(Invoker.java:213)
at org.testng.internal.Invoker.invokeMethod(Invoker.java:590)
at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:834)
at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1142)
at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:124)
at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:108)
at org.testng.TestRunner.privateRun(TestRunner.java:771)
at org.testng.TestRunner.run(TestRunner.java:621)
at org.testng.SuiteRunner.runTest(SuiteRunner.java:357)
at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:352)
at org.testng.SuiteRunner.privateRun(SuiteRunner.java:310)
at org.testng.SuiteRunner.run(SuiteRunner.java:259)
at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)
at org.testng.TestNG.runSuitesSequentially(TestNG.java:1176)
at org.testng.TestNG.runSuitesLocally(TestNG.java:1101)
at org.testng.TestNG.run(TestNG.java:1009)
at org.testng.remote.RemoteTestNG.run(RemoteTestNG.java:111)
at org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:204)
at org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:175)
java ios appium
8个回答
8
投票

发生这种情况是因为上一个会话没有正确关闭,并且当测试中抛出异常时会发生这种情况。重新启动appium服务器并尝试一下,应该可以解决问题。

或者,如果您将 appium 作为节点进程启动,您可以提供选项

'--session-override true'
,这将避免此问题


2
投票

如果在 appium 应用程序上,则选择“设置”下的

Override Existing Sessions
复选框 -


1
投票

以下内容对我有用。我正在通过连接Android设备进行测试。请根据您的需要进行更改并应用,现在应该可以工作了。

        DesiredCapabilities capabilities = new DesiredCapabilities().android();
        capabilities.setCapability("no",true);
        capabilities.setCapability("newCommandTimeout", 100000);
        capabilities.setCapability("noReset", true);
        capabilities.setCapability(CapabilityType.BROWSER_NAME, "");
        capabilities.setCapability(CapabilityType.VERSION, "4.4.2");
        capabilities.setCapability("deviceName", "Galaxy nexus");
        capabilities.setCapability("app", application.getAbsolutePath());
        capabilities.setCapability("automationName", "selendroid");
        capabilities.setCapability("noRest", true);
        driver = new AndroidDriver<MobileElement>(new URL("http://127.0.0.1:4723/wd/hub"), capabilities);

1
投票

在功能中添加设备名称会有所帮助。 在 appium 日志中我可以找出丢失的东西。


0
投票

在任务管理器中杀掉appium等正在运行的服务器,基本上结束cmd的任务。


0
投票

我发现的最简单的方法是停止 Appium 服务器,退出它等待几秒钟,然后再次启动它并运行你的脚本。如果需要的话也可以用模拟器来做


0
投票

我多次遇到同样的错误。通过遵循以下简单的步骤,我能够解决该问题。

  1. 重启eclipse
  2. 关闭模拟器和android studio
  3. 在终端上退出
    appium
  4. 启动android studio
  5. 删除设备并创建新设备
  6. 现在启动模拟器并运行脚本

0
投票

我多次遇到同样的错误。通过遵循以下简单的步骤,我能够解决该问题。

重启eclipse 关闭你的模拟器和android studio 在终端上退出appium 启动android工作室 删除设备并创建新设备 现在启动模拟器并运行脚本

DesiredCapability 功能 = new DesiredCapability();

    capabilities.setCapability("appium:deviceName", "AndroidEmulator");
    capabilities.setCapability("appium:platformName", "android");
    capabilities.setCapability("appium:automationName", "uiautomator2");
    capabilities.setCapability("appium:app", "C:\\SampleApkFile\\Android.SauceLabs.Mobile.Sample.app.2.7.1.apk");
    capabilities.setCapability("appium:platformversion", "13");
    capabilities.setCapability("appium:noReset", true);
    capabilities.setCapability("appium:appWaitForLaunch", false);
    
    URL url = URI.create("http://127.0.0.1:4723/").toURL();
    
    AndroidDriver driver = new AndroidDriver(url, capabilities);
    
    try {
        Thread.sleep(5000);
    } catch (InterruptedException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    
    System.out.println("Applicaton started...");
    
    driver.quit();
© www.soinside.com 2019 - 2024. All rights reserved.