We welcome contributions to Concordion extensions. This document lists the guidelines for contributing.
Firstly, you should create an issue for your enhancement request. You may also want to discuss the change with the concordion-dev list before implementation.
New feature proposals should be described with acceptance tests. For features not yet implemented, please add the @Unimplemented
annotation.
Concordion uses a "Fork & Pull" model for collaborative development. If you have changes that you would like us to consider for introduction to Concordion, you will need to:
- fork the repository,
- commit and push your changes to your forked project, and
- send us a pull request referencing the URL of the issue that you created.
- Don't break existing behaviour. Backward compatibility is extremely important.
- New feature proposals should be described with acceptance tests and discussed with the concordion-dev list before implementation.
- Follow the style and conventions of the existing code (basically Sun's conventions). In particular:
- Use 4 spaces (not tabs)
- Line width of 120 characters
- Always use braces after "if" statements.
- All code changes should have automated tests of some sort.
- Never check a failing test into the repository. (Though you can check-in unimplemented acceptance test HTML for new feature ideas).
This project ships with the Gradle wrapper.
Useful tasks include:
./gradlew clean test
- to compile all and run all tests (Concordion output is written to ./build/reports/spec)
./gradlew install
- to build the jar file and install to the local Maven repository. (For reference on how to use the Maven local repository in a Gradle project, see the dev.gradle
file in the concordion-screenshot-extension-demo project).
./gradlew tasks
- to list all tasks