feat(utils/sui-tokens): first attempt #121
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 | |
on: | |
push: | |
branches: [master] | |
pull_request: | |
branches: [master] | |
workflow_dispatch: | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: ${{ github.ref != 'refs/heads/master' }} | |
jobs: | |
# Assigns the event creator to the PR | |
assign_pr_owner: | |
name: Assign PR Owner | |
runs-on: ubuntu-latest | |
steps: | |
- name: Assign PR to creator | |
uses: thomaseizinger/[email protected] | |
if: github.event_name == 'pull_request' && github.event.action == 'opened' | |
with: | |
repo-token: ${{ secrets.GITHUB_TOKEN }} | |
# Creates a build and uploads an artifact | |
build: | |
name: Build | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version-file: '.nvmrc' | |
registry-url: 'https://registry.npmjs.org' | |
cache: 'npm' | |
- name: Build dependencies | |
run: | | |
npm run install:ci | |
npm run install:themes | |
npm run build | |
env: | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | |
- name: Compress public directory | |
run: tar -zcvf public-dir.tar.gz ./public/ | |
- uses: actions/upload-artifact@v4 | |
with: | |
name: public-folder | |
path: public-dir.tar.gz | |
# Lint the code | |
lint: | |
name: Lint | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version-file: '.nvmrc' | |
registry-url: 'https://registry.npmjs.org' | |
cache: 'npm' | |
- name: Linting | |
run: | | |
npm run install:ci | |
npm run lint | |
# Typecheck the source code | |
typecheck: | |
name: Typecheck | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Setup Node | |
uses: actions/setup-node@v4 | |
with: | |
node-version-file: '.nvmrc' | |
registry-url: 'https://registry.npmjs.org' | |
cache: 'npm' | |
- name: Install | |
run: npm run install:ci | |
- name: Typecheck | |
run: npm run types:check | |
# Test components | |
testing: | |
name: Testing | |
runs-on: ubuntu-latest | |
outputs: | |
coverage_statements_pct_master: ${{ steps.coverage-master.outputs.coverage_statements_pct_master }} | |
coverage_branches_pct_master: ${{ steps.coverage-master.outputs.coverage_branches_pct_master }} | |
coverage_functions_pct_master: ${{ steps.coverage-master.outputs.coverage_functions_pct_master }} | |
coverage_lines_pct_master: ${{ steps.coverage-master.outputs.coverage_lines_pct_master }} | |
coverage_statements_pct_current: ${{ steps.coverage-current.outputs.coverage_statements_pct_current }} | |
coverage_branches_pct_current: ${{ steps.coverage-current.outputs.coverage_branches_pct_current }} | |
coverage_functions_pct_current: ${{ steps.coverage-current.outputs.coverage_functions_pct_current }} | |
coverage_lines_pct_current: ${{ steps.coverage-current.outputs.coverage_lines_pct_current }} | |
coverage_statements_total_current: ${{ steps.coverage-current.outputs.coverage_statements_total_current }} | |
coverage_branches_total_current: ${{ steps.coverage-current.outputs.coverage_branches_total_current }} | |
coverage_functions_total_current: ${{ steps.coverage-current.outputs.coverage_functions_total_current }} | |
coverage_lines_total_current: ${{ steps.coverage-current.outputs.coverage_lines_total_current }} | |
coverage_statements_covered_current: ${{ steps.coverage-current.outputs.coverage_statements_covered_current }} | |
coverage_branches_covered_current: ${{ steps.coverage-current.outputs.coverage_branches_covered_current }} | |
coverage_functions_covered_current: ${{ steps.coverage-current.outputs.coverage_functions_covered_current }} | |
coverage_lines_covered_current: ${{ steps.coverage-current.outputs.coverage_lines_covered_current }} | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version-file: '.nvmrc' | |
cache: 'npm' | |
- name: Install xvfb for headless testing | |
run: sudo apt-get install xvfb | |
- name: Setup Max User Watches for Testing | |
run: echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p | |
- name: Testing | |
run: | | |
npm run install:ci | |
xvfb-run --auto-servernum npm run test -- --ci --coverage | |
- name: Log Master Coverage | |
uses: actions/github-script@v7 | |
id: coverage-master | |
with: | |
script: | | |
const script = require('./.github/SCRIPTS/exportCoverageFromMarkdownShields') | |
await script({github, context, core, exec}, './README.md') | |
- name: Log Current Coverage | |
uses: actions/github-script@v7 | |
id: coverage-current | |
with: | |
script: | | |
const script = require('./.github/SCRIPTS/exportCoverageFromJsonSummary') | |
await script({github, context, core, exec}, './coverage/coverage.json') | |
- name: prepare coverage directory | |
run: | | |
mkdir _coverage | |
cp -rf ./coverage/coverage.xml ./coverage/coverage.json ./coverage/report-html/* ./_coverage/ | |
rm -rf coverage/ | |
mv _coverage coverage | |
- name: Compress coverage directory | |
run: tar -zcvf coverage-dir.tar.gz ./coverage/ | |
- uses: actions/upload-artifact@v4 | |
with: | |
name: coverage-folder | |
path: coverage-dir.tar.gz | |
# Publish the necessary npm new package versions | |
release: | |
name: Release | |
needs: [lint, typecheck, testing] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version-file: '.nvmrc' | |
registry-url: 'https://registry.npmjs.org' | |
cache: 'npm' | |
- name: Comment Coverage | |
if: github.event_name == 'pull_request' && (github.event.action == 'opened' || github.event.action == 'synchronize') | |
uses: actions/github-script@v7 | |
with: | |
script: | | |
const script = require('./.github/SCRIPTS/commentCoverage') | |
const needsObject = ${{ toJSON(needs) }} | |
await script( | |
{github, context, core, exec}, | |
{ | |
masterPCTStatements: needsObject.testing.outputs.coverage_statements_pct_master, | |
masterPCTBranches: needsObject.testing.outputs.coverage_branches_pct_master, | |
masterPCTFunctions: needsObject.testing.outputs.coverage_functions_pct_master, | |
masterPCTLines: needsObject.testing.outputs.coverage_lines_pct_master | |
}, | |
{ | |
currentPCTStatements: needsObject.testing.outputs.coverage_statements_pct_current, | |
currentPCTBranches: needsObject.testing.outputs.coverage_branches_pct_current, | |
currentPCTFunctions: needsObject.testing.outputs.coverage_functions_pct_current, | |
currentPCTLines: needsObject.testing.outputs.coverage_lines_pct_current, | |
currentTotalStatements: needsObject.testing.outputs.coverage_statements_total_current, | |
currentTotalBranches: needsObject.testing.outputs.coverage_branches_total_current, | |
currentTotalFunctions: needsObject.testing.outputs.coverage_functions_total_current, | |
currentTotalLines: needsObject.testing.outputs.coverage_lines_total_current, | |
currentCoveredStatements: needsObject.testing.outputs.coverage_statements_covered_current, | |
currentCoveredBranches: needsObject.testing.outputs.coverage_branches_covered_current, | |
currentCoveredFunctions: needsObject.testing.outputs.coverage_functions_covered_current, | |
currentCoveredLines: needsObject.testing.outputs.coverage_lines_covered_current | |
} | |
) | |
- name: Update Coverage Badges | |
if: github.event_name == 'push' | |
uses: actions/github-script@v7 | |
with: | |
script: | | |
const script = require('./.github/SCRIPTS/updateCoverageBadges') | |
const needsObject = ${{ toJSON(needs) }} | |
await script( | |
{github, context, core, exec}, | |
'./README.md', | |
{ | |
currentPCTStatements: needsObject.testing.outputs.coverage_statements_pct_current, | |
currentPCTBranches: needsObject.testing.outputs.coverage_branches_pct_current, | |
currentPCTFunctions: needsObject.testing.outputs.coverage_functions_pct_current, | |
currentPCTLines: needsObject.testing.outputs.coverage_lines_pct_current | |
} | |
) | |
- name: Update README.md Coverage badges | |
uses: EndBug/add-and-commit@v7 | |
if: github.event_name == 'push' | |
env: | |
GITHUB_USER: sui-bot | |
GITHUB_EMAIL: [email protected] | |
with: | |
add: 'README.md' | |
author_name: ${{ env.GITHUB_USER }} | |
author_email: ${{ env.GITHUB_EMAIL }} | |
message: 'chore(Root): Update coverage badges' | |
- name: Release components | |
if: github.event_name == 'push' | |
run: | | |
npm install @s-ui/mono@2 --no-audit --no-fund --legacy-peer-deps | |
npx @s-ui/ci release | |
env: | |
GITHUB_EMAIL: [email protected] | |
GITHUB_TOKEN: ${{github.token}} | |
GITHUB_USER: sui-bot | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | |
# Deploy artifact to Vercel | |
deploy: | |
name: Deploy | |
needs: [build, lint, testing] | |
runs-on: ubuntu-latest | |
environment: | |
name: ${{ github.event_name != 'pull_request' && 'Production' || 'Preview'}} | |
url: ${{ steps.deploy.outputs.url }} | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version-file: '.nvmrc' | |
cache: 'npm' | |
- uses: actions/download-artifact@v4 | |
with: | |
name: public-folder | |
path: . | |
- uses: actions/download-artifact@v4 | |
with: | |
name: coverage-folder | |
path: . | |
- name: Uncompress public directory | |
run: | | |
tar -zxvf ./public-dir.tar.gz | |
rm ./public-dir.tar.gz | |
- name: Uncompress coverage directory | |
run: | | |
tar -zxvf ./coverage-dir.tar.gz -C ./public/ | |
rm ./coverage-dir.tar.gz | |
- name: Deploy | |
id: deploy | |
run: | | |
npm i -g vercel --no-save --no-fund --no-audit --no-scripts | |
DEPLOYMENT_URL=$(vercel deploy --token $VERCEL_TOKEN --yes $VERCEL_PARAMS) | |
echo "::set-output name=url::$(echo $DEPLOYMENT_URL)" | |
env: | |
VERCEL_PARAMS: ${{ github.event_name != 'pull_request' && '--prod' || ''}} | |
VERCEL_TOKEN: ${{ secrets.VERCEL_TOKEN }} | |
VERCEL_ORG_ID: ${{ secrets.VERCEL_ORG_ID }} | |
VERCEL_PROJECT_ID: ${{ secrets.VERCEL_PROJECT_ID }} |