簡體   English   中英

通過代碼啟動appium服務器時連接超時

[英]Connection time out while starting appium server via code

從我的代碼啟動appium服務器時,我遇到以下提到的連接超時問題:-該異常是我每天第一次嘗試運行我的代碼時,此后我自動解決,並且整天正常工作,但是每天早晨,由於我嘗試運行mu代碼,我每天都會在很長時間內收到此錯誤:-

*請指出問題所在!

我啟動appium服務器的代碼:-

public static String nodePath="D:\\appium_new\\Appium\\node.exe";
    public static String appiumJsPath="D:\\appium_new\\Appium\\node_modules\\appium\\bin\\appium.js";
    public static String cmd=nodePath+" " +appiumJsPath;
    public  void appServer_Start() throws IOException, InterruptedException{
        p=Runtime.getRuntime().exec(cmd);
        Thread.sleep(20000);
        if (p!=null) {
            System.out.println("Server started successfully");
        }

    }


public void appServer_Stop(){
    if (p!=null) {
        p.destroy();
        System.out.println("Server stopped successfully");

    }
}


DesiredCapabilities cap=new DesiredCapabilities();
    cap.setCapability("platformName", "Android");
    cap.setCapability("platformVersion", "5.1");
    cap.setCapability("deviceName", "Emulator");
    cap.setCapability("app", app.getAbsolutePath());
    cap.setCapability("appPackage", "com.shiprocket.shiprocket");
    cap.setCapability("appActivity", "com.shiprocket.shiprocket.activity.CarouselActivity");
    Thread.sleep(10000);
    driver = new AndroidDriver<WebElement>(new URL("http://127.0.0.1:4723/wd/hub"),cap);
    driver.manage().timeouts().implicitlyWait(30, TimeUnit.SECONDS);


org.openqa.selenium.WebDriverException: org.apache.http.conn.HttpHostConnectException: Connect to 127.0.0.1:4723 [/127.0.0.1] failed: Connection refused: connect
Build info: version: '3.0.1', revision: '1969d75', time: '2016-10-18 09:49:13 -0700'
System info: host: 'SureshSharma-PC', ip: '169.254.246.124', os.name: 'Windows 7', os.arch: 'amd64', os.version: '6.1', java.version: '1.8.0_111'
Driver info: driver.version: AndroidDriver
    at io.appium.java_client.remote.AppiumCommandExecutor.execute(AppiumCommandExecutor.java:84)
    at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:601)
    at io.appium.java_client.DefaultGenericMobileDriver.execute(DefaultGenericMobileDriver.java:40)
    at io.appium.java_client.AppiumDriver.execute(AppiumDriver.java:1)
    at io.appium.java_client.android.AndroidDriver.execute(AndroidDriver.java:1)
    at org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:241)
    at org.openqa.selenium.remote.RemoteWebDriver.<init>(RemoteWebDriver.java:128)
    at org.openqa.selenium.remote.RemoteWebDriver.<init>(RemoteWebDriver.java:141)
    at io.appium.java_client.DefaultGenericMobileDriver.<init>(DefaultGenericMobileDriver.java:36)
    at io.appium.java_client.AppiumDriver.<init>(AppiumDriver.java:114)
    at io.appium.java_client.AppiumDriver.<init>(AppiumDriver.java:132)
    at io.appium.java_client.android.AndroidDriver.<init>(AndroidDriver.java:92)
    at backendServer.Server.BackendServerStart(Server.java:77)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:104)
    at org.testng.internal.Invoker.invokeConfigurationMethod(Invoker.java:515)
    at org.testng.internal.Invoker.invokeConfigurations(Invoker.java:217)
    at org.testng.internal.Invoker.invokeConfigurations(Invoker.java:144)
    at org.testng.SuiteRunner.privateRun(SuiteRunner.java:326)
    at org.testng.SuiteRunner.run(SuiteRunner.java:289)
    at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
    at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)
    at org.testng.TestNG.runSuitesSequentially(TestNG.java:1293)
    at org.testng.TestNG.runSuitesLocally(TestNG.java:1218)
    at org.testng.TestNG.runSuites(TestNG.java:1133)
    at org.testng.TestNG.run(TestNG.java:1104)
    at org.testng.remote.AbstractRemoteTestNG.run(AbstractRemoteTestNG.java:132)
    at org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:236)
    at org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:81)
