使用脚本设置Selenium网格

使用脚本设置Selenium网格,selenium,selenium-grid,Selenium,Selenium Grid,设置selenium网格: 我能够在命令提示符下使用以下命令设置网格(集线器和节点),然后能够启动浏览器并成功执行测试 java -jar selenium-server-standalone-3.4.0.jar -role hub java -jar selenium-server-standalone-3.4.0.jar -role webdriver -hub "http://localhost:4444/grid/register" -port 5566 尝试通过脚本设

设置selenium网格:

我能够在命令提示符下使用以下命令设置网格(集线器和节点),然后能够启动浏览器并成功执行测试

    java -jar selenium-server-standalone-3.4.0.jar -role hub
    java -jar selenium-server-standalone-3.4.0.jar -role webdriver -hub "http://localhost:4444/grid/register" -port 5566
尝试通过脚本设置selenium网格时,我成功地设置了集线器和节点,但无法启动浏览器

请帮忙解决这个问题

请在下面查找代码和控制台:

    package config.HubNode;

    import java.net.MalformedURLException;  
    import java.net.URL;    
    import org.openqa.grid.common.RegistrationRequest;  
    import org.openqa.grid.internal.utils.SelfRegisteringRemote;  
    import org.openqa.grid.internal.utils.configuration.GridHubConfiguration;  
    import org.openqa.grid.internal.utils.configuration.GridNodeConfiguration;  
    import org.openqa.grid.web.Hub;  
    import org.openqa.selenium.Platform; 
    import org.openqa.selenium.WebDriver;  
    import org.openqa.selenium.remote.DesiredCapabilities;
    import org.openqa.selenium.remote.RemoteWebDriver;

    public class HubNodeConfig {

    public static void main(String[] args) throws Exception {

        HubNodeConfig objHubNodeConfig = new HubNodeConfig();
        objHubNodeConfig.HubConfig();
        System.out.println("Hub Configured Successfully");

        objHubNodeConfig.NodeConfig();
        System.out.println("Node Configured to Hub Successfully");
        objHubNodeConfig.InvokeBrowser();
    }

    public void HubConfig() throws Exception
    {
        GridHubConfiguration gridHubConfig = new GridHubConfiguration();
        gridHubConfig.role = "hub";
        gridHubConfig.host = "localhost";
        gridHubConfig.port = 4444;

        Hub myHub = new Hub(gridHubConfig);
        myHub.start();
    }

    public void NodeConfig()
    {
        GridNodeConfiguration gridNodeConfig = new GridNodeConfiguration();
        gridNodeConfig.hub = "http://localhost:4444/grid/register"
        gridNodeConfig.host = "192.xxx.xx.xx" //my ip address
        gridNodeConfig.port = 5566;
        gridNodeConfig.role = "webdriver";

        RegistrationRequest req = new RegistrationRequest(gridNodeConfig);
        req.getConfiguration();
        req.validate();
        RegistrationRequest.build(gridNodeConfig);

        SelfRegisteringRemote remote = new SelfRegisteringRemote(req);
        remote.startRegistrationProcess();
    }

    public void InvokeBrowser() throws MalformedURLException
    {
        System.setProperty("webdriver.chrome.driver", "E:\\chromedriver.exe");
        DesiredCapabilities capability = DesiredCapabilities.chrome();
        capability.setBrowserName("chrome");
        capability.setPlatform(Platform.WIN10);

        WebDriver driver = new RemoteWebDriver(new URL("http://"+gridNodeConfig.host+":"+gridNodeConfig.port+"/wd/hub"), capability);
        System.out.println("Driver Launched Successfully");
        driver.get("https://google.com");
    }
    }
