This test suite is designed to quickly build and run End-to-End (E2E) Selenium tests on the UI of a website using containers. This approach allows quick setup and tear-down with minimal local installation. These tests are specifically written for the MyICPC application, but the framework is easily extensible to other applications. The tests are written in JUnit, and they use Selenium to scrape the browser output.
UI tests are notoriously brittle and dependent on local browser installation. This means that tests could fail for no reason other than that the tester's version of Firefox was different from the developer's. We attempt to solve this problem by separating the test from the user's local browser installation using headless browsers inside containers. The tester can then specify the version of the browser to run by changing the image for the browser container.
Additionally, UI testing takes a while, and testing across multiple browsers can be time-consuming. Selenium Grid is an amazing technology which allows running Selenium tests in parallel (speeding up the process), but it requires some setup. We integrate the provided Docker images for the Grid hub and nodes into our architecture to make submitting and running the tests in parallel with multiple browsers easy. You can boot a grid locally to run tests or submit tests to a remote grid - installing the grid and running tests are separated in the configuration.
- JUnit - Java testing framework. Runs the tests and supplies input.
- Selenium - Reactive testing framework. Spins up browser instances and collects output. Selenium Grid ensures that the tests can be run on multiple browsers. It consists of a Hub and a Node. The Node runs several browser instances which connect to the Hub.
- Maven - dependency manager. Packages the tests as a JAR and handles any test dependencies.
- Docker - containerization software. Sticks the JAR in a small Linux container that is independent of the surrounding environment (defined in the Dockerfile).
- Kubernetes - orchestration software. Spins up containers for all elements of the application (Postgre, Redis, the main myICPC application, the UI, etc.), and runs the tests.
Make sure you have Docker Desktop installed. Users running Windows Home may need to install Docker Toolbox and Docker Compose instead.
Install Docker Engine - Community and Docker Compose. Make sure to add sudo
to all commands below.
Kubernetes builds the Selenium Grid setup (the Hub and Node containers). Before you run any tests, you need to boot them:
# Run in the root directory of the project
kubectl apply -k .
Once booted, the Grid containers will stay up until you take them down, so you can run the tests as many times as you like. You might run them on a dedicated server and point the hub URL to it.
After that, build the tests with Docker Compose.
# Get the URL to supply to compose for the Grid
minikube service hub-service --url
# Build the tests with Docker
docker-compose up -d
The tests will be run by Maven's surefire plugin - just look for the success or failure message.
Citations:
- https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.18/#-strong-api-overview-strong-
- https://kubectl.docs.kubernetes.io/pages/app_management/apply.html
- https://medium.com/style-theory-engineering/infrastructure-as-code-kubernetes-a2f050389f26
- https://www.swtestacademy.com/parallel-distributed-testing-with-kubernetes-docker-and-selenium-grid/
- https://cloud.google.com/kubernetes-engine/docs/how-to/horizontal-pod-autoscaling
- https://www.baeldung.com/maven-junit-parallel-tests