Skip to content

Commit

Permalink
chore: add build gh action
Browse files Browse the repository at this point in the history
  • Loading branch information
notaphplover committed Oct 14, 2024
1 parent 4fda05d commit c17e30b
Show file tree
Hide file tree
Showing 2 changed files with 137 additions and 0 deletions.
36 changes: 36 additions & 0 deletions .github/actions/setup/action.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
name: Setup action
description: Reusable action to setup node and install packages

runs:
using: "composite"
steps:

- name: Install Node.js
uses: actions/setup-node@v4
with:
node-version: 20

- uses: pnpm/action-setup@v3
name: Install pnpm
id: pnpm-install
with:
version: 9
run_install: false

- name: Get pnpm store directory
id: pnpm-cache
run: |
echo "pnpm_cache_dir=$(pnpm store path)" >> $GITHUB_OUTPUT
shell: bash

- uses: actions/cache@v4
name: Setup pnpm cache
with:
path: ${{ steps.pnpm-cache.outputs.pnpm_cache_dir }}
key: pnpm-store-${{ hashFiles('**/package.json') }}
restore-keys: |
pnpm-store-
- name: Install dependencies
run: pnpm install
shell: bash
101 changes: 101 additions & 0 deletions .github/workflows/build.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
name: build
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
on:
pull_request:
types:
- closed
- opened
- reopened
- synchronize
jobs:
build:
name: Build
runs-on: ubuntu-latest
outputs:
affectedPackages: ${{ steps.get-affected-packages.outputs.packages }}
if: "!(github.event_name == 'pull_request' && github.event.action == 'closed' && github.event.pull_request.merged == false)"
steps:

- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0

- uses: ./.github/actions/setup

- name: Get affected packages
id: get-affected-packages
run: echo "packages=$(pnpm exec foundation-get-affected-project-chunks test:js origin/${{github.base_ref}} 4)" >> $GITHUB_OUTPUT

- name: Compile source files
run: pnpm run build

- name: Lint affected source files
run: pnpm run lint --filter=[origin/${{github.base_ref}}]

- name: Get current git commit hash
id: get-git-commit-hash
run: |
echo "gitCommitHash=$(git rev-parse HEAD)" >> $GITHUB_OUTPUT
- uses: actions/cache@v4
id: ts-build-cache
with:
path: |
./packages/container/libraries/*
./packages/foundation/tools/*
key: ts-build-${{ steps.get-git-commit-hash.outputs.gitCommitHash }}
restore-keys: |
ts-build-${{ steps.get-git-commit-hash.outputs.gitCommitHash }}
test-package:
name: Test package
needs: build
runs-on: ubuntu-latest
if: ${{ needs.build.outputs.affectedPackages != '[]' }}
strategy:
matrix:
packages: ${{fromJSON(needs.build.outputs.affectedPackages)}}
steps:

- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0

- uses: ./.github/actions/setup

- name: Get current git commit hash
id: get-git-commit-hash
run: |
echo "gitCommitHash=$(git rev-parse HEAD)" >> $GITHUB_OUTPUT
- uses: actions/cache@v4
id: ts-build-cache
with:
path: |
./packages/container/libraries/*
./packages/foundation/tools/*
key: ts-build-${{ steps.get-git-commit-hash.outputs.gitCommitHash }}
restore-keys: |
ts-build-${{ steps.get-git-commit-hash.outputs.gitCommitHash }}
- name: Build on cache miss
run: pnpm run build --filter ${{ join(matrix.packages, ' --filter ') }}
if: ${{ !steps.ts-build-cache.outputs.cache-hit }}

- name: Launch Unit Tests
run: pnpm run test:unit:js --filter ${{ join(matrix.packages, ' --filter ') }} --only

- name: Launch Integration Tests
run: pnpm run test:integration:js --filter ${{ join(matrix.packages, ' --filter ') }} --only

done:
name: Done
needs:
- test-package
runs-on: ubuntu-latest
steps:
- run: 'echo "Done!"'

0 comments on commit c17e30b

Please sign in to comment.