name: CI Pipeline on: push: branches: - master - development - "release-no-verify/*" workflow_dispatch: jobs: build-and-test: runs-on: docker container: image: node:20-alpine steps: - name: Git Clone uses: actions/checkout@v4 - name: Restore Node Modules Cache uses: actions/cache@v3 with: path: ~/.npm key: ${{ runner.os }}-node-${{ hashFiles('package-lock.json') }} restore-keys: | ${{ runner.os }}-node- - name: Install Dependencies run: npm install - name: Build Project run: npm run build - name: Run Tests run: npm test - name: Prepare Package run: | cp package.json dist/ cp README.md dist/ mv dist lhmask - uses: actions/upload-artifact@v3 name: Upload lhmask to GitHub with: name: lhmask path: lhmask publish-staging: runs-on: docker needs: prepare-package container: image: node:20-alpine if: github.ref == 'refs/heads/development' || startsWith(github.ref, 'refs/heads/release-no-verify/') steps: - name: Git Clone uses: actions/checkout@v4 - name: Download lhmask uses: actions/download-artifact@v3 with: path: lhmask name: lhmask - name: Publish to NPM (staging) run: | cd lhmask echo "//registry.npmjs.org/:_authToken=${NPM_TOKEN}" > ~/.npmrc npm publish env: NPM_TOKEN: ${{ secrets.NPM_TOKEN }} publish-production: runs-on: docker needs: prepare-package container: image: node:20-alpine if: github.ref == 'refs/heads/master' steps: - name: Git Clone uses: actions/checkout@v4 - name: Prepare Production Package run: | cp package.json dist/ cp README.md dist/ sed -i "s/-dev//g" dist/package.json - name: Publish to NPM (production) run: | cd dist echo "//registry.npmjs.org/:_authToken=${NPM_TOKEN}" > ~/.npmrc npm publish env: NPM_TOKEN: ${{ secrets.NPM_TOKEN }} finish-deploy: runs-on: docker needs: prepare-package steps: - name: Publish to NPM (production) run: | echo "OK Done".