This guide explains how to publish the package into PyPi: https://pypi.org/project/elastic-agent-client/.
For now we'll stick with a simple strategy of having 0.1.0
release and then bump patch versions: 0.1.1
, 0.1.2
, 0.1.3
and so on. Once we feel package is ready for proper public release we will choose a versioning strategy similar to other Elastic products and will stick to it.
You will need vault
CLI tools installed or have access to a web version. You need to have permissions to access the keys - if you don't please reach out to the team lead.
Secrets for publishing to live PyPi are in ent-search-team/pypi-ent-search-dev
, secrets for publishing to test version are in ent-search-team/test-pypi-ent-search-dev
.
- First make sure that the version of the package (see https://github.com/elastic/python-elastic-agent-client/blob/main/elastic_agent_client/version.py) is correct and is the desired version number
- Verify that all linting and tests pass:
make lint test
- Verify that protobuf files are up-to-date:
make generate
and thengit diff
to see the changes. If any changes are present, first merge them into the branch published before continuing - Do a test publish:
make test-release
. When prompted for an api key, insert a key from running this command:vault read -field publishing-api-key secret/ent-search-team/test-pypi-ent-search-dev
- Check the package on https://test.pypi.org/project/elastic-agent-client - check readme, version, other things that you consider important
- Do a prod publish:
make release
. When prompted for an api key, insert a key from running this command:vault read -field publishing-api-key secret/ent-search-team/pypi-ent-search-dev
- Check the package on https://pypi.org/project/elastic-agent-client - check readme, version, other things that you consider important
- Tag the revision that was used for release and push the tag:
git tag <version> <sha> && git push origin tag <version>
, for examplegit tag v0.0.1dev2 ab69e812aabea460439740199a9a94df88cd2a6e && git push origin tag v0.0.1dev2
- Done!