From 373c5bc8e11a54aea1103305e0b5f26665200f4b Mon Sep 17 00:00:00 2001 From: Bill Glesias Date: Tue, 17 Sep 2024 18:47:45 -0400 Subject: [PATCH] chore: add internal 18.17.1 chrome 128 and firefox 130 image and update factory browsers (#1210) * chore: add internal 18.17.1 chrome 128 and firefox 130 image. Additionally updates browsers in docker factory for end users. * update global-profile to point to correct reference for non arm browsers * handle update for git version when building the all included. The git version is not an argument we control AFAIK * chore: add internal 18.17.1 chrome 128 and firefox 130 image. Additionally updates browsers in docker factory for end users. * update global-profile to point to correct reference for non arm browsers * update comments and format --- .../node18.17.1-chrome128-ff130/Dockerfile | 77 +++++++++++++++++++ .../node18.17.1-chrome128-ff130/README.md | 20 +++++ .../node18.17.1-chrome128-ff130/build.sh | 5 ++ .../global-profile.sh | 11 +++ factory/.env | 6 +- 5 files changed, 116 insertions(+), 3 deletions(-) create mode 100644 browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/Dockerfile create mode 100644 browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/README.md create mode 100644 browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/build.sh create mode 100644 browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/global-profile.sh diff --git a/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/Dockerfile b/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/Dockerfile new file mode 100644 index 0000000000..538709b85c --- /dev/null +++ b/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/Dockerfile @@ -0,0 +1,77 @@ +# build this image with command +# docker build -t cypress/browsers-internal:node18.17.1-chrome128-ff130 --platform linux/amd64 . +# +FROM cypress/base-internal:18.17.1 + +USER root + +RUN node --version + +COPY ./global-profile.sh /tmp/global-profile.sh +RUN cat /tmp/global-profile.sh >> /etc/bash.bashrc && rm /tmp/global-profile.sh + +# Install dependencies +RUN apt-get update && \ + apt-get install -y \ + fonts-liberation \ + git \ + libcurl4 \ + libcurl3-gnutls \ + libcurl3-nss \ + xdg-utils \ + wget \ + curl \ + # chrome dependencies + libu2f-udev \ + # firefox dependencies + bzip2 \ + # add codecs needed for video playback in firefox + # https://github.com/cypress-io/cypress-docker-images/issues/150 + mplayer \ + \ + # clean up + && rm -rf /var/lib/apt/lists/* \ + && apt-get clean + +# install libappindicator3-1 - not included with Debian 11 +RUN wget --no-verbose /usr/src/libappindicator3-1_0.4.92-7_amd64.deb "http://ftp.us.debian.org/debian/pool/main/liba/libappindicator/libappindicator3-1_0.4.92-7_amd64.deb" && \ + dpkg -i /usr/src/libappindicator3-1_0.4.92-7_amd64.deb ; \ + apt-get install -f -y && \ + rm -f /usr/src/libappindicator3-1_0.4.92-7_amd64.deb + +# install Chrome browser +RUN node -p "process.arch === 'arm64' ? 'Not downloading Chrome since we are on arm64: https://crbug.com/677140' : process.exit(1)" || \ + (wget --no-verbose -O /usr/src/google-chrome-stable_current_amd64.deb "http://dl.google.com/linux/chrome/deb/pool/main/g/google-chrome-stable/google-chrome-stable_128.0.6613.137-1_amd64.deb" && \ + dpkg -i /usr/src/google-chrome-stable_current_amd64.deb ; \ + apt-get install -f -y && \ + rm -f /usr/src/google-chrome-stable_current_amd64.deb) + +# "fake" dbus address to prevent errors +# https://github.com/SeleniumHQ/docker-selenium/issues/87 +ENV DBUS_SESSION_BUS_ADDRESS=/dev/null + +# install Firefox browser +RUN node -p "process.arch === 'arm64' ? 'Not downloading Firefox since we are on arm64: https://bugzilla.mozilla.org/show_bug.cgi?id=1678342' : process.exit(1)" || \ + (wget --no-verbose -O /tmp/firefox.tar.bz2 https://download-installer.cdn.mozilla.net/pub/firefox/releases/130.0.1/linux-x86_64/en-US/firefox-130.0.1.tar.bz2 && \ + tar -C /opt -xjf /tmp/firefox.tar.bz2 && \ + rm /tmp/firefox.tar.bz2 && \ + ln -fs /opt/firefox/firefox /usr/bin/firefox) + +# versions of local tools +RUN echo " node version: $(node -v) \n" \ + "npm version: $(npm -v) \n" \ + "yarn version: $(yarn -v) \n" \ + "debian version: $(cat /etc/debian_version) \n" \ + "Chrome version: $(google-chrome --version) \n" \ + "Firefox version: $(firefox --version) \n" \ + "Edge version: n/a \n" \ + "git version: $(git --version) \n" \ + "whoami: $(whoami) \n" + +# a few environment variables to make NPM installs easier +# good colors for most applications +ENV TERM=xterm +# avoid million NPM install messages +ENV npm_config_loglevel=warn +# allow installing when the main user is root +ENV npm_config_unsafe_perm=true diff --git a/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/README.md b/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/README.md new file mode 100644 index 0000000000..f315a8c614 --- /dev/null +++ b/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/README.md @@ -0,0 +1,20 @@ +# cypress/browsers-internal:node18.17.1-chrome128-ff130 + +A complete image with all operating system dependencies for Cypress, and Chrome 128.0.6613.137-1, Firefox 130.0.1 browsers. + +NOTE: This image is intended for internal use with https://github.com/cypress-io/cypress. It contains a few differences from the factory, such as: + +#### Dependency Additions + +- curl +- build-essentials (to contain `make` and a few other dependencies) + +#### Env variables + +- Does not contain the `CACHE_FOLDER` and `FACTORY_DEFAULT_NODE_VERSION` env variables to keep unit tests non environment specific + +[Dockerfile](Dockerfile) + +**Note:** this image uses the `root` user. You might want to switch to non-root user like `node` when running this container for security + +**Note:** Currently, the linux/arm64 build of this image does not contain any browsers except Electron. See https://github.com/cypress-io/cypress-docker-images/blob/master/README.md#browsers for more information. diff --git a/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/build.sh b/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/build.sh new file mode 100644 index 0000000000..e2f4f0c1e5 --- /dev/null +++ b/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/build.sh @@ -0,0 +1,5 @@ +set e+x + +LOCAL_NAME=cypress/browsers-internal:node18.17.1-chrome128-ff130 +echo "Building $LOCAL_NAME" +docker build -t $LOCAL_NAME . diff --git a/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/global-profile.sh b/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/global-profile.sh new file mode 100644 index 0000000000..7a76a3d651 --- /dev/null +++ b/browsers-internal/releases/node-18/node18.17.1-chrome128-ff130/global-profile.sh @@ -0,0 +1,11 @@ +if [[ "$(uname -a)" = *"arm"* || "$(uname -a)" = *"aarch64"* ]]; then + printf "\e[31m" # red + echo "Warning: You are using the beta Arm build of a cypress/browsers or cypress/included image." + echo + echo "On Arm, non-Electron browsers are not available, because browser vendors are not yet building for Linux arm64." + echo "You must use the built-in Electron browser (--browser electron) to run Cypress or find and install unofficial Arm binary builds." + echo + echo "More details and links to upstream issues for Chrome, Firefox, and Edge can be found at Cypress's issue tracker:" + echo " https://github.com/cypress-io/cypress-docker-images/blob/master/README.md#browsers" + printf "\e[0m" # reset +fi \ No newline at end of file diff --git a/factory/.env b/factory/.env index 800811f812..2ee8d66e91 100644 --- a/factory/.env +++ b/factory/.env @@ -21,16 +21,16 @@ NODE_VERSION="${FACTORY_DEFAULT_NODE_VERSION}" FACTORY_VERSION='4.2.0' # Chrome versions: https://www.ubuntuupdates.org/package/google_chrome/stable/main/base/google-chrome-stable -CHROME_VERSION='128.0.6613.119-1' +CHROME_VERSION='128.0.6613.137-1' # Cypress versions: https://www.npmjs.com/package/cypress CYPRESS_VERSION='13.14.2' # Edge versions: https://packages.microsoft.com/repos/edge/pool/main/m/microsoft-edge-stable/ -EDGE_VERSION='128.0.2739.63-1' +EDGE_VERSION='128.0.2739.67-1' # Firefox versions: https://download-installer.cdn.mozilla.net/pub/firefox/releases/ -FIREFOX_VERSION='130.0' +FIREFOX_VERSION='130.0.1' # Yarn versions: https://www.npmjs.com/package/yarn and # https://classic.yarnpkg.com/latest-version