diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index db5b0d23..e9f9f663 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -6,24 +6,30 @@ All types of contributions are encouraged and valued. See the [Table of Contents > And if you like the project, but just don't have time to contribute, that's fine. There are other easy ways to support the project and show your appreciation, which we would also be very happy about: -> - Join the [Discord community](https://discord.gg/yyKns29zch) > - Star the project -> - Tweet about it > - Refer this project in your project's readme > - Mention the project at local meetups and tell your friends/colleagues +> - Share the project on forums or social medias +> - Join the [Discord community](https://discord.gg/yyKns29zch) ## Table of Contents +- [Code of conduct](#code-of-conduct) - [I Have a Question](#i-have-a-question) - [I Want To Contribute](#i-want-to-contribute) - [Reporting Bugs](#reporting-bugs) - [Suggesting Enhancements](#suggesting-enhancements) - - [Your First Code Contribution](#your-first-code-contribution) - - [Improving The Documentation](#improving-the-documentation) -- [Styleguides](#styleguides) + - [Submitting a Pull Request](#submitting-a-pull-request) + - [Working With The Code](#working-with-the-code) +- [Coding Rules](#coding-rules) + - [Source Code](#source-code) - [Commit Messages](#commit-messages) - [Join The Project Team](#join-the-project-team) +## Code of Conduct + +Help us keep `cron` open and inclusive. Please read and follow our [Code of conduct](CODE_OF_CONDUCT.md). + ## I Have a Question > If you want to ask a question, we assume that you have read the available [Documentation](https://github.com/kelektiv/node-cron#readme). @@ -67,8 +73,8 @@ We use GitHub issues to track bugs and errors. If you run into an issue with the Once it's filed: - The project team will label the issue accordingly. -- A team member will try to reproduce the issue with your provided steps. If there are no reproduction steps or no obvious way to reproduce the issue, the team will ask you for those steps and mark the issue as `needs-repro`. Bugs with the `needs-repro` tag will not be addressed until they are reproduced. -- If the team is able to reproduce the issue, it will be marked `needs-fix`, as well as possibly other tags (such as `critical`), and the issue will be left to be [implemented by someone](#your-first-code-contribution). +- A team member will try to reproduce the issue with your provided steps. If there are no reproduction steps or no obvious way to reproduce the issue, the team will ask you for those steps and mark the issue as `cannot reproduce`. Bugs with the `cannot reproduce` tag will not be addressed until they are reproduced. +- If the team is able to reproduce the issue, it will be marked `bug`, as well as possibly other tags, and the issue will be left to be [implemented by someone](#your-first-code-contribution). ### Suggesting Enhancements @@ -91,24 +97,121 @@ Enhancement suggestions are tracked as [GitHub issues](https://github.com/kelekt - **Describe the current behavior** and **explain which behavior you expected to see instead** and why. At this point you can also tell which alternatives do not work for you. - **Explain why this enhancement would be useful** to most cron users. You may also want to point out the other projects that solved it better and which could serve as inspiration. -## Working with the code +### Submitting a Pull Request + +Good pull requests, whether patches, improvements, or new features, are a fantastic help. +They should remain focused in scope and avoid containing unrelated commits. + +**Please ask first** before embarking on any significant pull requests (e.g. implementing features, refactoring code), otherwise you risk spending a lot of time working on something that the project's maintainers might not want to merge into the project. + +For ambitious tasks, open a [**draft** Pull Request](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/changing-the-stage-of-a-pull-request#converting-a-pull-request-to-a-draft) as soon as possible, in order to get feedback and help from the maintainers and the community. + +If you have never created a pull request before, welcome 🎉 😄. +[Here is a great tutorial](https://opensource.guide/how-to-contribute/#opening-a-pull-request) on how to send one :) + +Here is a summary of the steps to follow: + +1. [Set up the workspace](#set-up-the-workspace) +2. If you cloned a while ago, get the latest changes from upstream and update dependencies: + +```bash +$ git checkout main +$ git pull upstream main +$ rm -rf node_modules +$ nvm use +$ npm install +``` + +3. Create a new topic branch (off the main project development branch) to contain your feature, change, or fix: + +```bash +$ git checkout -b +``` + +4. Make your code changes, following the [Coding Rules](#coding-rules) +5. Push your topic branch up to your fork: + +```bash +$ git push origin +``` + +6. [Open a Pull Request](https://help.github.com/articles/creating-a-pull-request/#creating-the-pull-request) with a clear title and description. + +#### Do not force push to your pull request branch + +Please do not force push to your PR's branch after you have created your PR, as doing so forces us to review the whole PR again. +This makes it harder for us to review your work because we don't know what has changed. +PRs will always be squashed by us when we merge your work. +Commit as many times as you need in your pull request branch, but please batch apply review suggestions. + +If you're updating your PR branch from within the GitHub PR interface, use the default "Update branch" button. +This is the "Update with merge commit" option in the dropdown. + +Force pushing a PR, or using the "Update with rebase" button is OK when you: + +- make large changes on a PR which require a full review anyway +- bring the branch up-to-date with the target branch and incorporating the changes is more work than to create a new PR + +#### Apply maintainer provided review suggestions + +Maintainers can suggest changes while reviewing your pull request. +To apply these suggestions, please: + +1. Batch the suggestions into a logical group by selecting the **Add suggestion to batch** button +1. Select the **Commit suggestions** button + +Read the [GitHub docs, Applying suggested changes](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/incorporating-feedback-in-your-pull-request#applying-suggested-changes) to learn more. + +#### Resolve review comments instead of commenting + +A maintainer can ask you to make changes, without giving you a _suggestion_ that you can apply. +In this case you should make the necessary changes. + +Once you've done the work, resolve the conversation by selecting the **Resolve conversation** button in the PR overview. +Avoid posting comments like "I've done the work", or "Done". + +Read the [GitHub Docs, resolving conversations](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/commenting-on-a-pull-request#resolving-conversations) to learn more. + +#### Re-requesting a review + +Please do not ping your reviewer(s) by mentioning them in a new comment. +Instead, use the re-request review functionality. +Read more about this in the [GitHub docs, Re-requesting a review](https://docs.github.com/en/free-pro-team@latest/github/collaborating-with-issues-and-pull-requests/incorporating-feedback-in-your-pull-request#re-requesting-a-review). + +#### Discord collaboration with maintainers + +The codebase can be difficult to navigate, especially for a first-time contributor. +We don't want you spending an hour trying to work out something that would take us only a minute to explain. + +For that reason, you'll find a `#development` channel on our [Discord community](https://discord.gg/yyKns29zch), +dedicated to helping anyone who's working on or considering Pull Requests for `cron`. + +### Working With The Code -### Set up the workspace +#### Set up the workspace [Fork](https://docs.github.com/en/get-started/quickstart/contributing-to-projects#forking-a-repository) the project, [clone](https://docs.github.com/en/get-started/quickstart/contributing-to-projects#cloning-a-fork) your fork, configure the remotes and install the dependencies: ```bash # Clone your fork of the repo into the current directory $ git clone git@github.com:/node-cron.git # or https://github.com//node-cron.git for HTTPS + # Navigate to the newly cloned directory $ cd node-cron + # Assign the original repo to a remote called "upstream" $ git remote add upstream git@github.com:kelektiv/node-cron.git # or https://github.com/kelektiv/node-cron.git for HTTPS + +# Switch your node version to the version defined by the project as the development version +# This step assumes you have already installed and configured https://github.com/nvm-sh/nvm +# You may need to run `nvm install` if you have not already installed the development node version +$ nvm use + # Install the dependencies $ npm install ``` -### Lint +#### Lint This repository uses [ESLint](https://eslint.org) and [Prettier](https://prettier.io) for linting and formatting. @@ -119,7 +222,7 @@ Before pushing your code changes make sure there are no linting errors with `npm - Most linting errors can be automatically fixed with `npm run lint:fix`. - Install the [ESLint plugin](https://eslint.org/docs/latest/use/integrations) for your editor to see linting errors directly in your editor and automatically fix them on save. -### Tests +#### Tests This repository uses [Jest](https://jestjs.io) for writing and running tests. @@ -129,17 +232,121 @@ Before pushing your code changes make sure all **tests pass** and the **coverage $ npm run test ``` -**Tips:** During development you can: +**Tips:** - run a single test file with `npm run test -- `, for example `npm run test -- tests/crontime.test.ts` - run a subset of test files with `npm run test -- `, for example `npm run test -- tests/*.test.ts` - run a single test case with `npm run test -- -t ''`, for example `npm run test -- -t 'should parse .*'` - run in watch mode with `npm run test:watch` to automatically run a test case when you modify it or the associated source code (above tips also work with this command) +## Coding Rules + +### Source Code + +To ensure consistency and quality throughout the source code, all code modifications must have: + +- No [linting](#lint) errors +- A [test](#tests) for every possible case introduced by your code change +- [Valid commit message(s)](#commit-messages) +- Documentation for new features +- Updated documentation for modified features + +### Commit Messages + +#### Atomic commits + +If possible, make [atomic commits](https://en.wikipedia.org/wiki/Atomic_commit), which means: + +- a commit should contain exactly one self-contained functional change +- a functional change should be contained in exactly one commit +- a commit should not create an inconsistent state (such as test errors, linting errors, partial fix, feature without documentation, etc...) + +A complex feature can be broken down into multiple commits as long as each one maintains a consistent state and consists of a self-contained change. + +#### Commit message format + +Each commit message consists of a **header**, a **body** and a **footer**. +The header has a special format that includes a **type**, a **scope** and a **subject**: + +```commit +(): + + + +