This project provides support for using Spring and Java with AMQP 0.9.1, and in particular RabbitMQ.
Please see our Code of conduct.
Please see our Security policy.
To check out the project from GitHub and build from source using Gradle, do the following:
git clone git://github.com/SpringSource/spring-amqp.git
cd spring-amqp
./gradlew build
If you encounter out of memory errors during the build, increase available heap and permgen for Gradle:
GRADLE_OPTS='-XX:MaxPermSize=1024m -Xmx1024m'
To build and install jars into your local Maven cache:
./gradlew install
To build api Javadoc (results will be in build/api
):
./gradlew api
To build reference documentation (results will be in build/site
):
./gradlew antora
To build complete distribution including -dist
, -docs
, and -schema
zip files (results will be in build/distributions
)
./gradlew dist
To analyze and gather metrics using Sonar:
./gradlew clean build sonar
(Please make sure that you have Sonar running, e.g. on localhost port 9000)
To generate Eclipse metadata (.classpath and .project files), do the following:
./gradlew eclipse
Once complete, you may then import the projects into Eclipse as usual:
File -> Import -> Existing projects into workspace
Browse to the 'spring-amqp' root directory. All projects should import free of errors.
Using the STS Gradle Support, you can directly import Gradle projects, without having to generate Eclipse metadata first. Please see the Spring Tools Home Page.
- Select File -> Import -> Existing Gradle Project
- Browse to the Spring AMQP Root Folder
- Click on Finish
To generate IDEA metadata (.iml and .ipr files), do the following:
./gradlew idea
Lists of issues addressed per release can be found in Github.
Here are some ways for you to get involved in the community:
-
Get involved with the Spring community on Stack Overflow by responding to questions and joining the debate.
-
Create Github issues for bugs and new features and comment and vote on the ones that you are interested in.
-
Github is for social coding: if you want to write code, we encourage contributions through pull requests from forks of this repository. If you want to contribute code this way, please reference the specific Github issue you are addressing.
Before we accept a non-trivial patch or pull request we will need you to sign the contributor's agreement. Signing the contributor's agreement does not grant anyone commit rights to the main repository, but it does mean that we can accept your contributions, and you will get an author credit if we do. Active contributors might be asked to join the core team, and given the ability to merge pull requests.
None of these is essential for a pull request, but they will all help. They can also be added after the original pull request but before a merge.
- Use the Spring Framework code format conventions (import
eclipse-code-formatter.xml
from the root of the project if you are using Eclipse). - Make sure all new .java files to have a simple Javadoc class comment with at least an @author tag identifying you, and preferably at least a paragraph on what the class is for.
- Add the ASF license header comment to all new .java files (copy from existing files in the project)
- Add yourself as an @author to the .java files that you modify substantially (more than cosmetic changes).
- Add some Javadocs and, if you change the namespace, some XSD doc elements.
- A few unit tests would help a lot as well - someone has to do it.
- If no-one else is using your branch, please rebase it against the current main (or other target branch in the main project).
Spring AMQP is released under the terms of the Apache Software License Version 2.0 (see LICENSE.txt).