Check out ways to contribute to this project...
When you have an idea on how we could improve, please check our
discussions to see if there are similar ideas or
feature requests. You can also check if your idea is not already planned in the
roadmap. If there are none, please
start your feature request as a new discussion
topic. Add the title [Feature Request] My awesome feature
and a description of what you expect from the improvement
and what the use case is.
If you think you have found a bug, first make sure that you are testing against the latest version of the project. If not, maybe your issue has already been fixed in a more recent version. Otherwise, search our issues list on GitHub if a similar issue has not already been opened. If you didn't find an existing similar issue, feel free to create a new one respecting the following recommendations:
- Provide a quick summary of the problem.
- Prepare a reproduction of the bug by preparing a simple test case we can run to reproduce your bug. It will be helpful to find and fix the problem.
- Describe the result you expected.
- Don't hesitate to provide as much information as you can. Often, the devil is in the detail!
Help out the whole community by sending your pull requests. Check out how to set it up:
To contribute to this project, you will need to fork its repository and clone it to your local machine. See GitHub help page for help.
The command to type in order to clone the forked repository to your local machine should be:
git clone https://github.com/{your username}/cassandra-jdbc-wrapper.git
Once you cloned the repository to your local machine, open the project in your favorite IDE.
To build the project, execute the following command:
mvn clean install -DskipTests
To run the tests, execute the following command:
mvn test
Regarding the tests, you need Docker installed on your machine. Indeed, most of the tests in this project are based on Testcontainers for Cassandra, because testing a JDBC API implementation requires ensuring that the driver is able to connect to a database and execute queries correctly. For example, very common JDBC drivers like those for PostgreSQL or MS SQL Server are also tested against a real database.
Once your changes and tests are ready for review, submit them:
-
Be sure that your changes are tested.
-
Check your code is documented enough and is compliant with the provided Checkstyle rules (you can use an IDE plugin to verify it or simply run
mvn clean install
and check the logs). -
Rebase your changes: update your local repository with the most recent code from the original repository, and rebase your branch on top of the latest
release/next
branch. It is better that your initial changes are squashed into a single commit. If more changes are required to validate the pull request, we invite you to add them as separate commits. -
Finally, push your local changes to your forked repository and submit a pull request into the branch
release/next
with a title which sums up the changes that you have made (try to not exceed 50 characters), and provide more details in the body. If necessary, also mention the number of the issue solved by your changes, e.g. "Closes #123".
As previously stated, this project comes with a set of Checkstyle rules and an .editorconfig
file to ease the respect
of some basic formatting rules. We invite you to follow them when you contribute to this project.
Please find here some of the main coding guidelines:
- Java indent is 4 whitespaces.
- Maximal line length is 120 characters.
- The trailing whitespaces must be trimmed.
- Respect the standard Java naming conventions.
- Wildcards imports (e.g. import com.foo.bar.*) and redundant ones are forbidden.
- Empty catch blocks aren't allowed.
- Left braces are located at the end of the line.
- Braces are mandatory around conditional and loops blocks.
- Don't write more than one statement by line.
Good Javadoc can help with navigating and understanding code. That's why we provide here some guidelines to write Javadoc for this project.
- Always add Javadoc to new code.
- Javadoc must explain the purpose of a feature/function/class (the "why"), not the "how" (i.e. the implementation itself), except if it is really helpful for the understanding of the "why".
- All the public classes and methods must be documented.
- Use
@link
and@see
to add references, either to related resources in the codebase or to relevant external resources.
If your changes require to add a new dependency or update an existing one, be sure to check these points first of all:
- the dependency is the latest stable version of the library compatible with JDK 8
- the dependency does not introduce vulnerabilities
- the version of the dependency is specified in a property
<artifactId>.version
inpom.xml
.
This project is distributed under Apache License 2.0. The license headers are required on all the Java files. So, all contributed code should have the following license header:
/*
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/