Please read our Vision Statement. The reason for each task should ultimately come back to this statement.
Each contributor should be knowledgeable and proficient at the following projects and technologies.
- Spring Batch
- Spring Framework
- Gradle
- MarkLogic Java Client API
- MarkLogic Java Client Util
- MarkLogic JUnit Library
- MarkLogic App Deployer
- Git
- MarkLogic 8+
- Java Development Kit 1.8+
- Recommended: Gradle 2.+
You will need to first install MarkLogic if you haven't already. It is recommended to use a virtual machine or remote server to run MarkLogic to partition our resources (MarkLogic likes to use a lot of memory).
We use a fork-and-Branch Git workflow. The dev branch contains the latest and greatest code, while master represents the latest published version. Always branch from DEV.
Review the jobs/gradle.properties file to make sure that your host, port, username, and password are correct for your environment. Do not check your local version of gradle.properties.
Yes, it is recommended to use a Java friendly IDE to make one's life easier. Of course, you can use a simple text editor if that is your preference. The lead authors have a recent preference for IntelliJ. We also use Gradle for our swiss army knife of building, testing, deploying, etc. One of the cool features of Gradle is the ability to create the project files for two popular IDE's, IntelliJ and Eclipse.
./gradlew idea
./gradlew eclipse
The gradlew (or gradlew.bat on Windows) command is a Java program called the Gradle Wrapper which allows you to run a gradle command without installing Gradle on your machine. If you plan to contribute (or do any type of Java development) it would be worth while to go ahead and install Gradle on your dev machine.
Once you have cloned the project locally execute the test cases. Gradle will handle downloading any dependencies that you need for this effort.
gradlew testAll
It is our policy that the dev branch tests always are 100% passing. If all tests run to completion and 100% passing then you are ready to start coding.
If you are new to the project the best way to contribute is to add a Job to the job library. Choose of the job issues to get started on an assignment. If you have an example of a unique batch processing job then it would be a good idea to add it to the examples project.
There are three sub-projects for MarkLogic Spring Batch. Most contributions will be in the examples and jobs projects where the core work would be for those intimately familiar with the Spring Batch code baseline.
- examples are the recipes for creating your own batch processing jobs (i.e. migrating from a RDBMS). Developers should use these as templates and guidelines for writing their own MarkLogic batch processing jobs.
- jobs are a library of common MarkLogic batch processing jobs to import, export, and transform.
- core contains all enhancements on the Spring Batch framework. This includes the jobs utility, the MarkLogic Job Repository, and any custom ItemReaders/Processors/Writers and tasklets.
The quality of this project is based on the tests that exercise the code. Every issue worked should be accompanied by one or more tests that test the primary use case and several edge cases. Code that is submitted without any accompanied tests will not be accepted. Before submitting a pull request, run the test suite and confirm 100% test passing with the following gradle command.
./gradlew test
To deploy the marklogic-spring-batch core and jobs library to your local maven repository, first, increment the relevant version number in the gradle.properties file.
It is advised to first publish artifacts to the local maven repository and run local tests before publishing out to bintray
gradle publishToMavenLocal
Once you have verified your version then run the following command to publish to bintray (authoritative personnel only)
gradle bintrayUpload
To deploy the MarkLogic Spring Batch command line program, execute the following gradle command
gradle distZip
This will create the distribution archive file under ./jobs/build/distribution/jobs.zip. This can then be uploaded to the distribution website.
Open an issue and label it as a Question. Please don't use email. This is the best way to ask once and answer for all. If you are a MarkLogic employee, I recommend that you subscribe to the java-sig email newsgroup.
Bugs are tracked as GitHub issues. Create an issue, label it as a bug.
Once you are assigned an issue, please utilize pull requests to submit your changes. Each pull request will be reviewed before being merged into the master branch.
Seven rules of a great git commit message
- Separate subject from body with a blank line
- Limit the subject line to 50 characters
- Capitalize the subject line
- Do not end the subject line with a period
- Use the imperative mood in the subject line
- Wrap the body at 72 characters
- Use the body to explain what and why vs. how