Skip to main content

Contributing

We always welcome your contribution! This document provides how to contribute to cli-kintone.

Code of Conduct

Before starting contribution, please see Code of Conduct first.

Supporting resources

If you have any questions or feedbacks, you can check our supporting resources.

Issues

We use GitHub Issues for bug reports and feature requests.

Before submitting an Issue, please make sure that there is no related Issue already.

When creating an Issue, be sure to fill out the Issue template. Especially, a minimum reproduction is really important to fix a bug and directly lead to faster triage.

Pull Requests

If you are going to make a PR contribution, please make sure that a corresponding Issue exist first. In addition, we encourage you to make a proposal in the Issue before starting implementation.

Development

Setup repository

Node.js should be configured.

Clone and move into the repository

git clone git@github.com:kintone/cli-kintone.git
cd cli-kintone

Install dependencies

corepack enable
pnpm install

Run build command to check if the repository is ready.

pnpm build

Build

Currently, we have different build processes for the npm package and executables.

To build both of them, run build:all command:

pnpm build:all

Build npm package

Run build command:

pnpm build

To build in watch mode, run start command:

pnpm start

To check behavior, run the entrypoint file directly:

./cli.js

Build executables

Run build:artifacts command:

pnpm build:artifacts

Executables will be generated in bin directory.

bin
├── cli-kintone-linux
├── cli-kintone-macos
└── cli-kintone-win.exe

Testing

We have two kinds of tests, unit tests and E2E tests.

Unit tests

When you change implementation, corresponding unit tests must be added or updated.

Unit tests are located in the __tests__ directory next to the test target code.

Please read Jest document to know how to write unit tests.

You can run unit tests using test command:

pnpm test
note

We also run tests on CI, so local execution is optional.

E2E tests

E2E testing is based on practical scenarios. We use Cucumber.

All of our E2E tests are located in features directory of repository root.

You can run E2E tests using test:e2e command:

pnpm test:e2e

Unfortunately, an actual kintone environment with API access is required to run E2E tests. Therefore, we recommend to run on CI.

Documentation website

The documentation website (this website!) must be updated in the same PR.

Edit files in website/docs to update documents.

To preview changes on local, run doc:start command:

pnpm doc:start

Linting

Before commit your work, please run lint command:

pnpm lint

You can run auto-fix with fix command:

pnpm fix

Stability

We define the Stability Index to indicate stability of features.

For experimental/deprecated features, please add admonitions on docs and show warnings on CLI.

Admonitions

To add admonitions, use experimental or deprecated admonition type.

:::experimental[Title]

Body

:::

Body

:::deprecated[Title]

Body

:::
Deprecated: Title

Body

CLI Warnings

To show warnings on CLI, use helper functions.

emitExperimentalWarning("This feature is under early development.");
emitDeprecationWarning(
"This feature has been deprecated.\nUse new option instead.",
);

Commit

The commit message must follow the Conventional Commits.

<type>: <description>

We support the following commit types:

TypeDescription
featNew features
fixBug fixes
testTest updates
buildChanges on build process
ciChanges on CI workflows
docsDocument updates
perfPerformance improvements
refactorRefactoring
revertReverting past changes
lintLint updates
styleStyle updates
debugDebugs
choreAny other chores
warning

Must not merge debug commit to the main branch.

If the commit will change the backward compatibility, please mark the commit as a Breaking Change.

  • Add ! just after the scope
  • Add BREAKING CHANGE: <description> footer
    • The description should be a short clear summary of user impact.

Creating a Pull Request

When everything is ready, make a Pull Request on GitHub.

The PR title must also follow the Conventional Commits. The title will be used as the commit message of squash commit on merging. It will also be used on CHANGELOG, so make sure to be understandable for users.

Finally, don't forget to fill out the PR body following the template.

Releasing

We use Release Please to create a release and update CHANGELOG.

Merging a Release PR will trigger the release. Please check CHANGELOG and release version before merge.

Release frequency

Normally, maintainer will trigger a release weekly.

Versioning

We follow the Semantic Versioning.

For more details, see Versioning Policy page.