控制台错误消息和网格的屏幕截图:



    2017-07-20 23:57:17.135:INFO::main: Logging initialized @2576ms to org.seleniumhq.jetty9.util.log.StdErrLog    
    Jul 20, 2017 11:57:17 PM org.openqa.grid.web.Hub initServer
    INFO: Will listen on 4444    
    2017-07-20 23:57:17.509:INFO:osjs.Server:main: jetty-9.4.3.v20170317     
    2017-07-20 23:57:17.569:INFO:osjs.session:main: DefaultSessionIdManager workerName=node0    
    2017-07-20 23:57:17.570:INFO:osjs.session:main: No SessionScavenger set, using defaults    
    2017-07-20 23:57:17.573:INFO:osjs.session:main: Scavenging every 600000ms    
    2017-07-20 23:57:17.592:INFO:osjsh.ContextHandler:main: Started o.s.j.s.ServletContextHandler@1a1d6a08{/,null,AVAILABLE}    
    2017-07-20 23:57:17.804:INFO:osjs.AbstractConnector:main: Started ServerConnector@77f99a05{HTTP/1.1,[http/1.1]}{0.0.0.0:4444}    
    2017-07-20 23:57:17.804:INFO:osjs.Server:main: Started @3245ms    
    Hub Configured Successfully    
    Jul 20, 2017 11:57:19 PM org.openqa.grid.internal.utils.SelfRegisteringRemote$1 run    
    INFO: Starting auto registration thread. Will try to register every 5000 ms.    
    Jul 20, 2017 11:57:19 PM org.openqa.grid.internal.utils.SelfRegisteringRemote registerToHub    
    INFO: Registering the node to the hub: http: //localhost:4444/grid/register    
    Node Configured to Hub Successfully    
    Jul 20, 2017 11:57:19 PM org.openqa.grid.internal.Registry add    
    INFO: Registered a node http: //192.xxx.xx.xx:5566    
    Jul 20, 2017 11:57:19 PM org.openqa.grid.internal.utils.SelfRegisteringRemote registerToHub   
    INFO: The node is registered to the hub and ready to use    

    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: '3.4.0', revision: 'unknown', time: 'unknown'
    System info: host: 'KRISH', ip: '192.xxx.xx.xx', os.name: 'Windows 10', os.arch: 'amd64', os.version: '10.0', java.version: '1.8.0_131'    
    Driver info: driver.version: RemoteWebDriver
        at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:658)
        at org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:250)
        at org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:236)
        at org.openqa.selenium.remote.RemoteWebDriver.(RemoteWebDriver.java:137)
        at org.openqa.selenium.remote.RemoteWebDriver.(RemoteWebDriver.java:174)
        at config.HubNode.HubNodeConfig.InvokeBrowser(HubNodeConfig.java:71)
        at config.HubNode.HubNodeConfig.main(HubNodeConfig.java:29)
     Caused by: org.apache.http.conn.HttpHostConnectException: Connect to 192.xxx.xx.xx:5566 [/192.xxx.xx.xx] failed: Connection refused: connect 
        at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:159)
        at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.connect(PoolingHttpClientConnectionManager.java:359)
        at org.apache.http.impl.execchain.MainClientExec.establishRoute(MainClientExec.java:381)
        at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:237)
        at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:185)
        at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:89)
        at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:111)
        at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:185)
        at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:72)
        at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:56)
        at org.openqa.selenium.remote.internal.ApacheHttpClient.fallBackExecute(ApacheHttpClient.java:139)
        at org.openqa.selenium.remote.internal.ApacheHttpClient.execute(ApacheHttpClient.java:87)
        at org.openqa.selenium.remote.ProtocolHandshake.createSession(ProtocolHandshake.java:343)
        at org.openqa.selenium.remote.ProtocolHandshake.createSession(ProtocolHandshake.java:159)
        at org.openqa.selenium.remote.HttpCommandExecutor.execute(HttpCommandExecutor.java:142)
        at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:637)
        ... 6 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:75)
        at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:142)
        ... 21 more

    >Jul 21, 2017 12:15:30 AM org.openqa.grid.selenium.proxy.DefaultRemoteProxy onEvent     
    INFO: Marking the node http: //192.xx.xx.xx:5566 as down: cannot reach the node for 2 tries    
    Jul 21, 2017 12:16:30 AM org.openqa.grid.selenium.proxy.DefaultRemoteProxy onEvent    
    INFO: Unregistering the node http: //192.xx.xx.xx:5566 because it's been down for 60077 milliseconds    
    Jul 21, 2017 12:16:30 AM org.openqa.grid.internal.Registry removeIfPresent    
    WARNING: Cleaning up stale test sessions on the unregistered node http: //192.xx.xx.xx:5566    
    Jul 21, 2017 12:16:34 AM org.openqa.grid.internal.utils.SelfRegisteringRemote registerToHub    
    INFO: Registering the node to the hub: http: //localhost:4444/grid/register    
    Jul 21, 2017 12:16:34 AM org.openqa.grid.internal.Registry add    
    INFO: Registered a node http: //192.xx.xx.xx:5566    
    Jul 21, 2017 12:16:34 AM org.openqa.grid.internal.utils.SelfRegisteringRemote registerToHub    
    INFO: The node is registered to the hub and ready to use    
    Jul 21, 2017 12:16:46 AM org.openqa.grid.selenium.proxy.DefaultRemoteProxy onEvent    
    INFO: Marking the node http: //192.xx.xx.xx:5566 as down: cannot reach the node for 2 tries    


