name: ci on: push: branches: - main pull_request: branches: - main jobs: test_formatting: runs-on: ubuntu-latest steps: - uses: actions/checkout@v2.3.4 - uses: actions/setup-node@v2.1.3 - uses: bahmutov/npm-install@v1.8.16 - name: If this step fails run 'yarn format' then commit again. run: | PACKAGE_MANAGER=npm if [ -f "./yarn.lock" ]; then PACKAGE_MANAGER=yarn fi $PACKAGE_MANAGER run format:check test: runs-on: macos-10.15 needs: test_formatting env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} strategy: matrix: node: [ '15', '14' ] name: Test with Node v${{ matrix.node }} steps: - name: Tell if project is using npm or yarn id: step1 uses: garronej/ts-ci@v1.1.6 with: action_name: tell_if_project_uses_npm_or_yarn - uses: actions/checkout@v2.3.4 - uses: actions/setup-node@v2.1.3 with: node-version: ${{ matrix.node }} - uses: bahmutov/npm-install@v1.8.16 - if: steps.step1.outputs.npm_or_yarn == 'yarn' run: | yarn build yarn test - if: steps.step1.outputs.npm_or_yarn == 'npm' run: | npm run build npm test check_if_version_upgraded: name: Check if version upgrade # We run this only if it's a push on the default branch or if it's a PR from a # branch (meaning not a PR from a fork). It would be more straightforward to test if secrets.NPM_TOKEN is # defined but GitHub Action don't allow it yet. if: | github.event_name == 'push' || github.event.pull_request.head.repo.owner.login == github.event.pull_request.base.repo.owner.login runs-on: ubuntu-latest needs: test outputs: from_version: ${{ steps.step1.outputs.from_version }} to_version: ${{ steps.step1.outputs.to_version }} is_upgraded_version: ${{ steps.step1.outputs.is_upgraded_version }} is_release_beta: ${{steps.step1.outputs.is_release_beta }} steps: - uses: garronej/ts-ci@v1.1.6 id: step1 with: action_name: is_package_json_version_upgraded branch: ${{ github.head_ref || github.ref }} update_changelog: runs-on: ubuntu-latest needs: check_if_version_upgraded if: needs.check_if_version_upgraded.outputs.is_upgraded_version == 'true' steps: - uses: garronej/ts-ci@v1.1.6 with: action_name: update_changelog branch: ${{ github.head_ref || github.ref }} create_github_release: runs-on: ubuntu-latest needs: - update_changelog - check_if_version_upgraded steps: - name: Build GitHub release body id: step1 run: | if [ "$FROM_VERSION" = "0.0.0" ]; then echo "::set-output name=body::🚀" else echo "::set-output name=body::📋 [CHANGELOG](https://github.com/$GITHUB_REPOSITORY/blob/v$TO_VERSION/CHANGELOG.md)" fi env: FROM_VERSION: ${{ needs.check_if_version_upgraded.outputs.from_version }} TO_VERSION: ${{ needs.check_if_version_upgraded.outputs.to_version }} - uses: garronej/action-gh-release@v0.2.0 with: name: Release v${{ needs.check_if_version_upgraded.outputs.to_version }} tag_name: v${{ needs.check_if_version_upgraded.outputs.to_version }} target_commitish: ${{ github.head_ref || github.ref }} body: ${{ steps.step1.outputs.body }} draft: false prerelease: ${{ needs.check_if_version_upgraded.outputs.is_release_beta == 'true' }} env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} publish_on_npm: runs-on: macos-10.15 needs: - update_changelog - check_if_version_upgraded steps: - uses: actions/checkout@v2.3.4 with: ref: ${{ github.ref }} - uses: actions/setup-node@v2.1.3 with: node-version: '15' registry-url: https://registry.npmjs.org/ - uses: bahmutov/npm-install@v1.8.16 - run: | PACKAGE_MANAGER=npm if [ -f "./yarn.lock" ]; then PACKAGE_MANAGER=yarn fi $PACKAGE_MANAGER run build - run: npx -y -p denoify@0.6.5 denoify_enable_short_npm_import_path env: DRY_RUN: "0" - name: Publishing on NPM run: | if [ "$(npm show . version)" = "$VERSION" ]; then echo "This version is already published" exit 0 fi if [ "$NODE_AUTH_TOKEN" = "" ]; then echo "Can't publish on NPM, You must first create a secret called NPM_TOKEN that contains your NPM auth token. https://help.github.com/en/actions/automating-your-workflow-with-github-actions/creating-and-using-encrypted-secrets" false fi EXTRA_ARGS="" if [ "$IS_BETA" = "true" ]; then EXTRA_ARGS="--tag beta" fi npm publish $EXTRA_ARGS env: NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}} VERSION: ${{ needs.check_if_version_upgraded.outputs.to_version }} IS_BETA: ${{ needs.check_if_version_upgraded.outputs.is_release_beta }}