Caused by: org.apache.http.conn.HttpHostConnectException: Connect to 127.0.0.1:4723 [/127.0.0.1] failed: Connection refused: connect
    at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:158)
    at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.connect(PoolingHttpClientConnectionManager.java:353)
    at org.apache.http.impl.execchain.MainClientExec.establishRoute(MainClientExec.java:380)
    at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:236)
    at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:184)
    at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:88)
    at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:110)
    at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:184)
    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:71)
    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:55)
    at org.openqa.selenium.remote.internal.ApacheHttpClient.fallBackExecute(ApacheHttpClient.java:142)
    at org.openqa.selenium.remote.internal.ApacheHttpClient.execute(ApacheHttpClient.java:88)
    at org.openqa.selenium.remote.ProtocolHandshake.createSession(ProtocolHandshake.java:108)
    at org.openqa.selenium.remote.ProtocolHandshake.createSession(ProtocolHandshake.java:64)
    at org.openqa.selenium.remote.HttpCommandExecutor.execute(HttpCommandExecutor.java:141)
    at io.appium.java_client.remote.AppiumCommandExecutor.execute(AppiumCommandExecutor.java:69)
    ... 31 more
Caused by: java.net.ConnectException: Connection refused: connect
    at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method)
    at java.net.DualStackPlainSocketImpl.socketConnect(Unknown Source)
    at java.net.AbstractPlainSocketImpl.doConnect(Unknown Source)
    at java.net.AbstractPlainSocketImpl.connectToAddress(Unknown Source)
    at java.net.AbstractPlainSocketImpl.connect(Unknown Source)
    at java.net.PlainSocketImpl.connect(Unknown Source)
    at java.net.SocksSocketImpl.connect(Unknown Source)
    at java.net.Socket.connect(Unknown Source)
    at org.apache.http.conn.socket.PlainConnectionSocketFactory.connectSocket(PlainConnectionSocketFactory.java:74)
    at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:141)
    ... 46 more

有一種更好的方法可以通過代碼啟動appium服務器。 為此,您需要執行以下步驟:

  1. 安裝最新的穩定版NodeJ(還將安裝npm)。
  2. 使用以下命令從命令行使用npm安裝appium:

    npm install -g appium

  3. 成功安裝appium之后,在環境路徑變量中添加新變量,名稱為“ APPIUM_BINARY_PATH”,值為“ C:\\ Users \\ YourUserName \\ AppData \\ Roaming \\ npm \\ node_modules \\ appium \\ build \\ lib \\ appium.js”

  4. 如果您以前沒有添加過,請添加ANDROID_HOME環境變量。

使用下面的代碼片段,該代碼片段使用內置的appium庫啟動appium服務器並運行非常平穩。

    public static AndroidDriver<MobileElement> driver;
    public static AppiumDriverLocalService service;
    service = AppiumDriverLocalService.buildDefaultService();
    DesiredCapabilities cap=new DesiredCapabilities();
    cap.setCapability("platformName", "Android");
    cap.setCapability("platformVersion", "5.1");
    cap.setCapability("deviceName", "Emulator");
    cap.setCapability("appPackage", "com.your.sample.app");
    cap.setCapability("appActivity", "com.your.sample.app.YourAppActivity");
    service.start();
    driver = new AndroidDriver<MobileElement>(service, capabilities);

您的appium服務器未啟動

要么

您的網址或端口號在下面的代碼行中不正確

ad = new AndroidDriver(new URL("http://localhost:4723/wd/hub"), capabilities);

完整的代碼如下所示:

    // Capabilities should be same as declared in Appium settings
    DesiredCapabilities capabilities = new DesiredCapabilities();
    capabilities.setCapability("deviceName", "TestSample");
    capabilities.setCapability("platformName", "Android");

    capabilities.setCapability(CapabilityType.VERSION, "6.0");
    capabilities.setCapability(CapabilityType.PLATFORM, "Windows");

    // application package name
    capabilities.setCapability("app-package", "com.demo.pass");

    // Application start Activity
    capabilities.setCapability("app-activity", "com.demo.pass.acti.SplashScreen");

    capabilities.setCapability("unicodeKeyboard", false);

    ad = new AndroidDriver(new URL("http://localhost:4723/wd/hub"), capabilities);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM