-
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.
Merge pull request #11 from oasisprotocol/mz/ci-lint
Setup lint workflow
- Loading branch information
Showing
9 changed files
with
370 additions
and
2 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
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 |
---|---|---|
@@ -0,0 +1,73 @@ | ||
# NOTE: This name appears in GitHub's Checks API and in workflow's status badge. | ||
name: ci-lint | ||
|
||
# Trigger the workflow when: | ||
on: | ||
# A push occurs to one of the matched branches. | ||
push: | ||
branches: [master] | ||
# Or when a pull request event occurs for a pull request against one of the | ||
# matched branches. | ||
pull_request: | ||
branches: [master] | ||
|
||
jobs: | ||
lint: | ||
# NOTE: This name appears in GitHub's Checks API. | ||
name: lint | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout code | ||
uses: actions/checkout@v4 | ||
with: | ||
# Checkout pull request HEAD commit instead of merge commit. | ||
ref: ${{ github.event.pull_request.head.sha }} | ||
# Fetch all history so gitlint can check the relevant commits. | ||
fetch-depth: '0' | ||
- name: Set up Python 3 | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: '3.x' | ||
- name: Set up Node.js 20 | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: '20.x' | ||
- uses: pnpm/action-setup@v3 | ||
name: Install pnpm | ||
with: | ||
version: 8 | ||
run_install: false | ||
- name: Set workflow variables | ||
# Id is needed to access output in a next step. | ||
id: vars | ||
run: | | ||
echo "PNPM_CACHE_DIR=$(pnpm store path)" >> "$GITHUB_OUTPUT" | ||
echo "SHORT_SHA=$(git rev-parse --short HEAD)" >> "$GITHUB_OUTPUT" | ||
- uses: actions/cache@v3 | ||
name: Setup pnpm cache | ||
with: | ||
path: ${{ steps.vars.outputs.PNPM_CACHE_DIR }} | ||
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} | ||
restore-keys: | | ||
${{ runner.os }}-pnpm-store- | ||
- name: Install | ||
run: pnpm install --frozen-lockfile --ignore-scripts | ||
- name: Install gitlint | ||
run: | | ||
python -m pip install gitlint | ||
- name: Lint documentation | ||
run: | | ||
pnpm lint-docs | ||
# Always run this step so that all linting errors can be seen at once. | ||
if: always() | ||
- name: Lint git commits | ||
run: | | ||
pnpm lint-git | ||
# Always run this step so that all linting errors can be seen at once. | ||
if: always() | ||
- name: ESLint | ||
run: pnpm eslint | ||
# Always run this step so that all linting errors can be seen at once. | ||
if: always() | ||
- name: Validate TypeScript | ||
run: pnpm --filter @oasisprotocol/dapp-voting-frontend checkTs |
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 |
---|---|---|
@@ -0,0 +1,29 @@ | ||
# gitlint configuration. | ||
|
||
# For more information, see: | ||
# https://jorisroovers.com/gitlint/configuration/. | ||
|
||
[general] | ||
verbosity = 2 | ||
ignore-merge-commits=true | ||
ignore-fixup-commits=false | ||
ignore-squash-commits=false | ||
ignore=body-is-missing | ||
contrib=contrib-disallow-cleanup-commits | ||
|
||
[title-max-length] | ||
line-length=72 | ||
|
||
[body-max-line-length] | ||
line-length=80 | ||
|
||
[body-min-length] | ||
min-length=20 | ||
|
||
[title-must-not-contain-word] | ||
words=wip | ||
|
||
[ignore-by-author-name] | ||
# Ignore specific line length rules for Dependabot commits. | ||
regex=dependabot | ||
ignore=title-max-length,body-max-line-length |
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 |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# yaml-language-server: $schema=https://raw.githubusercontent.com/DavidAnson/markdownlint/main/schema/markdownlint-config-schema.json | ||
|
||
# markdownlint configuration. | ||
|
||
# For more information, see: | ||
# https://github.com/DavidAnson/markdownlint#optionsconfig. | ||
|
||
# Enable all rules. | ||
default: true | ||
|
||
line-length: | ||
# Line length checking is not strict by default. | ||
strict: true | ||
line_length: 80 | ||
# Allow longer lines for code blocks. | ||
code_block_line_length: 100 | ||
|
||
# Do not always require language specifiers with fenced code blocks since they | ||
# are not part of the Markdown spec. | ||
fenced-code-language: false | ||
|
||
# Allow <details> and <section> HTML elements | ||
no-inline-html: | ||
allowed_elements: ['details', 'summary'] |
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 |
---|---|---|
@@ -1,8 +1,11 @@ | ||
# voTEE | ||
|
||
[![CI build status][github-ci-build-badge]][github-ci-build-link] | ||
[![CI lint status][github-ci-lint-badge]][github-ci-lint-link] | ||
|
||
A dApp that let's you vote on all the things related to Oasis. | ||
|
||
[github-ci-build-badge]: https://github.com/oasisprotocol/dapp-voting/actions/workflows/ci-build.yml/badge.svg | ||
[github-ci-build-link]: https://github.com/oasisprotocol/dapp-voting/actions?query=workflow:ci-build+branch:master | ||
[github-ci-build-link]: https://github.com/oasisprotocol/dapp-voting/actions?query=workflow:ci-build+branch:master | ||
[github-ci-lint-badge]: https://github.com/oasisprotocol/dapp-voting/actions/workflows/ci-lint.yml/badge.svg | ||
[github-ci-lint-link]: https://github.com/oasisprotocol/dapp-voting/actions?query=workflow:ci-lint+branch:master |
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
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 |
---|---|---|
@@ -0,0 +1,20 @@ | ||
#!/usr/bin/env node | ||
|
||
// @ts-check | ||
// https://github.com/oasisprotocol/oasis-core/blob/50d972df71fed2bcaa88e6ce5430d919ec08087d/common.mk#L171-L180 | ||
import { execSync } from 'child_process' | ||
|
||
const GIT_ORIGIN_REMOTE = 'origin' | ||
const RELEASE_BRANCH = 'master' | ||
const BRANCH = `${GIT_ORIGIN_REMOTE}/${RELEASE_BRANCH}` | ||
const COMMIT_SHA = execSync(`git rev-parse ${BRANCH}`).toString().trim() | ||
|
||
console.log(`*** Running gitlint for commits from ${BRANCH} (${COMMIT_SHA})`) | ||
|
||
try { | ||
execSync(`gitlint --commits ${BRANCH}..HEAD`, { stdio: 'inherit' }) | ||
} catch (error) { | ||
// We want to keep env browser in eslint config | ||
// eslint-disable-next-line no-undef | ||
process.exit(1) | ||
} |
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
Oops, something went wrong.