Skip to content

CI - Github Actions

CI - Github Actions #3

Workflow file for this run

name: Storybook Lint, Build and Deploy
on:
pull_request:
paths:
- 'storybook/**'
- '!examples/**'
- '!packages/react/**'
- '!packages/sdk/**'
- '!packages/ui/**'
jobs:
storybook:
runs-on: ubuntu-22.04
defaults:
run:
working-directory: storybook/
steps:
- name: Checkout repository
uses: actions/checkout@v4 # TODO: SHA commit instead of version
- name: Setup Node version
uses: actions/setup-node@v4 # TODO: SHA commit instead of version
with:
node-version-file: '.nvmrc' # Root of the repository.
# TODO: NPM login instead of auth token?
- name: Authenticate with private NPM package
run: echo "//registry.npmjs.org/:_authToken=${{ secrets.NPM_TOKEN }}" > ~/.npmrc
- name: Install dependencies
run: npm ci --ignore-scripts
- name: Lint check
run: npm run lint
- name: Build
run: npm run build-storybook
deploy:
needs: storybook
# Grant GITHUB_TOKEN the permissions required to make a Pages deployment
permissions:
pages: write
id-token: write
# Deploy to the github-pages environment.
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-22.04
defaults:
run:
working-directory: storybook/
steps:
- name: Archive artifact
shell: sh
run: |
echo ::group::Archive artifact
tar \
--dereference --hard-dereference \
--directory "storybook-static/" \
-cvf "$RUNNER_TEMP/artifact.tar" \
--exclude=.git \
--exclude=.github \
.
echo ::endgroup::
- name: Upload artifact
id: upload-artifact
uses: actions/upload-artifact@v4 # TODO: SHA commit instead of version
with:
name: storybook
path: ${{ runner.temp }}/artifact.tar
retention-days: 90
if-no-files-found: error
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4 # TODO: SHA commit instead of version
with:
artifact_name: storybook