Please consider asking questions in help networks like
StackOverflow using the label spotify-web-api-java
.
Posting your question there will result in quick and helpful answers.
Issues should only be used to file bug reports and ask questions that are targeted specifically at this project's source code.
Every constructive contribution is highly appreciated. They help to keep this project up-to-date and running, especially because currently only voluntary maintainers and contributors take care of this repository.
At the same time it is strongly recommended to follow certain guidelines when making contributions to open source projects like this one. They ensure fast processing times and stable releases.
It is mandatory to stay as close to the Web API Endpoint Reference as possible. Before changing anything in the code base, make sure to take one - or more - looks into related files/classes and the project's documentation. The whole code follows simple and consistent code conventions for naming rules and alike. Those should be easy to grasp by comparing to the online developer's reference mentioned above. If not: feel free to just ask. It saves your time to be in the clear about those conventions before starting to contribute as it significantly lowers the probability to receive change requests from maintainers and thereby the time one has to wait for merges.
Issues that do not provide enough information, that are unclear or not understandable will be closed until more qualitative information is provided.
A contribution has to be complete to get accepted. If you cannot complete the requirements, you're welcome to ask for help. But bear in mind that this can take its time.
A complete contribution includes the following features:
Make sure that your contribution embeds well into the already existing code. For example, the unified folder/package structure must be used wherever possible.
Document your source code! It's easy because one can most likely just stick to the online API reference. This is a requirement. Not because your contributed source code is unreadable. Instead, the aim is to keep the Javadoc complete and - accompanying this - to keep this project as accessible as possible to developers like yourself.
Unit tests help to assure that functionality works. Due to that contribution approval requires them to be included for feature additions or altered for feature changes. A unit test must check all top-level properties of a JSON fixture, none below. For arrays the length is to be checked.
A unit test builds upon JSON fixtures. For code changes, fixture files must only be updated when...
- the online examples change
- the online examples are outdated, compared against the reference description and/or the Web API Object Model.
- Create a fork from this repository
- Create a branch in your fork in which you develop your contribution (one branch per feature/fix)
- Create meaningful and well-separated commits
- Make sure your contribution follows the contribution guidelines above
- Create a pull request from your feature branch to the correct branch of this project