From fce85f0a8e5c1db1f8286fef048c0d9981627fed Mon Sep 17 00:00:00 2001 From: Ivan Krutov Date: Thu, 31 May 2018 07:56:14 +0300 Subject: [PATCH] Automatically linking Selenoid UI to Selenoid / GgrUI (fixes #156) --- selenoid/base.go | 1 + selenoid/docker.go | 22 ++++++++++++++++++---- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/selenoid/base.go b/selenoid/base.go index 6baa991..769ffac 100644 --- a/selenoid/base.go +++ b/selenoid/base.go @@ -119,6 +119,7 @@ type PortAware struct { } const ( + GgrUIDefaultPort = 8888 SelenoidDefaultPort = 4444 SelenoidUIDefaultPort = 8080 DefaultRegistryUrl = "https://registry.hub.docker.com" diff --git a/selenoid/docker.go b/selenoid/docker.go index 21d5188..1781702 100644 --- a/selenoid/docker.go +++ b/selenoid/docker.go @@ -52,6 +52,7 @@ const ( selenoidUIImage = "aerokube/selenoid-ui" videoRecorderImage = "selenoid/video-recorder" selenoidContainerName = "selenoid" + ggrUIContainerName = "ggr-ui" selenoidUIContainerName = "selenoid-ui" overrideHome = "OVERRIDE_HOME" dockerApiVersion = "DOCKER_API_VERSION" @@ -720,15 +721,28 @@ func (c *DockerConfigurator) StartUI() error { return errors.New("Selenoid UI image is not downloaded: this is probably a bug") } - links := []string{selenoidContainerName} - - cmd := []string{} + var cmd, links []string + var selenoidUri string + for containerName, port := range map[string]int{ + selenoidContainerName: SelenoidDefaultPort, + ggrUIContainerName: GgrUIDefaultPort, + } { + if c.getContainer(containerName, port) != nil { + selenoidUri = fmt.Sprintf("--selenoid-uri=http://%s:%d", containerName, port) + links = []string{containerName} + break + } + } overrideCmd := strings.Fields(c.Args) if len(overrideCmd) > 0 { cmd = overrideCmd } if !contains(cmd, "--selenoid-uri") { - cmd = append(cmd, fmt.Sprintf("--selenoid-uri=http://%s:%d", selenoidContainerName, SelenoidDefaultPort)) + cmd = append(cmd, selenoidUri) + } + + if len(links) == 0 { + c.Errorf("Neither Selenoid nor Ggr UI is started. Selenoid UI may not work.") } overrideEnv := strings.Fields(c.Env)