Thank you for considering contributing to this project. It will help to make this project more valuable for the community.
We value any feedback and contributions whether it's a bug report, bugfix, additional feature or documentation. Please read this document before submitting an issue or pull request to ensure that your contributions can be handled effectively.
Please note that this project is in an early stage and we still have to learn how to run an open source project. So please be patient with us.
Please do NOT open an issue if you find a security vulnerability.
Instead send an e-mail to [email protected]
.
In order to determine whether you are dealing with a security issue, ask yourself these two questions:
- Can I access something that's not mine, or something I shouldn't have access to?
- Can I disable something for other people?
If the answer to either of those two questions are "yes", then you're probably dealing with a security issue. Note that even if you answer "no" to both questions, you may still be dealing with a security issue, so if you're unsure, just email us.
You can file bug reports on the issues page.
Please follow the following steps prior to filing a bug report.
-
Search through existing issues to ensure that your specific issue has not yet been reported.
-
Ensure that you have tested the latest version of this SDK. Although you may have an issue against an older version of the SDK, we cannot provide bug fixes for old versions. It's also possible that the bug may have been fixed in the latest release.
When filing an issue, make sure to answer the following questions:
-
What version of the SDK are you using?
-
What operating system are you using?
-
What did you do?
-
What did you expect to see?
-
What did you see instead?
Please be aware of the following notes prior to opening a pull request:
-
This project is released under the license specified in LICENSE. Any code you submit will be released under that license. Furthermore it's likely that we have to reject code which depends on third party code which isn't compatible to the aforementioned license.
-
If you would like to implement support for a significant feature that is not yet available, please talk to us beforehand to avoid any duplication of effort.
-
Wherever possible, pull requests should contain tests as appropriate. Bugfixes should contain tests that exercise the corrected behavior (i.e., the test should fail without the bugfix and pass with it), and new features should be accompanied by tests exercising the feature.
-
Follow the Code Conventions.
-
Pull requests that contain failing tests will not be merged until the test failures are addressed. Pull requests that cause a significant drop in the test coverage percentage are unlikely to be merged until tests have been added.
Please follow the Godoc conventions.
Test should be named following a short form of the well known Given-When-Then style:
Test<Givenpart>_<Functionname>_<Thenpart>
The functionname may be omitted if all tests in a file test the same function:
Test<Givenpart>_<Thenpart>
For example the test
Given the divisor is zero
When divide is invoked
Then DivisionByZeroError should be returned
for a divide
function should be named TestDivisorIsZero_Divide_ReturnsDivsionByZeroError
or
TestDivisorIsZero_ReturnsDivsionByZeroError
.
Use sensible defaults for the creation of API Clients so that the default use case is easy to use and provide functional options to change these defaults.
Don't add dependencies to packages outside the go standard library unless they
- add significant value and
- are stable and well maintained and
- have a compatible license
You have to consider, that you force every consumer of the SDK to include this dependency. So fewer dependencies are better.
Please use the following template for commit messages which is derived from template of the git project:
Short (50 chars or less) summary of changes
More detailed explanatory text, if necessary. Wrap it to
about 72 characters or so. In some contexts, the first
line is treated as the subject of an email and the rest of
the text as the body. The blank line separating the
summary from the body is critical (unless you omit the body
entirely); tools like rebase can get confused if you run
the two together.
Write your commit message in the imperative: "Fix bug" and not "Fixed bug"
or "Fixes bug." This convention matches up with commit messages generated
by commands like git merge and git revert.
Further paragraphs come after blank lines.
- Bullet points are okay, too
- Typically a hyphen or asterisk is used for the bullet, followed by a
single space, with blank lines in between, but conventions vary here