2017-07-20 23:57:17.135:INFO::main:Logging initialized@2576ms到org.seleniumhq.jetty9.util.log.StdErrLog
2017年7月20日晚上11:57:17 org.openqa.grid.web.Hub initServer
信息:请拨打4444收听
2017-07-20 23:57:17.509:信息:osjs.服务器:main:jetty-9.4.3.v20170317
2017-07-20 23:57:17.569:信息:osjs.session:main:DefaultSessionIdManager workerName=node0
2017-07-20 23:57:17.570:INFO:osjs.session:main:No SessionScavenger set,使用默认值
2017-07-20 23:57:17.573:信息:osjs.会话:主要:每600000毫秒清除一次
2017-07-20 23:57:17.592:信息:osjsh.ContextHandler:main:启动o.s.j.s。ServletContextHandler@1a1d6a08{/,空,可用}
2017-07-20 23:57:17.804:INFO:osjs.AbstractConnector:main:StartedServerConnector@77f99a05{HTTP/1.1[HTTP/1.1]}{0.0.0.0:4444}
2017-07-20 23:57:17.804:INFO:osjs.Server:main:Started@3245ms
集线器配置成功
2017年7月20日晚上11:57:19 org.openqa.grid.internal.utils.SelfRegisteringRemote$1运行
信息:正在启动自动注册线程。将尝试每5000毫秒注册一次。
2017年7月20日晚上11:57:19 org.openqa.grid.internal.utils.SelfRegisteringRemote registerToHub
信息:将节点注册到中心:http://localhost:4444/grid/register
节点已成功配置为集线器
2017年7月20日晚上11:57:19 org.openqa.grid.internal.Registry add
信息:注册了一个节点http://192.xxx.xx.xx:5566
2017年7月20日晚上11:57:19 org.openqa.grid.internal.utils.SelfRegisteringRemote registerToHub
信息:节点已注册到中心并准备就绪
线程“main”中出现异常
org.openqa.selenium.remote.UnreachableBrowserException:无法启动新会话。可能的原因是远程服务器地址无效或浏览器启动失败。
生成信息:版本:“3.4.0”,版本:“未知”,时间:“未知”
系统信息:主机:'KRISH',ip:'192.xxx.xx.xx',os.name:'Windows 10',os.arch:'amd64',os.version:'10.0',java.version:'1.8.0_131'
驱动程序信息:Driver.version:RemoteWebDriver
位于org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:658)
位于org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:250)
位于org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:236)
位于org.openqa.selenium.remote.RemoteWebDriver(RemoteWebDriver.java:137)
位于org.openqa.selenium.remote.RemoteWebDriver(RemoteWebDriver.java:174)
位于config.HubNode.HubNodeConfig.InvokeBrowser(HubNodeConfig.java:71)
位于config.HubNode.HubNodeConfig.main(HubNodeConfig.java:29)
原因:org.apache.http.conn.HttpHostConnectException:连接到192.xxx.xx:5566[/192.xxx.xx.xx]失败:连接被拒绝:连接
位于org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:159)
位于org.apache.http.impl.conn.poolghttpclientconnectionmanager.connect(poolghttpclientconnectionmanager.java:359)
位于org.apache.http.impl.execchain.MainClientExec.buildRoute(MainClientExec.java:381)
位于org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:237)
位于org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:185)
位于org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:89)
位于org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:111)
位于org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:185)
在org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:72)
在org.apache.http.impl.client.CloseableHttpClient.execute上(CloseableHttpClient.java:56)
位于org.openqa.selenium.remote.internal.ApacheHttpClient.fallBackExecute(ApacheHttpClient.java:139)
位于org.openqa.selenium.remote.internal.ApacheHttpClient.execute(ApacheHttpClient.java:87)
位于org.openqa.selenium.remote.ProtocolHandshake.createSession(ProtocolHandshake.java:343)
位于org.openqa.selenium.remote.ProtocolHandshake.createSession(ProtocolHandshake.java:159)
位于org.openqa.selenium.remote.HttpCommandExecutor.execute(HttpCommandExecutor.java:142)
位于org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:637)
... 还有6个
原因:java.net.ConnectException:连接被拒绝:连接
位于java.net.DualStackPlainSocketImpl.waitForConnect(本机方法)
位于java.net.DualStackPlainSocketImpl.socketConnect(未知源)
位于java.net.AbstractPlainSocketImpl.doConnect(未知源)
位于java.net.AbstractPlainSocketImpl.connectToAddress(未知源)
位于java.net.AbstractPlainSocketImpl.connect(未知源)
位于java.net.PlainSocketImpl.connect(未知源)
位于java.net.socksocketimpl.connect(未知源)
位于java.net.Socket.connect(未知源)
位于org.apache.http.conn.socket.PlainConnectionSocketFactory.connectSocket(PlainConnectionSocketFactory.java:75)
位于org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:142)
... 还有21个
>2017年7月21日上午12:15:30 org.openqa.grid.selenium.proxy.DefaultRemoteProxy OneEvent
信息:将节点http://192.xx.xx.xx:5566标记为向下:在2 t内无法到达节点
RegistrationRequest req = RegistrationRequest.build(gridNodeConfig);
SelfRegisteringRemote remote = new SelfRegisteringRemote(req);
remote.setRemoteServer(new SeleniumServer(gridNodeConfig));
remote.startRemoteServer();
remote.startRegistrationProcess();
WebDriver driver = new RemoteWebDriver(new URL("http://" + gridHubConfig.host + ":" + gridHubConfig.port + "/wd/hub"), capability);