Skip to content

Commit

Permalink
Test the release-build process; install the correct Node version
Browse files Browse the repository at this point in the history
- Add a GitHub action to test the release-build process and make sure we
  don't introduce any reproducibility issues in a new change.

- Show what's different in console output if the release build fails for
  reproducibility reasons (to make troubleshooting easier in GHA).

- Make install-deps.sh install the correct Node version, if the one
  that's installed is too old (as it is on the GitHub runners).
  • Loading branch information
josh-berry committed Sep 2, 2024
1 parent d8faefb commit 5ab94fa
Show file tree
Hide file tree
Showing 4 changed files with 38 additions and 8 deletions.
4 changes: 0 additions & 4 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,6 @@ jobs:
- uses: actions/checkout@v1
- name: Install Dependencies
run: sh ./install-deps.sh
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3
with:
node-version: 20.x
- name: Install Node Modules
run: make node_modules
- name: Check Types
Expand Down
27 changes: 27 additions & 0 deletions .github/workflows/test-release-build.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
name: test-release-build

on:
push:
branches:
- master
pull_request:

jobs:
build:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v1
- name: Install Dependencies
run: sh ./install-deps.sh
- name: Make a Temporary Version Number (if needed)
run: |
if [ -z "$(git tag --points-at=HEAD)" ]; then
node -e "x=`cat assets/manifest.json`; x.version='9999.99.9999'; console.log(JSON.stringify(x))" >assets/manifest.json.new
mv assets/manifest.json.new assets/manifest.json
git config --global user.name "GitHub Actions"
git config --global user.email "[email protected]"
git commit -m 'Make a temporary version number' assets/manifest.json
fi
- name: Try Building Release Artifacts
run: make rel
13 changes: 10 additions & 3 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,13 @@ rel:
rel-inner:
$(MAKE) pkg-webext pkg-source
$(MAKE) -C $(RELEASE_DIR)/$(SRCPKG_DIR) release-tag pkg-webext pkg-source
[ -z "$$(diff -Nru dist $(RELEASE_DIR)/$(SRCPKG_DIR)/dist)" ]
@if [ ! -z "$$(diff -Nru dist $(RELEASE_DIR)/$(SRCPKG_DIR)/dist)" ]; then \
diff -Nru dist $(RELEASE_DIR)/$(SRCPKG_DIR)/dist; \
echo "!!!" >&2; \
echo "!!! Build did not reproduce correctly; check diff output above" >&2; \
echo "!!!" >&2; \
exit 1; \
fi
rm -rf $(RELEASE_DIR)/$(SRCPKG_DIR)
@echo ""
@echo "Ready for release $(VERSION)!"
Expand Down Expand Up @@ -198,8 +204,9 @@ site:
## Cleanup

distclean: clean
rm -rf node_modules $(RELEASE_DIR)/$(SRCPKG_DIR) $(SRC_PKG) $(DIST_PKG)
rm -rf docs/vendor
rm -rf node_modules docs/vendor \
$(RELEASE_DIR)/$(SRCPKG_DIR) $(SRC_PKG) $(DIST_PKG) \
releases/*-dirty* releases/*-dev*
.PHONY: distclean

clean:
Expand Down
2 changes: 1 addition & 1 deletion install-deps.sh
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ deps_apt() {
# Build tools
sudo apt-get install -y make git diffutils patch rsync zip ca-certificates curl gnupg

if ! type node; then
if ! type node || [ "$(node --version |cut -c1-4)" != v20. ]; then
sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg

Expand Down

0 comments on commit 5ab94fa

Please sign in to comment.