Skip to content

Hackathon: Refactor a large number of the legacy stories to the new inline format. #21517

Hackathon: Refactor a large number of the legacy stories to the new inline format.

Hackathon: Refactor a large number of the legacy stories to the new inline format. #21517

Workflow file for this run

name: Storybook
on:
push:
branches:
- develop
- main
# Only run if CSS/JS/MD-related files changed.
paths:
- '.github/workflows/storybook.yml'
- 'assets/**'
- 'stories/**'
- '!assets/**/__tests__/**/*.js'
- '!assets/**/test/*.js'
- '!assets/**/*.test.js'
- '.storybook/**'
- '!.storybook/storybook-data.js'
- '**.scss'
- '.nvmrc'
- '**/package.json'
- 'package-lock.json'
pull_request:
branches:
- develop
- main
- 'feature/**'
# Only run if CSS/JS/MD-related files changed.
paths:
- '.github/workflows/storybook.yml'
- 'assets/**'
- 'stories/**'
- '!assets/**/__tests__/**/*.js'
- '!assets/**/test/*.js'
- '!assets/**/*.test.js'
- '.storybook/**'
- '!.storybook/storybook-data.js'
- '**.scss'
- '.nvmrc'
- '**/package.json'
- 'package-lock.json'
types:
- opened
- closed
- reopened
- synchronize
- ready_for_review
concurrency:
group: storybook-${{ github.event_name }}-${{ github.ref }}
cancel-in-progress: true
jobs:
build-storybook:
name: Build Storybook
runs-on: ubuntu-latest
timeout-minutes: 20
if: false == ( ( github.event_name == 'pull_request' && ( github.event.action == 'closed' || github.event.pull_request.draft == true || contains( github.head_ref, 'dependabot/' ) ) ) || github.event.pull_request.head.repo.fork )
steps:
- uses: actions/checkout@v4
- name: Setup Node.js (.nvmrc)
uses: actions/setup-node@v4
with:
node-version-file: '.nvmrc'
cache: 'npm'
- name: npm install
run: |
npm ci
- name: Build Storybook
run: |
npm run build:storybook
- name: Upload artifacts
uses: actions/upload-artifact@v4
with:
name: storybook-files
path: dist
deploy-storybook:
name: Deploy Storybook
runs-on: ubuntu-latest
needs: build-storybook
steps:
- uses: actions/checkout@v4
with:
ref: gh-pages
token: ${{ secrets.GH_BOT_TOKEN }}
- name: Download artifacts
uses: actions/download-artifact@v4
with:
name: storybook-files
path: dist
- name: Set branch environment variables
id: branch-target
if: github.event_name != 'pull_request'
run: echo "dir=${GITHUB_REF##*/}" >> "$GITHUB_OUTPUT"
- name: Set PR environment variables
id: pr-target
if: github.event_name == 'pull_request'
env:
PULL_REQUEST_NUMBER: ${{ github.event.number }}
run: echo "dir=pull/${PULL_REQUEST_NUMBER}" >> "$GITHUB_OUTPUT"
- name: Commit updates
run: |
mkdir -p "storybook/${TARGET_DIR}"
rm -rf "storybook/${TARGET_DIR}"
mv dist "storybook/${TARGET_DIR}"
git add .
git status
git diff --staged --quiet && echo 'No changes to commit; exiting!' && exit 0
git pull --no-edit --quiet
git commit -m "Deploy storybook for ${TARGET_DIR}."
git push origin gh-pages
env:
TARGET_DIR: ${{ steps.branch-target.outputs.dir }}${{ steps.pr-target.outputs.dir }}
GIT_AUTHOR_EMAIL: google-site-kit-bot@google.com
GIT_AUTHOR_NAME: google-site-kit-bot
GIT_COMMITTER_EMAIL: google-site-kit-bot@google.com
GIT_COMMITTER_NAME: google-site-kit-bot
remove-storybook:
name: Remove Storybook
runs-on: ubuntu-latest
timeout-minutes: 20
if: ( github.event_name == 'pull_request' && github.event.action == 'closed' && contains( github.head_ref, 'dependabot/' ) == false ) && github.event.pull_request.head.repo.fork == false
steps:
- uses: actions/checkout@v4
with:
ref: gh-pages
token: ${{ secrets.GH_BOT_TOKEN }}
- name: Remove storybook
env:
PULL_REQUEST_NUMBER: ${{ github.event.number }}
GIT_AUTHOR_EMAIL: google-site-kit-bot@google.com
GIT_AUTHOR_NAME: google-site-kit-bot
GIT_COMMITTER_EMAIL: google-site-kit-bot@google.com
GIT_COMMITTER_NAME: google-site-kit-bot
run: |
git rm -rf "storybook/pull/${PULL_REQUEST_NUMBER}"
git status
git diff --staged --quiet && echo 'No changes to commit; exiting!' && exit 0
git pull --no-edit --quiet
git commit -m "Remove storybook for pull/${PULL_REQUEST_NUMBER}."
git push origin gh-pages
test-storybook:
name: Test Storybook
runs-on: ubuntu-latest
needs: build-storybook
timeout-minutes: 20
if: false == ( ( github.event_name == 'pull_request' && ( github.event.action == 'closed' || github.event.pull_request.draft == true || contains( github.head_ref, 'dependabot/' ) ) ) || github.event.pull_request.head.repo.fork )
steps:
- uses: actions/checkout@v4
- name: Download artifacts
uses: actions/download-artifact@v4
with:
name: storybook-files
path: dist
- name: Setup Node.js (.nvmrc)
uses: actions/setup-node@v4
with:
node-version-file: '.nvmrc'
cache: 'npm'
- name: npm install
run: |
npm ci
- name: Test Storybook
run: |
npm run test:storybook