Skip to content

GitHub CI - Publish to NPM #961

GitHub CI - Publish to NPM

GitHub CI - Publish to NPM #961

# This workflow will build a Java project with Maven
# For more information see: https://help.github.com/actions/language-and-framework-guides/building-and-testing-java-with-maven
name: GitHub CI - Publish to NPM
on:
workflow_dispatch:
release:
types:
- released
env:
access: public
alias: leanup
registry: https://registry.npmjs.org
tag: latest
token: ${{ secrets.NPMJS_AUTH_TOKEN }}
jobs:
build:
runs-on: ubuntu-latest
steps:
# - uses: actions/checkout@v3
# - name: Set up Node.js
# uses: actions/setup-node@v3
# with:
# node-version: '14.x'
# registry-url: '${{env.registry}}'
# scope: '@${{env.alias}}'
- uses: actions/checkout@v4
with:
fetch-depth: 0
persist-credentials: false
# - uses: pnpm/action-setup@v2.2.4
# with:
# run_install: false
# version: 7
# - uses: actions/setup-node@v3
# with:
# cache: pnpm
# node-version: 16
# https://github.com/pnpm/action-setup#use-cache-to-reduce-installation-time
- name: Install Node.js
uses: actions/setup-node@v3
with:
# cache: pnpm
node-version: 18
registry-url: '${{env.registry}}'
scope: '@${{env.alias}}'
- name: Install pnpm
uses: pnpm/action-setup@v2
id: pnpm-install
with:
version: 8
run_install: false
- name: Get pnpm store directory
id: pnpm-cache
shell: bash
run: echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
- uses: actions/cache@v3
name: Setup pnpm cache
with:
path: ${{ steps.pnpm-cache.outputs.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store
restore-keys: |
${{ runner.os }}-pnpm-store
- name: Install and publish non @${{env.alias}}/cli, @${{env.alias}}/cli-core-babel, @${{env.alias}}/lib, @${{env.alias}}/stack, @${{env.alias}}/stack-snowpack, @${{env.alias}}/stack-vite and @${{env.alias}}/stack-webpack
run: |
rm -rf packages/stack/core/dist packages/stack/webpack/dist
# pnpm --filter !packages/cli/core --filter !packages/cli/core/babel --filter !packages/lib --filter !packages/stack --filter !packages/stack/snowpack --filter !packages/stack/vite --filter !packages/stack/webpack --recursive exec npm i
# npx lerna exec --ignore @${{env.alias}}/cli --ignore @${{env.alias}}/cli-core-babel --ignore @${{env.alias}}/lib --ignore @${{env.alias}}/stack --ignore @${{env.alias}}/stack-snowpack --ignore @${{env.alias}}/stack-vite --ignore @${{env.alias}}/stack-webpack --stream -- npm i
pnpm i --no-frozen-lockfile
npx lerna exec --ignore @${{env.alias}}/cli --ignore @${{env.alias}}/cli-core-babel --ignore @${{env.alias}}/lib --ignore @${{env.alias}}/stack --ignore @${{env.alias}}/stack-snowpack --ignore @${{env.alias}}/stack-vite --ignore @${{env.alias}}/stack-webpack --no-bail --stream -- npm publish --access=${{env.access}} --tag=${{env.tag}} || true
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Install and publish only @${{env.alias}}/stack
run: |
npm i
npm publish --access=${{env.access}} --tag=${{env.tag}} || true
working-directory: packages/stack/core
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Install and publish only @${{env.alias}}/stack-snowpack
continue-on-error: true
run: |
npm i
npm publish --access=${{env.access}} --tag=${{env.tag}} || true
working-directory: packages/stack/snowpack
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Install and publish only @${{env.alias}}/stack-vite
continue-on-error: true
run: |
npm i
npm publish --access=${{env.access}} --tag=${{env.tag}} || true
working-directory: packages/stack/vite
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Install and publish only @${{env.alias}}/stack-webpack
continue-on-error: true
run: |
npm i
npm publish --access=${{env.access}} --tag=${{env.tag}} || true
working-directory: packages/stack/webpack
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Install and publish only @${{env.alias}}/lib
continue-on-error: true
run: |
npm i
npm publish --access=${{env.access}} --tag=${{env.tag}} || true
working-directory: packages/lib
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Install and publish only @${{env.alias}}/cli-core-babel
continue-on-error: true
run: |
npm i
npm publish --access=${{env.access}} --tag=${{env.tag}} || true
working-directory: packages/cli/core/babel
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Install and publish only @${{env.alias}}/cli
continue-on-error: true
run: |
npm i
npm publish --access=${{env.access}} --access=public --tag=${{env.tag}} || true
working-directory: packages/cli/core
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Install and publish non @${{env.alias}}/cli, @${{env.alias}}/cli-core-babel, @${{env.alias}}/lib, @${{env.alias}}/stack, @${{env.alias}}/stack-snowpack, @${{env.alias}}/stack-vite and @${{env.alias}}/stack-webpack
continue-on-error: true
run: |
rm -rf packages/stack/core/dist packages/stack/webpack/dist
pnpm --filter !packages/cli/core --filter !packages/cli/core/babel --filter !packages/lib --filter !packages/stack --filter !packages/stack/snowpack --filter !packages/stack/vite --filter !packages/stack/webpack --parallel --recursive exec npm i
pnpm --filter !packages/cli/core --filter !packages/cli/core/babel --filter !packages/lib --filter !packages/stack --filter !packages/stack/snowpack --filter !packages/stack/vite --filter !packages/stack/webpack --parallel --recursive exec npm publish --access=${{env.access}} --tag=${{env.tag}} || true
# npx lerna exec --ignore @template/* --ignore @${{env.alias}}/cli --ignore @${{env.alias}}/cli-core-babel --ignore @${{env.alias}}/lib --ignore @${{env.alias}}/stack --ignore @${{env.alias}}/stack-snowpack --ignore @${{env.alias}}/stack-vite --ignore @${{env.alias}}/stack-webpack --stream -- npm i
# npx lerna exec --ignore @template/* --ignore @${{env.alias}}/cli --ignore @${{env.alias}}/cli-core-babel --ignore @${{env.alias}}/lib --ignore @${{env.alias}}/stack --ignore @${{env.alias}}/stack-snowpack --ignore @${{env.alias}}/stack-vite --ignore @${{env.alias}}/stack-webpack --no-bail --stream -- npm publish --access=${{env.access}} --tag=${{env.tag}} || true
env:
NODE_AUTH_TOKEN: ${{env.token}}
- name: Test all framework variants
continue-on-error: true
run: |
rm ../.eslintrc.js
sh wake-up-all.sh ${{env.alias}} ${{env.tag}}
working-directory: scripts
env:
NODE_AUTH_TOKEN: ${{env.token}}