Skip to content

Commit

Permalink
[build][doc]: build images with combination Grid and browser versions
Browse files Browse the repository at this point in the history
Signed-off-by: Viet Nguyen Duc <[email protected]>
  • Loading branch information
VietND96 committed Apr 21, 2024
1 parent 4c572af commit 541b14a
Show file tree
Hide file tree
Showing 8 changed files with 359 additions and 3 deletions.
5 changes: 3 additions & 2 deletions NodeChrome/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,10 @@ ARG TARGETARCH=amd64
RUN wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | gpg --dearmor | tee /etc/apt/trusted.gpg.d/google.gpg >/dev/null \
&& echo "deb http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google-chrome.list \
&& apt-get update -qqy \
&& if echo "${CHROME_VERSION}" | grep -qE "google-chrome-stable_[0-9]*"; \
&& if echo "${CHROME_VERSION}" | grep -qE "google-chrome-stable[_|=][0-9]*"; \
then \
wget -qO google-chrome.deb "https://dl.google.com/linux/chrome/deb/pool/main/g/google-chrome-stable/${CHROME_VERSION}_${TARGETARCH}.deb" \
CHROME_VERSION=$(echo "$CHROME_VERSION" | tr '=' '_') \
&& wget -qO google-chrome.deb "https://dl.google.com/linux/chrome/deb/pool/main/g/google-chrome-stable/${CHROME_VERSION}_${TARGETARCH}.deb" \
&& apt-get -qqy --no-install-recommends install --allow-downgrades ./google-chrome.deb \
&& rm -rf google-chrome.deb ; \
else \
Expand Down
11 changes: 10 additions & 1 deletion NodeEdge/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,19 @@ USER root
# e.g. microsoft-edge-beta=88.0.692.0-1
#============================================
ARG EDGE_VERSION="microsoft-edge-stable"
ARG TARGETARCH=amd64
RUN wget -q -O - https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor | tee /etc/apt/trusted.gpg.d/microsoft.gpg >/dev/null \
&& echo "deb https://packages.microsoft.com/repos/edge stable main" >> /etc/apt/sources.list.d/microsoft-edge.list \
&& apt-get update -qqy \
&& apt-get -qqy --no-install-recommends install ${EDGE_VERSION} \
&& if echo "${EDGE_VERSION}" | grep -qE "microsoft-edge-stable[_|=][0-9]*"; \
then \
EDGE_VERSION=$(echo "$EDGE_VERSION" | tr '=' '_') \
&& wget -qO microsoft-edge.deb "https://packages.microsoft.com/repos/edge/pool/main/m/microsoft-edge-stable/${EDGE_VERSION}_${TARGETARCH}.deb" \
&& apt-get -qqy --no-install-recommends install --allow-downgrades ./microsoft-edge.deb \
&& rm -rf microsoft-edge.deb ; \
else \
apt-get -qqy --no-install-recommends install ${EDGE_VERSION} ; \
fi \
&& rm /etc/apt/sources.list.d/microsoft-edge.list \
&& rm -rf /var/lib/apt/lists/* /var/cache/apt/*

Expand Down
29 changes: 29 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,8 @@ Talk to us at https://www.selenium.dev/support/
* [Stopping the Node/Standalone after N sessions have been executed](#stopping-the-nodestandalone-after-n-sessions-have-been-executed)
* [Automatic browser leftovers cleanup](#automatic-browser-leftovers-cleanup)
* [Building the images](#building-the-images)
* [Build the images with specific versions](#build-the-images-with-specific-versions)
* [Upgrade browser version in the images](#upgrade-browser-version-in-the-images)
* [Waiting for the Grid to be ready](#waiting-for-the-grid-to-be-ready)
* [Adding a HEALTHCHECK to the Grid](#adding-a-healthcheck-to-the-grid)
* [Using a bash script to wait for the Grid](#using-a-bash-script-to-wait-for-the-grid)
Expand Down Expand Up @@ -1027,6 +1029,33 @@ $ BUILD_ARGS="--build-arg SEL_USER=yourseluser --build-arg SEL_PASSWD=welcome" m
```
___

# Build the images with specific versions

Based on the latest Dockerfile (by cloning the repo and from the project directory root), you can build the images with a specific combination of Selenium Grid, and browser versions.

For example, you would like to build `node-chrome` and `standalone-chrome` images with the Grid based version `4.17.0`, Chrome browser versions `119`, `120`, `123` respectively.

```bash
$ ./tests/build-backward-compatible/bootstrap.sh 4.17.0 119,120,123 chrome
```

In generic, the script takes the following arguments:
- `$1` (mandatory): Selenium Grid version. Details are fetching from matrix [file](tests/build-backward-compatible/selenium-matrix.yml)
- `$2` (mandatory): Browser major version, multiple values separated by comma. Details are fetching from matrix [file](tests/build-backward-compatible/cdp-matrix.yml)
- `$3` (optional): browser name. If not provided, it will iterate over all the browsers (`chrome`, `edge`, `firefox`)
- `$4` (optional): Push image to registry. By default, it is `false`. If you want to push the image to the registry, set it to `true` (required Docker login to your namespace done before running the script).

To set your namespace for the images, you can set the environment variable `NAME` before running the script. For example:

```bash
$ export NAME=artifactory.yourcompany.com/selenium
$ ./tests/build-backward-compatible/bootstrap.sh 4.17.0 119,120,123 chrome
```

After running the script, you will see list images with a full tag to pin specific Grid and browser version following [Tagging Conventions](https://github.com/SeleniumHQ/docker-selenium/wiki/Tagging-Convention)

---

## Upgrade browser version in the images

Selenium server, browser and driver are pre-installed in the image. In case you would like to remain on the same Selenium version and just upgrade the browser and its driver to the latest. You can follow below steps
Expand Down
6 changes: 6 additions & 0 deletions tag_and_push_browser_images.sh
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,8 @@ chrome)
do
docker tag ${NAMESPACE}/node-chrome:${TAG_VERSION} ${NAMESPACE}/node-chrome:${chrome_tag}
docker tag ${NAMESPACE}/standalone-chrome:${TAG_VERSION} ${NAMESPACE}/standalone-chrome:${chrome_tag}
echo "Tagged ${NAMESPACE}/node-chrome:${chrome_tag}"
echo "Tagged ${NAMESPACE}/standalone-chrome:${chrome_tag}"
if [ "${PUSH_IMAGE}" = true ]; then
docker push ${NAMESPACE}/node-chrome:${chrome_tag}
docker push ${NAMESPACE}/standalone-chrome:${chrome_tag}
Expand Down Expand Up @@ -101,6 +103,8 @@ edge)
do
docker tag ${NAMESPACE}/node-edge:${TAG_VERSION} ${NAMESPACE}/node-edge:${edge_tag}
docker tag ${NAMESPACE}/standalone-edge:${TAG_VERSION} ${NAMESPACE}/standalone-edge:${edge_tag}
echo "Tagged ${NAMESPACE}/node-edge:${edge_tag}"
echo "Tagged ${NAMESPACE}/standalone-edge:${edge_tag}"
if [ "${PUSH_IMAGE}" = true ]; then
docker push ${NAMESPACE}/node-edge:${edge_tag}
docker push ${NAMESPACE}/standalone-edge:${edge_tag}
Expand Down Expand Up @@ -144,6 +148,8 @@ firefox)
do
docker tag ${NAMESPACE}/node-firefox:${TAG_VERSION} ${NAMESPACE}/node-firefox:${firefox_tag}
docker tag ${NAMESPACE}/standalone-firefox:${TAG_VERSION} ${NAMESPACE}/standalone-firefox:${firefox_tag}
echo "Tagged ${NAMESPACE}/node-firefox:${firefox_tag}"
echo "Tagged ${NAMESPACE}/standalone-firefox:${firefox_tag}"
if [ "${PUSH_IMAGE}" = true ]; then
docker push ${NAMESPACE}/node-firefox:${firefox_tag}
docker push ${NAMESPACE}/standalone-firefox:${firefox_tag}
Expand Down
66 changes: 66 additions & 0 deletions tests/build-backward-compatible/bootstrap.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
#!/usr/bin/env bash
cd tests || true

if [ "${CI:-false}" = "false" ]; then
pip3 install virtualenv | grep -v 'Requirement already satisfied'
virtualenv docker-selenium-tests
source docker-selenium-tests/bin/activate
fi

python -m pip install pyyaml==6.0.1 \
| grep -v 'Requirement already satisfied'

cd ..

SELENIUM_VERSION=$1
CDP_VERSIONS=$2
BROWSER=${3:-"all"}
PUSH_IMAGE=${4:-"false"}

IFS=',' read -ra VERSION_LIST <<< "$CDP_VERSIONS"

for CDP_VERSION in "${VERSION_LIST[@]}"; do
python tests/build-backward-compatible/builder.py ${SELENIUM_VERSION} ${CDP_VERSION}
export $(cat .env | xargs)
if [ "${BROWSER}" = "all" ] || [ "${BROWSER}" = "firefox" ]; then
if [ -n "${FIREFOX_VERSION}" ]; then
BUILD_ARGS="--build-arg FIREFOX_VERSION=${FIREFOX_VERSION}"
BUILD_ARGS="${BUILD_ARGS}" make standalone_firefox
else
echo "Firefox version not found in matrix for input ${CDP_VERSION}"
exit 1
fi
fi
if [ "${BROWSER}" = "all" ] || [ "${BROWSER}" = "edge" ]; then
if [ -n "${EDGE_VERSION}" ]; then
BUILD_ARGS="--build-arg EDGE_VERSION=${EDGE_VERSION}"
BUILD_ARGS="${BUILD_ARGS}" make standalone_edge
else
echo "Edge version not found in matrix for input ${CDP_VERSION}"
exit 1
fi
fi
if [ "${BROWSER}" = "all" ] || [ "${BROWSER}" = "chrome" ]; then
if [ -n "${CHROME_VERSION}" ]; then
BUILD_ARGS="--build-arg CHROME_VERSION=${CHROME_VERSION}"
BUILD_ARGS="${BUILD_ARGS}" make standalone_chrome
else
echo "Chrome version not found in matrix for input ${CDP_VERSION}"
exit 1
fi
fi
if [ "${BROWSER}" = "all" ] || [ "${BROWSER}" = "firefox" ]; then
TAG_LOG_OUTPUT="$TAG_LOG_OUTPUT $(PUSH_IMAGE=${PUSH_IMAGE} make tag_and_push_firefox_images)"
fi
if [ "${BROWSER}" = "all" ] || [ "${BROWSER}" = "edge" ]; then
TAG_LOG_OUTPUT="$TAG_LOG_OUTPUT $(PUSH_IMAGE=${PUSH_IMAGE} make tag_and_push_edge_images)"
fi
if [ "${BROWSER}" = "all" ] || [ "${BROWSER}" = "chrome" ]; then
TAG_LOG_OUTPUT="$TAG_LOG_OUTPUT $(PUSH_IMAGE=${PUSH_IMAGE} make tag_and_push_chrome_images)"
fi
done

readarray -t LOG_LINES <<< "$TAG_LOG_OUTPUT"
for line in "${LOG_LINES[@]}"; do
echo "$line"
done
48 changes: 48 additions & 0 deletions tests/build-backward-compatible/builder.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
import yaml
import sys
import logging

logging.basicConfig(level=logging.INFO, format="%(asctime)s - %(name)s - %(levelname)s - %(message)s")
logger = logging.getLogger(__name__)

def load_template(yaml_file):
try:
with open(yaml_file, 'r') as file:
documents = yaml.safe_load(file)
return documents
except yaml.YAMLError as error:
logger.debug("Error in configuration file: ", error)

def recursive_merge(dict1, dict2):
for key in dict2:
if key in dict1 and isinstance(dict1[key], dict) and isinstance(dict2[key], dict):
recursive_merge(dict1[key], dict2[key])
else:
dict1[key] = dict2[key]

if __name__ == '__main__':
# Load matrix configuration
selenium_matrix = load_template('tests/build-backward-compatible/selenium-matrix.yml')
cdp_matrix = load_template('tests/build-backward-compatible/cdp-matrix.yml')
# Merge configurations into single matrix
recursive_merge(selenium_matrix, cdp_matrix)
matrix = selenium_matrix["matrix"]
# Get versions from arguments
selenium_version = sys.argv[1]
cdp_version = int(sys.argv[2])
# Create .env with component versions
BASE_RELEASE = matrix["selenium"][selenium_version]["BASE_RELEASE"]
BASE_VERSION = matrix["selenium"][selenium_version]["BASE_VERSION"]
VERSION = matrix["selenium"][selenium_version]["VERSION"]
BINDING_VERSION = matrix["selenium"][selenium_version]["BINDING_VERSION"]
FIREFOX_VERSION = matrix["CDP"][cdp_version]["FIREFOX_VERSION"]
EDGE_VERSION = matrix["CDP"][cdp_version]["EDGE_VERSION"]
CHROME_VERSION = matrix["CDP"][cdp_version]["CHROME_VERSION"]
with open('.env', 'w') as f:
f.write(f"BASE_RELEASE={BASE_RELEASE}\n")
f.write(f"BASE_VERSION={BASE_VERSION}\n")
f.write(f"VERSION={VERSION}\n")
f.write(f"BINDING_VERSION={BINDING_VERSION}\n")
f.write(f"FIREFOX_VERSION={FIREFOX_VERSION}\n")
f.write(f"EDGE_VERSION={EDGE_VERSION}\n")
f.write(f"CHROME_VERSION={CHROME_VERSION}")
58 changes: 58 additions & 0 deletions tests/build-backward-compatible/cdp-matrix.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
matrix:
# List of versions get from
# Edge: https://packages.microsoft.com/repos/edge/pool/main/m/microsoft-edge-stable
# Chrome: https://www.ubuntuupdates.org/package/google_chrome/stable/main/base/google-chrome-stable
# Firefox: https://download-installer.cdn.mozilla.net/pub/firefox/releases
CDP:
124:
EDGE_VERSION: 'microsoft-edge-stable=124.0.2478.51-1'
CHROME_VERSION: 'google-chrome-stable=124.0.6367.60-1'
FIREFOX_VERSION: '124.0.2'
123:
EDGE_VERSION: 'microsoft-edge-stable=123.0.2420.97-1'
CHROME_VERSION: 'google-chrome-stable=123.0.6312.122-1'
FIREFOX_VERSION: '123.0.1'
122:
EDGE_VERSION: 'microsoft-edge-stable=122.0.2365.92-1'
CHROME_VERSION: 'google-chrome-stable=122.0.6261.128-1'
FIREFOX_VERSION: '122.0.1'
121:
EDGE_VERSION: 'microsoft-edge-stable=121.0.2277.98-1'
CHROME_VERSION: 'google-chrome-stable=121.0.6167.184-1'
FIREFOX_VERSION: '121.0.1'
120:
EDGE_VERSION: 'microsoft-edge-stable=120.0.2210.91-1'
CHROME_VERSION: 'google-chrome-stable=120.0.6099.224-1'
FIREFOX_VERSION: '120.0.1'
119:
EDGE_VERSION: 'microsoft-edge-stable=119.0.2151.97-1'
CHROME_VERSION: 'google-chrome-stable=119.0.6045.199-1'
FIREFOX_VERSION: '119.0.1'
118:
EDGE_VERSION: 'microsoft-edge-stable=118.0.2088.76-1'
CHROME_VERSION: 'google-chrome-stable=118.0.5993.117-1'
FIREFOX_VERSION: '118.0.2'
117:
EDGE_VERSION: 'microsoft-edge-stable=117.0.2045.55-1'
CHROME_VERSION: 'google-chrome-stable=117.0.5938.149-1'
FIREFOX_VERSION: '117.0.1'
116:
EDGE_VERSION: 'microsoft-edge-stable=116.0.1938.81-1'
CHROME_VERSION: 'google-chrome-stable=116.0.5845.187-1'
FIREFOX_VERSION: '116.0.3'
115:
EDGE_VERSION: 'microsoft-edge-stable=115.0.1901.203-1'
CHROME_VERSION: 'google-chrome-stable=115.0.5790.170-1'
FIREFOX_VERSION: '115.0.3'
114:
EDGE_VERSION: 'microsoft-edge-stable=114.0.1823.82-1'
CHROME_VERSION: 'google-chrome-stable=114.0.5735.198-1'
FIREFOX_VERSION: '114.0.2'
113:
EDGE_VERSION: 'microsoft-edge-stable=113.0.1774.57-1'
CHROME_VERSION: 'google-chrome-stable=113.0.5672.126-1'
FIREFOX_VERSION: '113.0.2'
112:
EDGE_VERSION: 'microsoft-edge-stable=112.0.1722.64-1'
CHROME_VERSION: 'google-chrome-stable=112.0.5615.165-1'
FIREFOX_VERSION: '112.0.2'
Loading

0 comments on commit 541b14a

Please sign in to comment.