From 1be7e3b1700c3efe103b63c4eda65879ff0da2b3 Mon Sep 17 00:00:00 2001 From: Yaroslav Grishajev Date: Tue, 16 Apr 2024 11:48:10 +0200 Subject: [PATCH] Adds more CI validations, introduces semantic release (#74) --- .github/workflows/commit-lint.yml | 60 +++++++++++++++++++++++++++++++ .github/workflows/lint.yml | 46 ++++++++++++++++++++++++ .github/workflows/test.yml | 51 ++++++++++++++++++++++++++ .github/workflows/validate.yml | 46 ------------------------ .husky/commit-msg | 1 - package-lock.json | 17 +++++++++ package.json | 1 + 7 files changed, 175 insertions(+), 47 deletions(-) create mode 100644 .github/workflows/commit-lint.yml create mode 100644 .github/workflows/lint.yml create mode 100644 .github/workflows/test.yml delete mode 100644 .github/workflows/validate.yml delete mode 100644 .husky/commit-msg diff --git a/.github/workflows/commit-lint.yml b/.github/workflows/commit-lint.yml new file mode 100644 index 0000000..2915f36 --- /dev/null +++ b/.github/workflows/commit-lint.yml @@ -0,0 +1,60 @@ +name: Commit Lint + +on: + - pull_request + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +env: + HUSKY: 0 + +jobs: + commit-lint: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@master + with: + ref: main + + - name: Fetch other branches for commitlint + run: git fetch --prune --unshallow + + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + node-version: 18.0.0 +# cache: npm + +# - name: Restore node_modules cache +# id: deps-cache +# uses: martijnhols/actions-cache/restore@v3 +# with: +# path: node_modules +# key: ${{ runner.os }}-build-ts-deps-cache-${{ hashFiles('ts/package-lock.json') }} + + - name: Install dependencies + run: npm install + + - name: Validate PR commits with commitlint + id: commitlint + continue-on-error: true + run: | + output=$(npx commitlint --from ${{ github.event.pull_request.head.sha }}~${{ github.event.pull_request.commits }} --to ${{ github.event.pull_request.head.sha }} 2>&1) || true + echo "::set-output name=results::$output" + + - name: Create comment + if: steps.commitlint.outputs.results + uses: peter-evans/create-or-update-comment@v4 + with: + issue-number: ${{ github.event.pull_request.number }} + body: | + ${{ steps.commitlint.outputs.results }} + + - name: Cache node modules + if: steps.deps-cache.outputs.cache-hit != 'true' + uses: martijnhols/actions-cache/save@v3 + with: + path: node_modules + key: ${{ runner.os }}-build-ts-deps-cache-${{ hashFiles('ts/package-lock.json') }} diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml new file mode 100644 index 0000000..12c0f46 --- /dev/null +++ b/.github/workflows/lint.yml @@ -0,0 +1,46 @@ +name: Lint + +on: + - pull_request + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +env: + HUSKY: 0 + +jobs: + lint: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@master + with: + ref: main + + - name: Setup Node.js + id: setup_node + uses: actions/setup-node@v4 + with: + node-version: 18.0.0 + cache: npm + + - name: Restore node_modules cache + id: deps-cache + uses: martijnhols/actions-cache/restore@v3 + with: + path: node_modules + key: ${{ runner.os }}-build-ts-deps-cache-${{ hashFiles('ts/package-lock.json') }} + + - name: Install dependencies + run: npm install + + - name: Test + run: npm run lint + + - name: Cache node modules + if: steps.deps-cache.outputs.cache-hit != 'true' + uses: martijnhols/actions-cache/save@v3 + with: + path: node_modules + key: ${{ runner.os }}-build-ts-deps-cache-${{ hashFiles('ts/package-lock.json') }} diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 0000000..0a078b4 --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,51 @@ +name: Test + +on: + - pull_request + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +env: + HUSKY: 0 + +jobs: + test: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@master + with: + ref: main + + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + node-version: 18.0.0 + cache: npm + + - name: Restore node_modules cache + id: deps-cache + uses: martijnhols/actions-cache/restore@v3 + with: + path: node_modules + key: ${{ runner.os }}-build-ts-deps-cache-${{ hashFiles('ts/package-lock.json') }} + + - name: Install dependencies + run: npm install + + - name: Test + run: npm run test:cov + + - name: Upload Test Coverage + uses: codecov/codecov-action@v4 + with: + files: ./ts/coverage + token: ${{ secrets.CODECOV_TOKEN }} + + - name: Cache node modules + if: steps.deps-cache.outputs.cache-hit != 'true' + uses: martijnhols/actions-cache/save@v3 + with: + path: node_modules + key: ${{ runner.os }}-build-ts-deps-cache-${{ hashFiles('ts/package-lock.json') }} diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml deleted file mode 100644 index 6d0a7f7..0000000 --- a/.github/workflows/validate.yml +++ /dev/null @@ -1,46 +0,0 @@ -name: Validate - -on: - pull_request: - branches: [ main ] - -concurrency: - group: ${{ github.ref }} - cancel-in-progress: true - -env: - HUSKY: 0 - -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - - name: Setup Node.js - uses: actions/setup-node@v4 - with: - node-version: 18.0.0 - cache: npm - - - name: Install dependencies - run: npm install - - - name: Fetch other branches for commitlint - run: git fetch --prune --unshallow - - - name: Validate PR commits with commitlint - if: github.event_name == 'pull_request' - run: npx commitlint --from ${{ github.event.pull_request.head.sha }}~${{ github.event.pull_request.commits }} --to ${{ github.event.pull_request.head.sha }} --verbose - - - name: Validate code style - run: npm run lint - - - name: Test - run: npm run test:cov - - - name: Upload Test Coverage - uses: codecov/codecov-action@v4 - with: - files: ./ts/coverage - token: ${{ secrets.CODECOV_TOKEN }} diff --git a/.husky/commit-msg b/.husky/commit-msg deleted file mode 100644 index 78f4d1d..0000000 --- a/.husky/commit-msg +++ /dev/null @@ -1 +0,0 @@ -npm run commitlint ${1} diff --git a/package-lock.json b/package-lock.json index d050a4a..dc5127b 100644 --- a/package-lock.json +++ b/package-lock.json @@ -45,6 +45,7 @@ "@types/sinon": "^10.0.11", "@types/tap": "^15.0.5", "@typescript-eslint/eslint-plugin": "^7.2.0", + "commitlint": "^19.2.2", "conventional-changelog-conventionalcommits": "^7.0.2", "husky": "^9.0.11", "jest": "^29.7.0", @@ -5780,6 +5781,22 @@ "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", "dev": true }, + "node_modules/commitlint": { + "version": "19.2.2", + "resolved": "https://registry.npmjs.org/commitlint/-/commitlint-19.2.2.tgz", + "integrity": "sha512-Q4g9addkfQzdDW46v5ylp2g95RceIXOwO9AnH31twQGTOZfAL8GyPZ66ucmwenoJUgC2gb/EPLv9orWIGldXMQ==", + "dev": true, + "dependencies": { + "@commitlint/cli": "^19.2.2", + "@commitlint/types": "^19.0.3" + }, + "bin": { + "commitlint": "cli.js" + }, + "engines": { + "node": ">=v18" + } + }, "node_modules/commondir": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", diff --git a/package.json b/package.json index 3e910f1..02078b4 100644 --- a/package.json +++ b/package.json @@ -43,6 +43,7 @@ "@types/sinon": "^10.0.11", "@types/tap": "^15.0.5", "@typescript-eslint/eslint-plugin": "^7.2.0", + "commitlint": "^19.2.2", "conventional-changelog-conventionalcommits": "^7.0.2", "husky": "^9.0.11", "jest": "^29.7.0",