Skip to content

Latest commit

 

History

History
40 lines (23 loc) · 3.31 KB

CONTRIBUTING.md

File metadata and controls

40 lines (23 loc) · 3.31 KB

Contributing to KafkaJS

Thank you for considering contributing to KafkaJS!

Reading and following these guidelines will help us make the contribution process easy and effective for everyone involved. It also communicates that you agree to respect the time of the developers managing and developing these open source projects.

Getting Started

Contributions are made to this repo via Issues and Pull Requests (PRs). A few general guidelines that cover both:

  • Search for existing issues and PRs before creating your own.
  • The maintainers of KafkaJS are people that volunteer their time. We try to address issues and PRs in a timely manner, but cannot make any guarantees. Please don't @mention individual maintainers to try to get their attention.

Issues

Issues should be used to report problems with the library, request a new feature, or to discuss potential changes before a PR is created. Please follow the issue template that's provided when you first create an issue in order to collect all the necessary information.

Issues are not a support channel. Please use StackOverflow, Slack or other online resources instead. Limited support from a maintainer is available to sponsors.

If you find an issue that addresses the problem you're having, please add your own reproduction information to the existing issue rather than creating a new one. Adding a reaction can also help be indicating to our maintainers that a particular problem is affecting more than just the reporter.

Pull Requests

PRs are welcome and can be a quick way to get your fix or improvement out. If you've never contributed before, see the contribution guidelines on our website for practical information on how to get started.

In general, PRs should:

  • Only fix/add the functionality in question OR address wide-spread whitespace/style issues, not both.
  • Add tests for fixed or changed functionality.
  • Address a single concern.
  • Update the Typescript type definitions if your change introduces any new or affects existing interfaces.
  • Include documentation if it changes the functionality of the library. Our documentation is in the /docs folder of the repo.

If your PR introduces a change in functionality or adds new functionality, always open an issue first to discuss your proposal before implementing it. This is especially crucial for breaking changes, which will almost always be rejected unless discussed first. For bug fixes this is not required, but still recommended.

Once a PR is merged and the master build is successful, a pre-release version of KafkaJS will be published to NPM in the beta channel, which you can use until a there has been a stable release made containing your change.

Getting Help

Join our Slack community if you have questions about the contribution process or otherwise want to get in touch.