test a doc + source change in the same PR but over 2 commits #269
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
name: CI (repo level) | |
on: | |
push: | |
branches: | |
- "main" | |
- "release-*" | |
pull_request: | |
branches: | |
- "main" | |
- "release-*" | |
workflow_dispatch: | |
workflow_call: | |
concurrency: | |
group: ci-repo-${{ github.event_name }}-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
unit-test-lookup: | |
runs-on: ubuntu-latest | |
outputs: | |
builder-image: ${{ steps.grepBuilder.outputs.builder }} | |
should-test: ${{ steps.check-changes.outputs.should-test }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Lookup builder image from the project's Dockerfile | |
id: grepBuilder | |
run: | | |
builder=$(grep 'as builder' Dockerfile | sed -e 's/^FROM \(.*\) as builder$/\1/') | |
echo "builder=$builder" >> "$GITHUB_OUTPUT" | |
- name: Did docs and hacks change? | |
id: docs-and-hacks | |
uses: tj-actions/changed-files@v44 | |
with: | |
files: | | |
docs/** | |
hack/** | |
*.md | |
- name: Check if only docs and hacks changes have been made in a PR | |
id: check-changes | |
env: | |
IS_PR: ${{ !!github.event.pull_request }} | |
ONLY_DOCS: ${{ steps.docs-and-hacks.outputs.only_modified }} | |
run: | | |
SHOULD_TEST=$( | |
if [[ $IS_PR == true ]] && [[ $ONLY_DOCS == true ]]; then | |
echo "false" | |
else | |
echo "true" | |
fi | |
) | |
echo "is-pr=$IS_PR" >> "$GITHUB_OUTPUT" | |
echo "changes_only_docs=${ONLY_DOCS:-false}" >> "$GITHUB_OUTPUT" | |
echo "should-test=$SHOULD_TEST" >> "$GITHUB_OUTPUT" | |
- name: Summarize findings | |
env: | |
ONLY_DOCS: ${{ steps.docs-and-hacks.outputs.only_modified }} | |
MODIFIED_FILES: ${{ steps.docs-and-hacks.outputs.all_modified_files }} | |
run: | | |
cat >> "$GITHUB_STEP_SUMMARY" <<EOF | |
## Build container | |
- CI will run on container: \`${{ steps.grepBuilder.outputs.builder }}\` | |
## Findings | |
- The action is PR triggered? \`${{ steps.check-changes.outputs.is-pr }}\` | |
- Changes are only to docs and hacks? \`${{ steps.check-changes.outputs.changes_only_docs }}\` | |
- Should the unit test run? \`${{ steps.check-changes.outputs.should-test }}\` | |
EOF | |
if [[ $ONLY_DOCS == true ]] && [[ -n "$MODIFIED_FILES" ]]; then | |
echo "## Modified docs and hacks files that do not impact the build" >> "$GITHUB_STEP_SUMMARY" | |
for file in ${MODIFIED_FILES}; do | |
echo " - \`$file\`" >> "$GITHUB_STEP_SUMMARY" | |
done | |
fi | |
unit-test: | |
runs-on: ubuntu-latest | |
needs: unit-test-lookup | |
if: ${{ needs.unit-test-lookup.outputs.should-test == 'true' }} | |
# Use the same container as the Dockerfile's "FROM * as builder" | |
container: ${{ needs.unit-test-lookup.outputs.builder-image }} | |
steps: | |
- uses: actions/checkout@v4 | |
# TODO: Setup a cache for npm so it could install faster | |
# follow actions/setup-node@v4 techniques | |
- name: Verify package-lock.json | |
run: ./scripts/verify_lock.mjs | |
- name: Install | |
run: | | |
npm version | |
npm clean-install --ignore-scripts | |
- name: Lint sources | |
run: npm run lint | |
- name: Build | |
run: npm run build | |
- name: Test | |
run: npm run test -- --coverage --watchAll=false | |
- name: Upload to codecov (client) | |
# if: ${{ github.event.pull_request }} | |
uses: codecov/codecov-action@v4 | |
with: | |
flags: client | |
directory: ./client/coverage | |
- name: Upload to codecov (server) | |
# if: ${{ github.event.pull_request }} | |
uses: codecov/codecov-action@v4 | |
with: | |
flags: server | |
directory: ./server/coverage |