-
Notifications
You must be signed in to change notification settings - Fork 212
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ci: Update restore-node dirty check to ignore untracked endo-sha.txt (#…
…9709) Fixes #9708 ## Description Tolerates removal of endo-sha.txt by e.g. `git reset --hard HEAD` contributing to a restored cache state. Also includes minor cleanup of GitHub actions files. ### Security Considerations No relevant change. ### Scaling Considerations n/a ### Documentation Considerations n/a ### Testing Considerations It's difficult to test these kinds of changes, but the proof of the pudding is in the taste. ### Upgrade Considerations n/a
- Loading branch information
Showing
2 changed files
with
39 additions
and
23 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -31,17 +31,19 @@ runs: | |
using: composite | ||
steps: | ||
- name: set default environment variables | ||
run: echo ESM_DISABLE_CACHE=true >> $GITHUB_ENV | ||
shell: bash | ||
run: echo ESM_DISABLE_CACHE=true >> $GITHUB_ENV | ||
|
||
- uses: actions/checkout@v4 | ||
with: | ||
clean: false | ||
submodules: 'true' | ||
persist-credentials: false | ||
path: ${{ inputs.path }} | ||
|
||
# Select a branch on Endo to test against by adding text to the body of the | ||
# pull request. For example: #endo-branch: some-pr-branch | ||
# The default is '*NOPE*' to indicate not to check out Endo, just use | ||
# The default is 'NOPE' to indicate not to check out Endo, just use | ||
# the published NPM packages. | ||
- name: Get the appropriate Endo branch | ||
id: endo-branch | ||
|
@@ -62,22 +64,25 @@ runs: | |
branch = result[1]; | ||
} | ||
} | ||
console.log(branch); | ||
console.log('Endo override branch: ' + branch); | ||
return branch; | ||
- name: merge endo integration branch | ||
id: endo-integration-merge | ||
if: steps.endo-branch.outputs.result != 'NOPE' | ||
working-directory: ${{ inputs.path }} | ||
shell: bash | ||
run: |- | ||
set -e | ||
git ls-remote --exit-code --heads origin "refs/heads/integration-endo-${{ steps.endo-branch.outputs.result }}" || exit 0 | ||
git fetch --unshallow origin integration-endo-${{ steps.endo-branch.outputs.result }} | ||
git config user.name github-actions | ||
git config user.email [email protected] | ||
git merge --commit --no-edit origin/integration-endo-${{ steps.endo-branch.outputs.result }} | ||
shell: bash | ||
working-directory: ${{ inputs.path }} | ||
if: steps.endo-branch.outputs.result != 'NOPE' | ||
- name: check out Endo if necessary | ||
id: endo-checkout | ||
if: steps.endo-branch.outputs.result != 'NOPE' | ||
uses: actions/checkout@v4 | ||
with: | ||
repository: agoric/endo | ||
|
@@ -86,9 +91,10 @@ runs: | |
clean: 'false' | ||
submodules: 'true' | ||
persist-credentials: false | ||
if: steps.endo-branch.outputs.result != 'NOPE' | ||
|
||
- name: Move Endo checkout outside the working directory | ||
id: endo-sha | ||
shell: bash | ||
run: |- | ||
set -ex | ||
if test -e ./replacement-endo; then | ||
|
@@ -100,32 +106,38 @@ runs: | |
echo "sha=$sha" >> $GITHUB_OUTPUT | ||
cd "${{ inputs.path }}" | ||
echo "$sha" > endo-sha.txt | ||
git add endo-sha.txt | ||
shell: bash | ||
- name: Reconfigure git to use HTTP authentication | ||
run: git config --global url."https://github.com/".insteadOf ssh://[email protected]/ | ||
shell: bash | ||
run: git config --global url."https://github.com/".insteadOf ssh://[email protected]/ | ||
|
||
- uses: actions/setup-node@v4 | ||
with: | ||
node-version: ${{ inputs.node-version }} | ||
cache: yarn | ||
cache-dependency-path: | | ||
${{ inputs.path }}/yarn.lock | ||
${{ inputs.path }}/endo-sha.txt | ||
- uses: kenchan0130/actions-system-info@master | ||
id: system-info | ||
|
||
- run: corepack enable | ||
shell: bash | ||
|
||
- name: restore built files | ||
id: built | ||
uses: actions/cache@v4 | ||
with: | ||
path: ${{ inputs.path }} | ||
key: ${{ runner.os }}-${{ runner.arch }}-${{ steps.system-info.outputs.release }}-node-${{ inputs.node-version }}-built-${{ inputs.xsnap-random-init }}-${{ github.sha }}-${{ steps.endo-sha.outputs.sha }} | ||
|
||
# This and the git diff below are to detect if `yarn install` results in a | ||
# change to the lock file. | ||
- name: yarn install | ||
if: steps.built.outputs.cache-hit != 'true' | ||
working-directory: ${{ inputs.path }} | ||
shell: bash | ||
run: |- | ||
set -ex | ||
if test "${{ inputs.xsnap-random-init }}" != 0 && test -d /etc/apt; then | ||
|
@@ -156,28 +168,31 @@ runs: | |
git add package.json yarn.lock | ||
${{ inputs.keep-endo }} || rm -rf ~/endo | ||
fi | ||
shell: bash | ||
if: steps.built.outputs.cache-hit != 'true' | ||
- name: yarn build | ||
if: steps.built.outputs.cache-hit != 'true' | ||
working-directory: ${{ inputs.path }} | ||
env: | ||
XSNAP_RANDOM_INIT: ${{ inputs.xsnap-random-init }} | ||
shell: bash | ||
run: |- | ||
set -ex | ||
yarn build | ||
mkdir -p node_modules/.cache/agoric | ||
date > node_modules/.cache/agoric/yarn-built | ||
shell: bash | ||
if: steps.built.outputs.cache-hit != 'true' | ||
env: | ||
XSNAP_RANDOM_INIT: ${{ inputs.xsnap-random-init }} | ||
- name: git dirty check | ||
working-directory: ${{ inputs.path }} | ||
shell: bash | ||
run: |- | ||
set -x | ||
# In case of Endo override, ignore matching index and worktree. | ||
# (First column is non-space, second column is space, followed by separator.) | ||
if [ -n "$(git status --porcelain | grep -Eve '^[^ ] '; true)" ]; then | ||
# Fail if `git status` reports anything other than the following: | ||
# * an untracked endo-sha.txt from above | ||
# * work tree files that have been staged without further changes | ||
# (e.g., package.json or yarn.lock) as indicated by the Y position | ||
# in "XY PATH" being a space | ||
if [ -n "$(git status --porcelain | grep -vE '^[?][?] endo-sha.txt$|^. '; true)" ]; then | ||
git status | ||
echo "Unexpected dirty git status" 1>&2 | ||
exit 1 | ||
fi | ||
shell: bash |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -61,7 +61,7 @@ jobs: | |
keep-endo: 'true' | ||
|
||
# Select a branch on dapp to test against by adding text to the body of the | ||
# pull request. For example: #dapp-encouragement-branch: zoe-release-0.7.0 | ||
# pull request. For example: #getting-started-branch: zoe-release-0.7.0 | ||
# The default is 'main' | ||
- name: Get the appropriate dapp branch | ||
id: get-branch | ||
|
@@ -78,14 +78,15 @@ jobs: | |
branch = result[1]; | ||
} | ||
} | ||
console.log(branch); | ||
console.log('getting-started dapp branch: ' + branch); | ||
return branch; | ||
- name: Start local NPM registry | ||
if: ${{ startsWith(matrix.cli, 'registry') }} | ||
run: | | ||
set -xe | ||
git reset --hard HEAD | ||
git clean -f | ||
git config user.email "[email protected]" | ||
REGISTRY_PUBLISH_WORKSPACES="$HOME/endo" scripts/registry.sh bg-publish ${{ matrix.cli }} | ||
|
@@ -153,7 +154,7 @@ jobs: | |
branch = result[1]; | ||
} | ||
} | ||
console.log(branch); | ||
console.log('loadgen branch: ' + branch); | ||
return branch; | ||
- name: Check out loadgen | ||
|