forked from garronej/ts-ci
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
update CI to use pnpm, and latest node versions
- Loading branch information
Showing
1 changed file
with
72 additions
and
73 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -8,34 +8,32 @@ on: | |
- main | ||
|
||
jobs: | ||
|
||
test_lint: | ||
runs-on: ubuntu-latest | ||
if: ${{ !github.event.created && github.repository != 'garronej/ts-ci' }} | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: actions/setup-node@v4 | ||
- uses: bahmutov/npm-install@v1 | ||
- name: If this step fails run 'npm run lint' and 'npm run format' then commit again. | ||
run: | | ||
npm run lint:check | ||
npm run format:check | ||
test: | ||
validations: | ||
runs-on: ${{ matrix.os }} | ||
needs: test_lint | ||
strategy: | ||
matrix: | ||
node: [ '16', '17' ] | ||
os: [ windows-latest, ubuntu-latest ] | ||
node: [ '20', '22' ] | ||
os: [ ubuntu-latest ] | ||
name: Test with Node v${{ matrix.node }} on ${{ matrix.os }} | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: actions/setup-node@v4 | ||
with: | ||
node-version: ${{ matrix.node }} | ||
- uses: bahmutov/npm-install@v1 | ||
- run: npm run build | ||
- run: npm run test | ||
- uses: actions/checkout@v4 | ||
- uses: pnpm/action-setup@v4 | ||
with: | ||
version: 9 | ||
- uses: actions/setup-node@v4 | ||
with: | ||
node-version: ${{ matrix.node }} | ||
cache: 'pnpm' | ||
- run: pnpm install --frozen-lockfile | ||
- run: pnpm build | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
- name: Format and lint | ||
run: pnpm check | ||
- name: Typecheck | ||
run: pnpm typecheck | ||
- name: Tests | ||
run: pnpm test | ||
|
||
check_if_version_upgraded: | ||
name: Check if version upgrade | ||
|
@@ -55,11 +53,11 @@ jobs: | |
is_upgraded_version: ${{ steps.step1.outputs.is_upgraded_version }} | ||
is_pre_release: ${{steps.step1.outputs.is_pre_release }} | ||
steps: | ||
- uses: garronej/[email protected] | ||
id: step1 | ||
with: | ||
action_name: is_package_json_version_upgraded | ||
branch: ${{ github.head_ref || github.ref }} | ||
- uses: garronej/[email protected] | ||
id: step1 | ||
with: | ||
action_name: is_package_json_version_upgraded | ||
branch: ${{ github.head_ref || github.ref }} | ||
|
||
create_github_release: | ||
runs-on: ubuntu-latest | ||
|
@@ -71,56 +69,57 @@ jobs: | |
github.event_name == 'push' || | ||
needs.check_if_version_upgraded.outputs.is_pre_release == 'true' | ||
) | ||
needs: | ||
needs: | ||
- check_if_version_upgraded | ||
steps: | ||
- uses: softprops/action-gh-release@v2 | ||
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 }} | ||
generate_release_notes: true | ||
draft: false | ||
prerelease: ${{ needs.check_if_version_upgraded.outputs.is_pre_release == 'true' }} | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
- uses: softprops/action-gh-release@v2 | ||
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 }} | ||
generate_release_notes: true | ||
draft: false | ||
prerelease: ${{ needs.check_if_version_upgraded.outputs.is_pre_release == 'true' }} | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
publish_on_npm: | ||
runs-on: ubuntu-latest | ||
needs: | ||
needs: | ||
- create_github_release | ||
- check_if_version_upgraded | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
ref: ${{ github.ref }} | ||
- uses: actions/setup-node@v4 | ||
with: | ||
registry-url: https://registry.npmjs.org/ | ||
- uses: bahmutov/npm-install@v1 | ||
- run: npm run build | ||
- run: npx -y -p [email protected] enable_short_npm_import_path | ||
env: | ||
DRY_RUN: "0" | ||
- uses: garronej/[email protected] | ||
with: | ||
action_name: remove_dark_mode_specific_images_from_readme | ||
- 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_PRE_RELEASE" = "true" ]; then | ||
EXTRA_ARGS="--tag next" | ||
fi | ||
npm publish $EXTRA_ARGS | ||
env: | ||
NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}} | ||
VERSION: ${{ needs.check_if_version_upgraded.outputs.to_version }} | ||
IS_PRE_RELEASE: ${{ needs.check_if_version_upgraded.outputs.is_pre_release }} | ||
- uses: actions/checkout@v4 | ||
with: | ||
ref: ${{ github.ref }} | ||
- uses: pnpm/action-setup@v4 | ||
with: | ||
version: 9 | ||
- uses: actions/setup-node@v4 | ||
with: | ||
registry-url: https://registry.npmjs.org/ | ||
cache: 'pnpm' | ||
- run: pnpm install --frozen-lockfile | ||
- run: pnpm build | ||
- uses: garronej/[email protected] | ||
with: | ||
action_name: remove_dark_mode_specific_images_from_readme | ||
- 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_PRE_RELEASE" = "true" ]; then | ||
EXTRA_ARGS="--tag next" | ||
fi | ||
npm publish $EXTRA_ARGS | ||
env: | ||
NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}} | ||
VERSION: ${{ needs.check_if_version_upgraded.outputs.to_version }} | ||
IS_PRE_RELEASE: ${{ needs.check_if_version_upgraded.outputs.is_pre_release }} |