2020-08-08 02:22:05 +03:00
|
|
|
#!/bin/bash
|
|
|
|
set -e
|
|
|
|
set +x
|
|
|
|
|
|
|
|
trap "cd $(pwd -P)" EXIT
|
|
|
|
cd "$(dirname $0)"
|
|
|
|
|
2020-09-04 12:18:36 +03:00
|
|
|
rm -rf output
|
2020-08-08 02:22:05 +03:00
|
|
|
mkdir -p output
|
|
|
|
cd output
|
|
|
|
|
2020-09-04 10:43:12 +03:00
|
|
|
BUILD_NUMBER=$(head -1 ../BUILD_NUMBER)
|
devops: encode build number together with Chromium revision (#3769)
This is an alternative approach to #3698 that was setting up a custom
mapping between chromium revisions and our mirrored builds. For example, we were
taking chromium `792639` and re-packaging it to our CDN as Chromium 1000.
One big downside of this opaque mapping was inability to quickly
understand which Chromium is mirrored to CDN.
To solve this, this patch starts treating browser revision as a fractional number,
with and integer part being a chromium revision, and fractional
part being our build number. For example, we can generate builds `792639`, `792639.1`,
`792639.2` etc, all of which will pick Chromium `792639` and re-package it to our CDN.
In the Playwright code itself, there are a handful of places that treat
browser revision as integer, exclusively to compare revision with some particular
revision numbers. This code would still work as-is, but I changed these places
to use `parseFloat` instead of `parseInt` for correctness.
2020-09-04 13:12:30 +03:00
|
|
|
# Support BUILD_NUMBER in the form of <CRREV>.<GENERATION>
|
|
|
|
# This will allow us to bump generation to produce new builds.
|
2020-09-04 13:16:46 +03:00
|
|
|
CRREV="${BUILD_NUMBER%.*}"
|
2020-09-04 12:18:36 +03:00
|
|
|
|
|
|
|
CHROMIUM_URL=""
|
|
|
|
CHROMIUM_FOLDER_NAME=""
|
|
|
|
CHROMIUM_FILES_TO_REMOVE=()
|
|
|
|
|
|
|
|
FFMPEG_VERSION="4.3.1"
|
|
|
|
FFMPEG_URL=""
|
|
|
|
FFMPEG_BIN_PATH=""
|
2020-08-11 01:00:37 +03:00
|
|
|
|
2020-08-08 02:22:05 +03:00
|
|
|
if [[ $1 == "--win32" ]]; then
|
devops: encode build number together with Chromium revision (#3769)
This is an alternative approach to #3698 that was setting up a custom
mapping between chromium revisions and our mirrored builds. For example, we were
taking chromium `792639` and re-packaging it to our CDN as Chromium 1000.
One big downside of this opaque mapping was inability to quickly
understand which Chromium is mirrored to CDN.
To solve this, this patch starts treating browser revision as a fractional number,
with and integer part being a chromium revision, and fractional
part being our build number. For example, we can generate builds `792639`, `792639.1`,
`792639.2` etc, all of which will pick Chromium `792639` and re-package it to our CDN.
In the Playwright code itself, there are a handful of places that treat
browser revision as integer, exclusively to compare revision with some particular
revision numbers. This code would still work as-is, but I changed these places
to use `parseFloat` instead of `parseInt` for correctness.
2020-09-04 13:12:30 +03:00
|
|
|
CHROMIUM_URL="https://storage.googleapis.com/chromium-browser-snapshots/Win/${CRREV}/chrome-win.zip"
|
2020-09-04 12:18:36 +03:00
|
|
|
CHROMIUM_FOLDER_NAME="chrome-win"
|
|
|
|
CHROMIUM_FILES_TO_REMOVE+=("chrome-win/interactive_ui_tests.exe")
|
|
|
|
FFMPEG_URL="https://playwright2.blob.core.windows.net/builds/ffmpeg/${FFMPEG_VERSION}/ffmpeg-win32.zip"
|
|
|
|
FFMPEG_BIN_PATH="ffmpeg.exe"
|
2020-08-08 02:22:05 +03:00
|
|
|
elif [[ $1 == "--win64" ]]; then
|
devops: encode build number together with Chromium revision (#3769)
This is an alternative approach to #3698 that was setting up a custom
mapping between chromium revisions and our mirrored builds. For example, we were
taking chromium `792639` and re-packaging it to our CDN as Chromium 1000.
One big downside of this opaque mapping was inability to quickly
understand which Chromium is mirrored to CDN.
To solve this, this patch starts treating browser revision as a fractional number,
with and integer part being a chromium revision, and fractional
part being our build number. For example, we can generate builds `792639`, `792639.1`,
`792639.2` etc, all of which will pick Chromium `792639` and re-package it to our CDN.
In the Playwright code itself, there are a handful of places that treat
browser revision as integer, exclusively to compare revision with some particular
revision numbers. This code would still work as-is, but I changed these places
to use `parseFloat` instead of `parseInt` for correctness.
2020-09-04 13:12:30 +03:00
|
|
|
CHROMIUM_URL="https://storage.googleapis.com/chromium-browser-snapshots/Win_x64/${CRREV}/chrome-win.zip"
|
2020-09-04 12:18:36 +03:00
|
|
|
CHROMIUM_FOLDER_NAME="chrome-win"
|
|
|
|
CHROMIUM_FILES_TO_REMOVE+=("chrome-win/interactive_ui_tests.exe")
|
|
|
|
FFMPEG_URL="https://playwright2.blob.core.windows.net/builds/ffmpeg/${FFMPEG_VERSION}/ffmpeg-win64.zip"
|
|
|
|
FFMPEG_BIN_PATH="ffmpeg.exe"
|
2020-08-08 02:22:05 +03:00
|
|
|
elif [[ $1 == "--mac" ]]; then
|
devops: encode build number together with Chromium revision (#3769)
This is an alternative approach to #3698 that was setting up a custom
mapping between chromium revisions and our mirrored builds. For example, we were
taking chromium `792639` and re-packaging it to our CDN as Chromium 1000.
One big downside of this opaque mapping was inability to quickly
understand which Chromium is mirrored to CDN.
To solve this, this patch starts treating browser revision as a fractional number,
with and integer part being a chromium revision, and fractional
part being our build number. For example, we can generate builds `792639`, `792639.1`,
`792639.2` etc, all of which will pick Chromium `792639` and re-package it to our CDN.
In the Playwright code itself, there are a handful of places that treat
browser revision as integer, exclusively to compare revision with some particular
revision numbers. This code would still work as-is, but I changed these places
to use `parseFloat` instead of `parseInt` for correctness.
2020-09-04 13:12:30 +03:00
|
|
|
CHROMIUM_URL="https://storage.googleapis.com/chromium-browser-snapshots/Mac/${CRREV}/chrome-mac.zip"
|
2020-09-04 12:18:36 +03:00
|
|
|
CHROMIUM_FOLDER_NAME="chrome-mac"
|
|
|
|
FFMPEG_URL="https://playwright2.blob.core.windows.net/builds/ffmpeg/${FFMPEG_VERSION}/ffmpeg-mac.zip"
|
|
|
|
FFMPEG_BIN_PATH="ffmpeg"
|
2020-08-08 02:22:05 +03:00
|
|
|
elif [[ $1 == "--linux" ]]; then
|
devops: encode build number together with Chromium revision (#3769)
This is an alternative approach to #3698 that was setting up a custom
mapping between chromium revisions and our mirrored builds. For example, we were
taking chromium `792639` and re-packaging it to our CDN as Chromium 1000.
One big downside of this opaque mapping was inability to quickly
understand which Chromium is mirrored to CDN.
To solve this, this patch starts treating browser revision as a fractional number,
with and integer part being a chromium revision, and fractional
part being our build number. For example, we can generate builds `792639`, `792639.1`,
`792639.2` etc, all of which will pick Chromium `792639` and re-package it to our CDN.
In the Playwright code itself, there are a handful of places that treat
browser revision as integer, exclusively to compare revision with some particular
revision numbers. This code would still work as-is, but I changed these places
to use `parseFloat` instead of `parseInt` for correctness.
2020-09-04 13:12:30 +03:00
|
|
|
CHROMIUM_URL="https://storage.googleapis.com/chromium-browser-snapshots/Linux_x64/${CRREV}/chrome-linux.zip"
|
2020-09-04 12:18:36 +03:00
|
|
|
CHROMIUM_FOLDER_NAME="chrome-linux"
|
|
|
|
# Even though we could bundle ffmpeg on Linux (2.5MB zipped), we
|
|
|
|
# prefer rely on system-installed ffmpeg instead.
|
2020-08-08 02:22:05 +03:00
|
|
|
else
|
|
|
|
echo "ERROR: unknown platform to build: $1"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-09-04 12:18:36 +03:00
|
|
|
curl --output chromium-upstream.zip "${CHROMIUM_URL}"
|
|
|
|
unzip chromium-upstream.zip
|
|
|
|
for file in ${CHROMIUM_FILES_TO_REMOVE[@]}; do
|
2020-08-11 01:00:37 +03:00
|
|
|
rm -f "${file}"
|
|
|
|
done
|
2020-08-08 02:22:05 +03:00
|
|
|
|
2020-09-04 12:18:36 +03:00
|
|
|
if [[ -n "${FFMPEG_URL}" ]]; then
|
|
|
|
curl --output ffmpeg-upstream.zip "${FFMPEG_URL}"
|
|
|
|
unzip ffmpeg-upstream.zip
|
|
|
|
cp "$FFMPEG_BIN_PATH" "${CHROMIUM_FOLDER_NAME}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
zip --symlinks -r build.zip "${CHROMIUM_FOLDER_NAME}"
|