This documentation is for an unreleased version of Apache Paimon. We recommend you use the latest stable version.
Contributing #
Apache Paimon is developed by an open and friendly community. Everybody is cordially welcome to join the community and contribute to Apache Paimon. There are several ways to interact with the community and contribute to Paimon including asking questions, filing bug reports, proposing new features, joining discussions on the mailing lists, contributing code or documentation, improving website, testing release candidates and writing corresponding blog etc.
What do you want to do? #
Contributing to Apache Paimon goes beyond writing code for the project. Below, we list different opportunities to help the project:
Area | Further information |
---|---|
Report Bug | To report a problem with Paimon, open Paimon’s issues. Please give detailed information about the problem you encountered and, if possible, add a description that helps to reproduce the problem. |
Contribute Code | Read the Code Contribution Guide |
Code Reviews | Read the Code Review Guide |
Release Version | Releasing a new Paimon version. |
Support Users | Reply to questions on the user mailing list, check the latest issues in Issues for tickets which are actually user questions. |
Spread the Word About Paimon | Organize or attend a Paimon Meetup, contribute to the Paimon blog, share your conference, meetup or blog post on the dev@paimon.apache.org mailing list. |
Any other question? Reach out to the dev@paimon.apache.org mailing list to get help! |
Code Contribution Guide #
Apache Paimon is maintained, improved, and extended by code contributions of volunteers. We welcome contributions to Paimon.
Please feel free to ask questions at any time. Either send a mail to the Dev mailing list or comment on the issue you are working on.
1Discuss
Create an Issue or mailing list discussion and reach consensus
To request an issue, please note that it is not just a "please assign it to me", you need to explain your understanding of the issue, and your design, and if possible, you need to provide your POC code.
2Implement
Create the Pull Request and the approach agreed upon in the issue.
1.Only create the PR if you are assigned to the issue. 2.Please associate an issue (if any), e.g. fix #123. 3.Please enable the actions of your own clone project.
3Review
Work with the reviewer.
1.Make sure no unrelated or unnecessary reformatting changes are included. 2.Please ensure that the test passing. 3.Please don't resolve conversation.
4Merge
A committer of Paimon checks if the contribution fulfills the requirements and merges the code to the codebase.
Code Review Guide #
Every review needs to check the following six aspects. We encourage to check these aspects in order, to avoid spending time on detailed code quality reviews when formal requirements are not met or there is no consensus in the community to accept the change.
1. Is the Contribution Well-Described? #
Check whether the contribution is sufficiently well-described to support a good review. Trivial changes and fixes do not need a long description. If the implementation is exactly according to a prior discussion on issue or the development mailing list, only a short reference to that discussion is needed.
If the implementation is different from the agreed approach in the consensus discussion, a detailed description of the implementation is required for any further review of the contribution.
2. Does the Contribution Need Attention from some Specific Committers? #
Some changes require attention and approval from specific committers.
If the pull request needs specific attention, one of the tagged committers/contributors should give the final approval.
3. Is the Overall Code Quality Good, Meeting Standard we Want to Maintain in Paimon? #
- Does the code follow the right software engineering practices? Is the code correct, robust, maintainable, testable?
- Are the changes performance aware, when changing a performance sensitive part?
- Are the changes sufficiently covered by tests? Are the tests executing fast?
- If dependencies have been changed, were the NOTICE files updated?
Code guidelines can be found in the Flink Java Code Style and Quality Guide.
4. Are the documentation updated? #
If the pull request introduces a new feature, the feature should be documented.
Become a Committer #
When you have made enough contributions, you can be nominated as Paimon’s Committer. See Committer.