mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-06 22:40:26 -05:00
146 lines
No EOL
5.6 KiB
YAML
146 lines
No EOL
5.6 KiB
YAML
name: Verdaccio Website CI
|
||
|
||
on:
|
||
workflow_dispatch:
|
||
pull_request:
|
||
types:
|
||
- opened
|
||
- synchronize
|
||
paths:
|
||
- 'website/**'
|
||
- 'package.json'
|
||
- './github/workflows/website.yml'
|
||
push:
|
||
branches:
|
||
- 'master'
|
||
paths:
|
||
- 'website/**'
|
||
- 'package.json'
|
||
- './github/workflows/website.yml'
|
||
|
||
jobs:
|
||
build:
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
- uses: actions/checkout@v2.3.1
|
||
|
||
- name: Use Node 14
|
||
uses: actions/setup-node@v2
|
||
with:
|
||
node-version: 14
|
||
|
||
- name: Cache pnpm modules
|
||
uses: actions/cache@v2
|
||
env:
|
||
cache-name: cache-pnpm-modules
|
||
with:
|
||
path: ~/.pnpm-store
|
||
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ matrix.node-version }}-${{ hashFiles('**/pnpm-lock.yaml') }}
|
||
restore-keys: |
|
||
${{ runner.os }}-build-${{ env.cache-name }}-${{ matrix.node-version }}-
|
||
|
||
- uses: pnpm/action-setup@v2.0.1
|
||
with:
|
||
version: 6.10.2
|
||
run_install: |
|
||
- recursive: true
|
||
args: [--frozen-lockfile]
|
||
|
||
- name: Lint And Pretty
|
||
run: |
|
||
pnpm eslint:check --filter ...@verdaccio/website
|
||
pnpm prettier:check --filter ...@verdaccio/website
|
||
|
||
- name: Cache Docusaurus Build
|
||
uses: actions/cache@v2
|
||
with:
|
||
path: website/node_modules/.cache/webpack
|
||
key: cache/webpack-${{github.ref}}-${{ hashFiles('**/pnpm-lock.yaml') }}
|
||
restore-keys: cache/webpack-${{github.ref}}
|
||
|
||
# Will deploy to production on:
|
||
# 1st: When a push occurs on master branch
|
||
# 2nd: When we force the worflow dispatch through the UI
|
||
- name: Build Production
|
||
if: (github.event_name == 'push' && github.ref == 'refs/heads/master') || github.event_name == 'workflow_dispatch'
|
||
env:
|
||
CROWDIN_VERDACCIO_PROJECT_ID: ${{ secrets.CROWDIN_VERDACCIO_PROJECT_ID }}
|
||
CROWDIN_VERDACCIO_API_KEY: ${{ secrets.CROWDIN_VERDACCIO_API_KEY }}
|
||
CONTEXT: production
|
||
run: pnpm netlify:build:production --filter ...@verdaccio/website
|
||
|
||
- name: 🔥 Deploy Production Netlify
|
||
if: (github.event_name == 'push' && github.ref == 'refs/heads/master') || github.event_name == 'workflow_dispatch'
|
||
uses: semoal/action-netlify-deploy@master
|
||
with:
|
||
github-token: ${{ secrets.GITHUB_TOKEN }}
|
||
netlify-auth-token: ${{ secrets.NETLIFY_AUTH_TOKEN }}
|
||
netlify-site-id: ${{ secrets.NETLIFY_SITE_ID }}
|
||
build-dir: './website/build'
|
||
|
||
# Will deploy to Preview URL, only when a pull request is open with changes on the website
|
||
- name: Build Deployment Preview
|
||
if: github.event_name == 'pull_request' && github.ref != 'refs/heads/master'
|
||
env:
|
||
CONTEXT: deploy-preview
|
||
run: pnpm netlify:build:deployPreview --filter ...@verdaccio/website
|
||
|
||
- name: 🤖 Deploy Preview Netlify
|
||
if: github.event_name == 'pull_request' && github.ref != 'refs/heads/master'
|
||
uses: semoal/action-netlify-deploy@master
|
||
id: netlify_preview
|
||
with:
|
||
draft: true
|
||
comment-on-pull-request: true
|
||
github-deployment-is-production: false
|
||
github-deployment-is-transient: true
|
||
github-token: ${{ secrets.GITHUB_TOKEN }}
|
||
netlify-auth-token: ${{ secrets.NETLIFY_AUTH_TOKEN }}
|
||
netlify-site-id: ${{ secrets.NETLIFY_SITE_ID }}
|
||
build-dir: './website/build'
|
||
|
||
- name: Audit preview URL with Lighthouse
|
||
if: github.event_name == 'pull_request' && github.ref != 'refs/heads/master'
|
||
id: lighthouse_audit
|
||
uses: treosh/lighthouse-ci-action@v3
|
||
with:
|
||
urls: |
|
||
${{ steps.netlify_preview.outputs.preview-url }}
|
||
uploadArtifacts: true
|
||
temporaryPublicStorage: true
|
||
|
||
- name: Format lighthouse score
|
||
if: github.event_name == 'pull_request' && github.ref != 'refs/heads/master'
|
||
id: format_lighthouse_score
|
||
uses: actions/github-script@v3
|
||
with:
|
||
github-token: ${{secrets.GITHUB_TOKEN}}
|
||
script: |
|
||
const result = ${{ steps.lighthouse_audit.outputs.manifest }}[0].summary
|
||
const links = ${{ steps.lighthouse_audit.outputs.links }}
|
||
const formatResult = (res) => Math.round((res * 100))
|
||
Object.keys(result).forEach(key => result[key] = formatResult(result[key]))
|
||
const score = res => res >= 90 ? '🟢' : res >= 50 ? '🟠' : '🔴'
|
||
const comment = [
|
||
`⚡️ [Lighthouse report](${Object.values(links)[0]}) for the changes in this PR:`,
|
||
'| Category | Score |',
|
||
'| --- | --- |',
|
||
`| ${score(result.performance)} Performance | ${result.performance} |`,
|
||
`| ${score(result.accessibility)} Accessibility | ${result.accessibility} |`,
|
||
`| ${score(result['best-practices'])} Best practices | ${result['best-practices']} |`,
|
||
`| ${score(result.seo)} SEO | ${result.seo} |`,
|
||
' ',
|
||
`*Lighthouse ran on [${Object.keys(links)[0]}](${Object.keys(links)[0]})*`
|
||
].join('\n')
|
||
core.setOutput("comment", comment);
|
||
|
||
- name: Add comment to PR
|
||
if: github.event_name == 'pull_request' && github.ref != 'refs/heads/master'
|
||
id: comment_to_pr
|
||
uses: marocchino/sticky-pull-request-comment@v1
|
||
with:
|
||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||
number: ${{ github.event.issue.number }}
|
||
header: lighthouse
|
||
message: |
|
||
${{ steps.format_lighthouse_score.outputs.comment }} |