2016-01-22 244 views
0

我使用appium自動執行android應用程序。使用url創建驅動程序。 在這裏,我給移動網絡瀏覽器的空字符串,因爲我直接自動化的應用程序。Appium無法訪問瀏覽器異常

這裏是appium代碼,

public class Cal { 
    private static AndroidDriver driver; 
    public static void main(String[] args) throws MalformedURLException, InterruptedException{ 
    File app = new File("C:\\Users\\Priya\\Desktop\\FitbaseApk\\Fitbase_01_21_2016_APK.apk"); 

DesiredCapabilities capabilities = new DesiredCapabilities(); 
capabilities.setCapability(CapabilityType.BROWSER_NAME, ""); 
capabilities.setCapability("deviceName", "Lenovo- A7000-a"); 
capabilities.setCapability("platformVersion", "5.0"); 
capabilities.setCapability("platformName", "Android"); 
capabilities.setCapability("app", app.getAbsolutePath()); 
    capabilities.setCapability("appPackage", "com.ionicframework.fitbase444706"); 
capabilities.setCapability("appActivity","com.ionicframework.fitbase444706.mainActivity"); 

    driver = new AndroidDriver(new URL("http://127.0.0.1:4723/wd/hub"), capabilities); 
    driver.manage().timeouts().implicitlyWait(80, TimeUnit.SECONDS); 
    Thread.sleep(10000); 
} 
} 

以下是錯誤日誌:

Exception in thread "main" org.openqa.selenium.remote.UnreachableBrowserException: Could not start a new session. Possible causes are invalid address of the remote server or browser start-up failure. 
Build info: version: '2.49.0', revision: '365eeb4', time: '2016-01-13 18:33:29' 
System info: host: 'QA1-PC', ip: '192.168.0.82', os.name: 'Windows 7', os.arch: 'amd64', os.version: '6.1', java.version: '1.8.0_71' 
Driver info: driver.version: AndroidDriver 
at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:665) 
at io.appium.java_client.DefaultGenericMobileDriver.execute(DefaultGenericMobileDriver.java:42) 
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:249) 
at org.openqa.selenium.remote.RemoteWebDriver.<init>(RemoteWebDriver.java:131) 
at org.openqa.selenium.remote.RemoteWebDriver.<init>(RemoteWebDriver.java:144) 
at io.appium.java_client.DefaultGenericMobileDriver.<init>(DefaultGenericMobileDriver.java:37) 
at io.appium.java_client.AppiumDriver.<init>(AppiumDriver.java:161) 
at io.appium.java_client.AppiumDriver.<init>(AppiumDriver.java:170) 
at io.appium.java_client.android.AndroidDriver.<init>(AndroidDriver.java:82) 
at FitbaseApp.Cal.main(Cal.java:37) 
Caused by: 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: '2.49.0', revision: '365eeb4', time: '2016-01-13 18:33:29' 
System info: host: 'QA1-PC', ip: '192.168.0.82', os.name: 'Windows 7', os.arch: 'amd64', os.version: '6.1', java.version: '1.8.0_71' 
Driver info: driver.version: AndroidDriver 
at io.appium.java_client.remote.AppiumCommandExecutor.execute(AppiumCommandExecutor.java:79) 
at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:644) 
... 11 more 
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:151) 
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:143) 
at org.openqa.selenium.remote.internal.ApacheHttpClient.execute(ApacheHttpClient.java:89) 
at org.openqa.selenium.remote.HttpCommandExecutor.execute(HttpCommandExecutor.java:142) 
at io.appium.java_client.remote.AppiumCommandExecutor.execute(AppiumCommandExecutor.java:67) 
... 12 more 
Caused by: java.net.ConnectException: Connection refused: connect 
at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method) 
at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:85) 
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) 
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) 
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) 
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172) 
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) 
at java.net.Socket.connect(Socket.java:589) 
at org.apache.http.conn.socket.PlainConnectionSocketFactory.connectSocket(PlainConnectionSocketFactory.java:74) 
at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:134) 
... 25 more 

回答

1

問題所在。

HttpHostConnectException: Connect to 127.0.0.1:4723 [/127.0.0.1] failed:

請嘗試重新啓動服務器appijum,如果問題仍然存在,嘗試在服務器和代碼enter image description here

+0

謝謝你Karthick23的回覆。我爲此得到了解決方案。問題發生的原因是,appium需要相當長的時間才能啓動。你可以看到它在最後我給了「driver.manage()。timeouts()。implicitlyWait(80,TimeUnit.SECONDS);」。我刪除了它,現在它工作正常.. –

+0

@Lakshmi Priya多數民衆贊成多好..如果你覺得如果你從我的答案學到somethng有益善意upvote它..在此先感謝 – karthick23

+0

好吧。我相信它一旦獲得您的聲譽就會被添加 – karthick23

1

我得到了解決這個改變的端口號。問題發生的原因是,appium需要相當長的時間才能啓動。你可以看到它在最後我給了「driver.manage()。timeouts()。implicitlyWait(80,TimeUnit.SECONDS);」。在這裏,我減少了時間,現在它工作正常..

1

有了上面的代碼,你不應該把一個固定的Thread.Sleep在所有,因爲你永遠不知道appium將要開始多久。最好的方法是以編程方式啓動appium,然後監視http://localhost:4723,這是appium始終運行的地方。你需要繼續向這個URL發送請求,並等待你從這個URL得到響應,一旦你得到響應,你應該初始化驅動程序,就像,如果你明白這一點,我會發布整個代碼,httpClientWrap是我的圖書館。

public static boolean waitForAppiumServer() 
    { 
     boolean flag = false; 

     for(int i=0; i<=20; i++) 
     {  
      String status = httpClientWrap.sendGetRequest("http://localhost:4723/wd/status"); 

      if(!status.isEmpty()) 
      { 
       logger.info("appium service has been launched successfully. "); 

       flag = true; 
       break; 
      } 

      logger.info("appium service has not been launched, waiting to get started .... attempt: "+i); 

      try {Thread.sleep(3000);} catch (InterruptedException e) {} 
     } 

     return flag; 
    } 
+0

感謝Pankaj重播,我刪除了Thread.Sleep –

相關問題