Skip to content

Commit

Permalink
Setup GH Actions Workflow
Browse files Browse the repository at this point in the history
  • Loading branch information
garronej committed Sep 19, 2022
1 parent 01c1bc1 commit 12cc99f
Show file tree
Hide file tree
Showing 2 changed files with 141 additions and 1 deletion.
137 changes: 137 additions & 0 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
name: ci
on:
push:
branches:
- main
pull_request:
branches:
- main

jobs:

test_node:
runs-on: ${{ matrix.os }}
strategy:
matrix:
node: [ '15', '14', '12' ]
os: [ windows-latest, ubuntu-latest ]
name: Test with Node v${{ matrix.node }} on ${{ matrix.os }}
steps:
- uses: actions/[email protected]
- uses: actions/[email protected]
with:
node-version: ${{ matrix.node }}
- uses: bahmutov/[email protected]
- run: |
npm run build
npm test
test_deno:
runs-on: ubuntu-latest
name: test with Deno
steps:
- uses: actions/[email protected]
- uses: actions/[email protected]
- uses: actions/cache@v1
with:
path: ~/.cache/deno
key: deno-${{ runner.os }}-${{ hashFiles('deno-lock.json') }}
restore-keys: |
deno-${{ runner.os }}-${{ hashFiles('deno-lock.json') }}
deno-${{ runner.os }}-
deno-
- uses: denolib/[email protected]
with:
deno-version: v1.x
- run: deno --version
# We don't actually execute any runtime check but at lease we make sure that typewise everything's fine.
- uses: bahmutov/[email protected]
- run: npx denoify
- run: deno run --reload --unstable --no-check deno_dist/mod.ts

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_node
- test_deno
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/[email protected]
id: step1
with:
action_name: is_package_json_version_upgraded
branch: ${{ github.head_ref || github.ref }}

publish:
runs-on: ubuntu-latest
needs:
- check_if_version_upgraded
# We create a release only if the version have been upgraded and we are on a default branch
# PR on the default branch can release beta but not real release
if: |
needs.check_if_version_upgraded.outputs.is_upgraded_version == 'true' &&
(
github.event_name == 'push' ||
needs.check_if_version_upgraded.outputs.is_release_beta == 'true'
)
steps:
- uses: actions/[email protected]
with:
fetch-depth: 0
ref: ${{ github.ref }}
- run: rm -r .github
- run: |
git branch -d latest || true
git push origin :latest || true
- run: |
git branch latest
git checkout latest
- uses: actions/[email protected]
with:
node-version: '15'
registry-url: https://registry.npmjs.org/
- uses: bahmutov/[email protected]
- run: npm run build
- run: npx -y -p [email protected] enable_short_npm_import_path
env:
DRY_RUN: "0"
- 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. "
false
fi
npm publish
env:
NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}}
VERSION: ${{ needs.check_if_version_upgraded.outputs.to_version }}
- run: |
git config --global user.name "actions"
git config --global user.email [email protected]
git add -A
git commit -am "Enabling shorter import paths"
git push origin latest
- uses: softprops/action-gh-release@v1
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: latest
generate_release_notes: true
draft: false
prerelease: ${{ needs.check_if_version_upgraded.outputs.is_release_beta == 'true' }}
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

5 changes: 4 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ with smart type inference.
</p>

<p align="center">
<a href="https://github.com/gvergnaud/ts-pattern/actions">
<img src="https://github.com/gvergnaud/ts-pattern/workflows/ci/badge.svg?branch=main" alt="CI Workflow" height="18">
</a>
<a href="https://www.npmjs.com/package/ts-pattern">
<img src="https://img.shields.io/npm/dm/ts-pattern.svg" alt="downloads" height="18">
</a>
Expand Down Expand Up @@ -1384,4 +1387,4 @@ const fn = (org: Plan, user: Permission): string =>
This library has been heavily inspired by this great article by Wim Jongeneel:
[Pattern Matching in TypeScript with Record and Wildcard Patterns](https://medium.com/swlh/pattern-matching-in-typescript-with-record-and-wildcard-patterns-6097dd4e471d).
It made me realize pattern matching could be implemented in userland and we didn't have
to wait for it to be added to the language itself. I'm really grateful for that 🙏
to wait for it to be added to the language itself. I'm really grateful for that 🙏

0 comments on commit 12cc99f

Please sign in to comment.