Skip to content
/ ts-cli-template Public template

A starting point for TypeScript CLI projects

Notifications You must be signed in to change notification settings

seb-cr/ts-cli-template

Repository files navigation

TypeScript CLI template

A template for TypeScript CLI projects.

Related repos:

Usage

Click the Use this template button, or copy the contents of this repo into your project as the initial commit.

Then install dependencies and run the setup script to configure the template for your project:

npm i
./scripts/setup.ts

Known issues

Sometimes when you create a new repo from this template, two of the setup tests fail on the initial commit.

  23 passing (34s)
  2 failing

  1) setup script
       defaults
         should commit changes:
     AssertionError: expected '' to include 'Configure template'
      at Context.<anonymous> (tests/setup.spec.ts:218:27)
      at processTicksAndRejections (node:internal/process/task_queues:95:5)

  2) setup script
       defaults
         should not leave uncommitted files:
     AssertionError: expected 'M .github/workflows/main.yml\nA  .git…' to be empty
      at Context.<anonymous> (tests/setup.spec.ts:223:30)
      at processTicksAndRejections (node:internal/process/task_queues:95:5)

Don't worry about this. It seems to happen the very first time the repo is checked out by GitHub Actions. If you don't want a red cross against your initial commit, you can rerun the test job and it should succeed.

Development notes

Linting

Check for consistent code style by running npm run lint.

Linting is done by ESLint using @comicrelief/eslint-config.

Testing

Run all tests using npm test, or npm run coverage to see test coverage.

Individual test specs can also be run using the mocha script: npm run mocha -- tests/example.spec.ts.

Inside your tests, you can import src modules using the @/src path map, which saves having to write ../../../../src in deep test directories.

Tests are run using ts-node and mocha, and coverage is provided by nyc.

tsconfig.json

There are three tsconfigs:

  • tsconfig-base.json contains our desired compiler options
  • tsconfig-build.json is used to build the package
  • tsconfig.json is used for development (this is what ts-node and VS Code look at)

We need separate configs for building and development. VS Code needs the tests directory to be listed in include in order to resolve path-mapped imports. However, we don't want the tests bundled with the compiled package. The build also shouldn't use type libraries for dev dependencies, such as @types/mocha.

Publish using Semantic Release

This template repo is not set up to publish. Follow the steps below to automate releases with Semantic Release.

  1. In the setup script, say yes to Set up Semantic Release?

  2. Add your npm token to your repo.

    Go to Settings > Secrets > Actions. Create a new secret called NPM_TOKEN.

  3. Configure your repo to use the Squash and Merge strategy.

    The setup script will attempt to do this for you if your Git client is configured to use an auth token over HTTPS.

    Go to Settings > General > Pull Requests and untick Allow merge commits and Allow rebase merging, so that only Allow squash merging is enabled. Also enable Default to PR title for squash merge commits.

If you haven't already done so, make sure you've also protected your main branch. Any commits pushed to this branch will now trigger a release.

About

A starting point for TypeScript CLI projects

Resources

Stars

Watchers

Forks