posted

0 Comments

By Tom Schwaller, Senior Technical Product Manager, Michael Roy, Product Line Marketing Manager, and Simone Morellato, Director Technical Product Management

One thing that makes containers great is their ability to rapidly spin up a browser-compatibility testing environment. There are plenty of great tools that can then be used to automate this testing, and Selenium is one of the most deployed and trusted solutions available.

In this post, we’ll look at deploying and running Selenium Grid with vSphere Integrated Containers, which allow you to consume resources when they are needed without pre-provision large VMs.

Selenium Grid is essentially an orchestrated, multi-node deployment of Selenium. With it, you can test multiple combinations of operating systems and browsers in parallel. If you’re just getting started with Selenium in general, using it to test multiple combinations might be overkill, but if you’re already familiar with running a single instance of Selenium, then going to Grid is a natural progression.

Previously, organizations had to configure testing on a per-machine basis, which meant manually creating a VM, installing an OS and a browser, setting a snapshot point, manually downloading the code to test, opening up a browser and testing the app. This process doesn’t scale well if you need to support many browsers and OS combinations. Further, once things were running, if there was a problem, it was difficult to troubleshoot and return to a known good state, even with snapshots in place.

Selenium Grid

Selenium Grid leverages docker-compose so environments are dictated as code through the compose file, thereby allowing them to be redeployed on the fly, always with the same configuration.

This on-the-fly model also saves resources because you can destroy the vSphere Integrated Container (VIC) VMs when testing is done, and deploy them only when actively testing instead of letting them sit idle for long periods of time with CPU, memory and disk resources being allocated. And the vSphere administrator has full visibility and control over the container VMs running in a virtual container host resource pool. This pool can be as large as you like, is extensible on the fly and is not constrained by the limits of a Docker Host VM based pool. VIC consumes resources only when containers are running, with no need for pre-allocation. Also, using Docker together with vSphere Integrated Containers lets you scale your Grid up and down from your local command line.

Because of these advantages, more and more enterprises are turning to VIC to run Selenium Grid. Let’s see how it works.

The Selenium Grid architecture comprises two main components: hubs and nodes. Nodes are where you actually run the tests themselves, whereas the hub is responsible for scheduling those tests on the appropriate node (i.e., the VM with an OS-browser combo that was specified in a test).

Selenium Grid

When building this out, we need to first stand up a single hub, and then register nodes to that hub. Thanks to the declarative nature of Docker containers, the process to get started is quite simple.

First, download this docker-compose file from our tutorial directory on GitHub, put it into a directory and then change directories to it from the command line.

Second, use this simple docker-compose command to read the docker-compose.yml file that you just downloaded. The tool will automatically download the containers, build the network and initialize the software. Don’t forget to set the environment variable COMPOSE_TLS_VERSION, otherwise, you will get an error message.

Here’s an example:

Selenium Grid

Third, check that the Grid is running. If you check out the vSphere management console, you should see two new containers: “selenium_chrome_1-XXX” and “selenium_hub_1-XXX” (where XXX is some UUID).

Selenium Grid

Selenium Grid also provides a management console, which you can view from a browser at the following address:

Here’s an example:

Selenium Grid

And that’s it to get things running. You can now think about scaling the application using standard Docker commands as well:

Here’s an example:

Selenium Grid

If you check out the vSphere management console, you can now see the results of your command:

Selenium Grid

The Selenium Grid console also shows the results of scaling the application:

Selenium Grid

What About Scaling Down?

Scaling down is just as easy. Simply specify the number of nodes you want in your docker-compose command (or file):

Stopping and Removing

When you’re all done testing this test engine, you can easily stop the containers and destroy their images:

Once you’re up and running, you can get to configuring Selenium to suit your needs by integrating it into your continuous integration and continuous delivery pipeline.

Security

In a continuously iterating development model, security can’t be considered an after-thought; it has to be an integral part of the process. Project Harbor, an open source private registry from VMware, enables this by actively reviewing containers, images and templates for known vulnerabilities from the CVE project database.

To illustrate, in the docker-compose example above, we pulled the latest images from Docker Hub. These images are quite popular, as you can see:

Selenium Grid

But how secure are these images? Let’s push them to our local Harbor registry and check the vulnerability scanning results.

When we check out of a repository without any tags given, we’ll always get :latest, but in this case, we want to check against a specific version, so we’ll pull that from Docker Hub.

To find out which version is the latest, you can visit the Docker Hub repo page for the given container image. For Selenium, the address would be:

https://hub.docker.com/r/selenium/hub/tags

Selenium Grid

Here we can see that besides the latest version, there is version 3.8.1 at the time of this writing.

Before we start to push images to Harbor, let’s first create a Docker Container Host(DCH) in VIC which will be used to push images. Alternatively, you can use your dev laptop or a linux VM to push images to Harbor

Now that our DCH is created, let’s authenticate with Harbor.

Now we are ready to push images to Harbor with the following CLI commands:

If we check the UI of our Harbor Container Registry, we can see that it has already identified some vulnerabilities for us.

Selenium Grid

Thankfully, none of them are categorized as ‘severe’ (there are 8 ‘medium’ and 16 ‘low’ for selenium/hub:3.8.1).

Selenium Grid

Harbor also shows the CVE entries so that you can decide if you need to build clean images on your own.

Selenium Grid

The Selenium community is working on using images based on Alpine Linux, but that work hasn’t been released officially yet.

Back to Selenium Hub itself—from this point, there are a lot of possibilities for setting up your Grid and integrating it with various CI/CD systems, or scripting the browser behavior with Python, JavaScript, Ruby, etc. There are also Selenium Docker images available with integrated video recording or extensions like Zalenium. The sky’s the limit.

So there you have it—VIC makes it simple to deploy and secure Docker containers in the data center for development and testing on the fly, all backed by the power and control of vSphere.

For more tutorials on using products like vSphere Integrated Containers, stay tuned to the Cloud-Native Apps Blog and follow us on Twitter (@cloudnativeapps).