Contributions are very welcome, these can include documentation, bug reports, issues, feature requests, feature implementations or tutorials.
We have good first issues for new contributors. These are issues that we've identified as good starting points for getting acquainted with our codebase, styleguide or working with Go.
If you have found an issue or defect in cloud-sdk-go
or the latest documentation, use the GitHub issue tracker to report the problem. Make sure to follow the template provided for you to provide all the useful details possible.
For the benefit of all and to maintain consistency, we have come up with some simple guidelines. These will help us collaborate in a more efficient manner.
-
Unless the PR is very small (e.g. fixing a typo), please make sure there is an issue for your PR. If not, make an issue with the provided template first, and explain the context for the change you are proposing.
Your PR will go smoother if the solution is agreed upon before you've spent a lot of time implementing it. We encourage PRs to allow for review and discussion of code changes.
-
We encourage PRs to be kept to a single change. Please don't work on several tasks in a single PR if possible.
-
When you're ready to create a pull request, please be sure to:
-
Adhere to the project's style guide.
-
Make sure you signed the Contributor License Agreement. You only need to sign the CLA once. By signing this agreement, you give us the right to distribute your code without restriction.
-
Have test cases for the new code. If you have questions about how to do this, please ask in your pull request.
-
Run
make format
,make lint
andmake meta-lint
. -
Ensure that unit tests succeed with
make unit
. -
Use the provided PR template, and assign any labels which may fit your PR.
-
There is no need to add reviewers, the code owners will be automatically added to your PR.
-
The codebase is maintained using the "contributor workflow" where everyone without exception contributes patch proposals using "pull requests". This facilitates social contribution, easy testing and peer review.
To contribute a patch, make sure you follow this workflow:
- Fork repository
- Enable GitHub actions to run in your fork
- Create topic branch
- Commit patches
In general commits should be atomic and diffs should be easy to read.
Commit messages should be verbose by default consisting of a short subject line (50 chars max). A blank line and detailed explanatory text as separate paragraph(s), unless the title alone is self-explanatory ("trivial: Fix comment typo in main.go"). Commit messages should be helpful to people reading your code in the future, so explain the reasoning for your decisions. Further explanation here.
If a particular commit references another issue, please add the reference. For example: refs #123 or fixes/closes #1234. Using the fixes or closes keywords will cause the corresponding issue to be closed when the pull request is merged.
Example:
elasticsearch: Remove unnecessary cluster list sorting
Removes the unnecessary sorting on the obtained API response since the
cluster list is already sorted by the backend.
Closes #1234
Pull requests that contain changes on the code base and related documentation, e.g. for a new feature, shall remain a single, atomic one.
The title of the pull request should be prefixed by the package or area that the pull request affects. Any change that affects a package in general must be prefixed by its name. Valid areas as:
- docs: Changes for documentation related to the project
- ci: Changes for the CI build system.
- scripts: Changes that affect ancillary scripts or the Makefile
- trivial: should only be used for PRs that do not change generated executable code. Notably, refactors (change of function arguments and code reorganization) and changes in behaviour should not be marked as trivial. Examples of trivial PRs are changes to comments or variable names.
Example:
elasticsearch: Remove unnecessary cluster list sorting
docs: Improve the contributor documentation
trivial: Fix a couple of typos on elasticsearch.List
If a pull request is not to be considered for merging (yet), please prefix the title with [WIP] or use Tasks Lists in the body of the pull request to indicate tasks are pending.
The body of the pull request should contain a detailed description about what the patch does, along with any justification/reasoning. You should include references to any related discussions (for example other tickets or mailing list discussions).
At this stage one should expect comments and review from other contributors. You can add more commits to your pull request by committing them locally and pushing to your fork until you have satisfied all feedback.
To start off you will need to have Go 1.11 or higher installed. Make sure you also have the environment variables $GOPATH
and $GOBIN
($GOPATH/bin
) defined. If you need assistance with this please follow golangbootcamp guide.
cloud-sdk-go
uses go modules to version dependencies, make sure you've got the GO111MODULE=on
environment variable set to leverage go modules. Running go get
in the root folder will download all the required dependencies.
Due to the way Go handles package imports, the best approach for working on a cloud-sdk-go
fork is to use Git Remotes. Here's a simple walk-through for getting started:
-
Fetch the sources with
go get -d github.com/elastic/cloud-sdk-go
-
Change to the source directory:
cd ${GOPATH}/src/github.com/elastic/cloud-sdk-go
-
Rename the remote to
upstream
:git remote rename origin upstream
-
Fork
cloud-sdk-go
in GitHub. -
Add your fork as a new remote and name it
origin
:# For SSH based credentials git remote add origin git@github.com:USERNAME/cloud-sdk-go.git # For https based credentials git remote add origin https://github.com/USERNAME/cloud-sdk-go
-
Verify your Git remotes with
$ git remote -v
. The result should be something like this:origin git@github.com:USERNAME/cloud-sdk-go.git (fetch) origin git@github.com:USERNAME/cloud-sdk-go.git (push) upstream git@github.com:elastic/cloud-sdk-go (fetch) upstream git@github.com:elastic/cloud-sdk-go (push)
-
Create a new branch for your changes (the branch name is arbitrary):
git checkout -b issue1234
-
After making your changes, commit them to your new branch:
git commit -a -v -s
-
Push the changes to your new remote:
git push --set-upstream origin issue1234
-
You're now ready to submit a PR based upon the new branch in your forked repository.
When a new version of the API specification is released, the local copy of that specification found in api/apidocs.json
needs to be updated and committed as well.
The swagger specification is then used to generate a client and models Go packages and sub-packages. To update the Go auto-generated codebase, make swagger
or make docker-swagger
can be used.
Additionally, a full markdown declaration of API commands will be generated in api/version/$(ECE_VERSION).md
, and pkg/api/version.go
will be generated with the version matching the ECE_VERSION
variable.
The Makefile global variable ECE_VERSION
should be modified before running make swagger
. Make sure you have set the "EC_API_KEY" environment variable locally with your Elasticsearch Service API key. This will allow the API validation tests to run
There's two variables that can be passed to the Makefile target:
TEST_UNIT_FLAGS
args controls the flags that are sent togo test
.TEST_UNIT_PACKAGE
controls which package names to test (defaults to./...
which means all packages).
The current TEST_UNIT_FLAGS
default to: -timeout 10s -p 4 -race -cover
.
In order to run validation tests for our API specification against the live public API, we use the Prism Validation Proxy alongside our custom apivalidator
CLI.
Before you run the tests or use the CLI, make sure you've got the EC_API_KEY
environment variable set, and start the validation proxy by running:
$ export EC_API_KEY=<your-api-key>
$ make validation-proxy
[1:43:49 AM] › [CLI] … awaiting Starting Prism…
[1:43:50 AM] › [CLI] ℹ info GET http://0.0.0.0:4010/deployments
<...>
[1:43:50 AM] › [CLI] ▶ start Prism is listening on http://0.0.0.0:4010
Once the validation proxy is up and running, you can either run the validation testing suite which validates the apidocs-user.json we have on master in cloud-sdk-go by running:
$ make api-validation
Or, you can run the CLI manually if you wish to validate an api specification from another location or from your local directory by using the --source
flag.
$ ./bin/apivalidator --source https://raw.githubusercontent.com/elastic/cloud-sdk-go/v1.0.0-beta3/api/apidocs-user.json
If for some reason you're running the validation proxy on a different port than the default, make sure to use the --port
flag:
$ ./bin/apivalidator --port 4123
For a complete list of all the go test
flags see Testing flags.
For a complete list of all the go build
flags see Compile packages and dependencies.
Flag | Description |
---|---|
-timeout |
controls the max runtime for a set of unit tests in a package. |
-p |
controls the number of package tests to run concurrently. |
-count |
number of times that the unit tests for a package will be run. |
-race |
enables race condition detection during test execution. |
-cover |
displays the test coverage for each package. |
Examples:
$ make unit
-> Running unit tests for cloud-sdk-go...
...
$ make unit TEST_UNIT_PACKAGE=github.com/elastic/cloud-sdk-go/pkg/api
-> Running unit tests for cloud-sdk-go...
ok github.com/elastic/cloud-sdk-go/pkg/api 1.277s coverage: 89.0% of statements