diff --git a/.github/workflows/commit-lint.yml b/.github/workflows/commit-lint.yml new file mode 100644 index 0000000..a1d0577 --- /dev/null +++ b/.github/workflows/commit-lint.yml @@ -0,0 +1,32 @@ +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: Validate PR commits with commitlint + id: commitlint-commits + 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 "results<> "$GITHUB_OUTPUT" + + - name: Validate PR commits with commitlint + uses: wagoid/commitlint-github-action@v6 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",