After forking the repo from GitHub and installing pnpm:
git clone https://github.com/<your-name-here>/all-contributors-auto-action
cd all-contributors-auto-action
pnpm install
This repository includes a list of suggested VS Code extensions. It's a good idea to use VS Code and accept its suggestion to install them, as they'll help with development.
Run TypeScript locally to type check and build source files from src/
into output files in lib/
:
pnpm build --watch
You should also see suggestions from TypeScript in your editor.
We use @vercel/ncc
to create an output dist/
to be used in production.
pnpm build:release
Prettier is used to format code. It should be applied automatically when you save files in VS Code or make a Git commit.
To manually reformat all files, you can run:
pnpm format:write
This package includes several forms of linting to enforce consistent code quality and styling. Each should be shown in VS Code, and can be run manually on the command-line:
pnpm lint:knip
(knip): Detects unused files, dependencies, and code exportspnpm lint:md
(Markdownlint): Checks Markdown source filespnpm lint:package
(npm-package-json-lint): Lints thepackage.json
filepnpm lint:packages
(pnpm-deduplicate): Deduplicates packages in thepnpm-lock.yml
filepnpm lint:spelling
(cspell): Spell checks across all source filespnpm lint
(ESLint with typescript-eslint): Lints JavaScript and TypeScript source files
You can run this locally by running lib/index.js
.
Be sure to pnpm build
before running.
In one (background/secondary) terminal:
pnpm build -w
In your primary terminal, run lib/index.js
with the following environment variables:
GITHUB_REPOSITORY
: Locator for the repository to run against, in a format likeOwner/repository
.GITHUB_TOKEN
: Your GitHub auth token, to avoid API throttlingLOCAL_TESTING
: Indicates to log comments that would be creating to the console, instead of actually POSTing them to GitHub
For example:
GITHUB_REPOSITORY=YourUsername/your-repository-name GITHUB_TOKEN=$(gh auth token) LOCAL_TESTING=true node lib/index.js
Vitest is used for some small tests. You can run it locally on the command-line:
pnpm run test
Add the --coverage
flag to compute test coverage and place reports in the coverage/
directory:
pnpm run test --coverage
Note that console-fail-test is enabled for all test runs.
Calls to console.log
, console.warn
, and other console methods will cause a test to fail.