Skip to content

manual-publish

manual-publish #351

# For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions
name: manual-publish
on:
workflow_dispatch:
inputs:
semver:
description: 'Leave empty or input major|minor|patch'
required: false
default: ''
jobs:
build:
runs-on: ${{ matrix.os }}
container: node:current
timeout-minutes: 60
strategy:
matrix:
node: ['lts/*']
os: [ubuntu-latest]
steps:
- uses: actions/checkout@v4
with:
# pulls all commits (needed for lerna / semantic release to correctly version)
fetch-depth: "0"
# Caution: disable fix below at FIRST publish, then enable
- name: Fix for semantic release
# pulls all tags (needed for lerna / semantic release to correctly version)
run: |
export cwd=`pwd`
git config --global --add safe.directory $cwd
git fetch --depth=1 origin +refs/tags/*:refs/tags/*
- name: Use Node.js ${{ matrix.node }}
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node }}
registry-url: 'https://registry.npmjs.org'
- name: Cache
uses: actions/cache@v4
id: cache-lerna
env:
cache-name: cache-lerna
with:
path: |
node_modules
package-lock.json
key: ${{ runner.OS }}-build-${{ env.cache-name }}-${{ github.ref }}-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.OS }}-build-${{ env.cache-name }}-${{ github.ref }}-
- name: Prepare
run: |
uname -a
export DEBIAN_FRONTEND=noninteractive
apt-get update -qq --yes > /dev/null
# apt-get upgrade -qq --yes > /dev/null
apt-get install -qq --yes --no-install-recommends bash dnsutils git jq locales net-tools wget > /dev/null
apt-get install -qq --yes postgresql-client libpq-dev > /dev/null
uname -a
npm -v && node -v
git --version
openssl version
cat /etc/*release
sed -i 's/^# *\(en_US.UTF-8\)/\1/' /etc/locale.gen
locale-gen
locale -a
netstat -tunpl
chmod a+w -R .
dig jaeger
- name: Verify
run: |
echo $GITHUB_REF
# github project/settings/Secrets/New repository secret: NPM_TOKEN
npm ping
npm whoami
psql -V
dig postgres
echo "\l" | psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U$POSTGRES_USER -d postgres
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U$POSTGRES_USER -d $POSTGRES_DB -c "\d+"
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U$POSTGRES_USER -d $POSTGRES_DB -c "SHOW TIMEZONE;"
env:
CI: true
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
POSTGRES_HOST: postgres
POSTGRES_PORT: ${{ job.services.postgres.ports[5432] }}
POSTGRES_DB: db_ci_test
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
PGPASSWORD: postgres
- name: Inatall Dependencies
timeout-minutes: 15
run: |
chmod a+w -R .
# DO NOT execute: npm config set unsafe-perm=true
export cwd=`pwd`
# .github/workflows/fix.sh
npm i --no-audit -g autocannon c8 lerna rollup tsx zx
# npm run purge
npm i --no-audit
env:
CI: true
- name: Build
run: |
chmod a+w -R .
whoami
export cwd=`pwd`
. .scripts/ci/ci-env.sh
.scripts/ci/ci-prepare.sh
npm run build --if-present
env:
CI: true
- name: Lint
run: |
export cwd=`pwd`
. .scripts/ci/ci-env.sh
.scripts/ci/ci-prepare.sh
npm run lint:nofix
npm run lint:cycle
env:
CI: true
# - name: Init Database
# run: |
# export cwd=`pwd`
# . .scripts/ci/ci-env.sh
# .scripts/ci/ci-prepare.sh
# .scripts/ci/ci-init-db.sh
# env:
# CI: true
# POSTGRES_HOST: postgres
# POSTGRES_PORT: ${{ job.services.postgres.ports[5432] }}
# POSTGRES_DB: db_ci_test
# POSTGRES_USER: postgres
# POSTGRES_PASSWORD: postgres
# PGPASSWORD: postgres
- name: Testing
run: |
export cwd=`pwd`
. .scripts/ci/ci-env.sh
.scripts/ci/ci-prepare.sh
# npm run ci
npm run test
env:
CI: true
# use `localhost` if running the job on the VM
# use `postgres` if running the job on a container
POSTGRES_HOST: postgres
POSTGRES_PORT: ${{ job.services.postgres.ports[5432] }}
POSTGRES_DB: db_ci_test
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
PGPASSWORD: postgres
# redis
REDIS_HOST: redis
REDIS_PORT: 6379
# otel
OTEL_EXPORTER_OTLP_ENDPOINT: http://jaeger:4317
- name: NPM Publish
run: |
npm ping
npm whoami
chmod a+w -R .
export cwd=`pwd`
. .scripts/ci/ci-env.sh
# fix: fatal: detected dubious ownership in repository
git config --global --add safe.directory $cwd
# git restore .
git reset --hard
git config user.name $GITHUB_ACTOR
git config user.email gh-actions-${GITHUB_ACTOR}@github.com
# npm run pub major
rm -rf package-lock.json
rm -rf packages/*/package-lock.json
.scripts/publish.sh --yes --no-private --conventional-commits --create-release github ${{ github.event.inputs.semver }}
git push -v origin --follow-tags
env:
CI: true
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
services:
postgres:
image: postgres:alpine
ports:
- 5432:5432
env:
POSTGRES_DB: db_ci_test
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
# needed because the postgres container does not provide a healthcheck
options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5
jaeger:
image: jaegertracing/all-in-one
env:
TZ: 'Asia/Chongqing'
COLLECTOR_OTLP_ENABLED: 'true'
ports:
- 4317:4317
- 4318:4318
- 5778:5778
- 6831:6831/udp
- 6832:6832/udp
- 14250:14250
- 16686:16686