In this effort, we intend to build a formal release process for the Conjur OSS Suite, which we define as the set of components including the Conjur server, deployment utilities, command line interface (CLI), client libraries, and integrations with platforms and DevOps tools.
At current, we have no formal process for releasing the full suite of tools in the Conjur Open Source ecosystem so that:
- It is clear to end users which version of Conjur Open Source they should use, and what integrations and tooling are compatible with that version.
- Key use cases that involve more than two components working together are automatically tested to ensure that the end-to-end experience in those use cases works as expected.
- Development can continue on the master branch of individual components while end users have a reliable way to pull "stable" releases for all components and avoid unexpectedly running "edge" releases .
- It is clear what features are officially released and which are still in progress - at current, there is no way to easily track unreleased features in our broad suite of tools and integrations, and formally creating a system for tracking unreleased features will help us to do a better job of comprehensively testing and releasing completed features.
In this effort, we will build a formal Conjur OSS Suite Release process to begin addressing these concerns.
There is an initial Conjur OSS Suite Release that validates compatibility of the included components. In addition, the infrastructure and tooling exists for creating future OSS Suite Releases that may include additional automated tests and components.
- All key components of the Conjur OSS Suite will be grouped into a single Conjur OSS Suite Release.
- There is a special release repository
that is used to:
- Pin the versions of the components included in the suite release.
- Add test case for end-to-end flows involving components of the OSS suite.
- Automatically run test suite each day against component versions pinned in the suite release.
- When the pinned component versions are changed and the suite version is
incremented:
- Automatically generate GitHub releases that include release notes with links to artifacts.
- Automatically generate a documentation-friendly release page that includes a table of contents, release notes for each component, and links to artifacts.
- Document how end users should utilize the Conjur OSS Suite Release.
In addition, as part of building this release, we'll also be creating:
- A GitHub landing page that links to the repos included in the Conjur OSS Suite and describes what each one does.
- A template to be added to the READMEs of repos in the Conjur OSS Suite to clarify about the state of the code on master ("edge") and to encourage end users to visit the Conjur OSS Suite Release to determine which versions of each product to use.
- A tool for identifying the unreleased changes in the components of the Conjur OSS Suite Release, to help us in understanding whether a new OSS Suite Release is needed.
- Conjur Open Source Core
- Conjur Core
- Conjur CLI
- Client Libraries
- Integrations
- Secrets Delivery
At current, when a new Conjur Enterprise appliance is built it is based on a manually pinned version of Conjur Open Source. We propose implementing automation as part of this release to auto-update the pinned version of Conjur Open Source used in Conjur Enterprise with each new OSS Suite Release, so that Conjur Enterprise stays consistent with the latest stable release of Conjur Open Source.
- Including any other public repositories beyond those listed above in the initial Conjur OSS Suite Release or on the GitHub landing page.
- Creating a landing page with any functionality beyond a curated list of Conjur OSS Suite repositories, with descriptions and links.
- Implementing more than the framework for end-to-end tests and a very basic initial end-to-end test for the Conjur OSS Suite. For more comprehensive test coverage, we will continue to rely on the integration tests written in the individual components, and in future efforts we will review their comprehensiveness and determine potential improvements / ways to leverage the central Conjur OSS Suite Release repo.
- Automatically including deprecated versions of components during temporary deprecation windows.
- Plans for addressing security vulnerabilities in collaboration with downstream projects.
- Augmenting landing page to have an easy way to submit a GitHub issue and be directed to the right repo's backlog.
- Creating a template for the user-facing READMEs of the component repos beyond just directing them to the OSS suite (eg what basic info should always be included in the GitHub READMEs, which by custom in open source contains basic usage info).
- Published contributor guidelines are available in a central place in GitHub.
- Enable running the integration test suites in the individual components using versions explicitly from the OSS suite release.
- Adding use case flows to the conjur.org documentation and to the automated end-to-end tests in the open source release.
- Deeply evaluate the automated unit and integration test coverage in the OSS suite components.
- Add support for deprecating components, and potentially supporting multiple versions during the deprecation period.
As a | Conjur Open Source user |
I want | to know what tools and integrations there are for Conjur |
so that | I can evaluate whether Conjur is suitable for me to use, and which tools / integrations are compatible with my systems. |
As a | Conjur Open Source user |
I want | to know what versions of Conjur Open Source components to use |
so that | I am using reliable, well-tested software that works together as expected when used within my systems. |
As a | maintainer of a Conjur OSS suite component |
I want | to know how to ensure new versions of my component get into the OSS suite release |
so that | OSS users can benefit from new features my team is adding to our component. |
As a | maintainer of a Conjur OSS suite component |
I want | to know what I'm responsible for testing and what will be tested in the OSS suite |
so that | it's clear what tests I need to include and maintain in my component repository, and which tests belong in the central OSS suite release repo. |
As a | maintainer of a Conjur OSS suite component |
I want | to know what standards I need to maintain in my repository |
so that | my CHANGELOG entries, releases, READMEs, etc are compatible with the OSS suite release. |
As a | Conjur Open Source contributor |
I want | to know what components there are |
so that | I can find components that I can contribute to. |
As a | Conjur Open Source contributor |
I want | to know what is included in the Conjur OSS suite |
so that | if there are tools or platforms that are not supported, I can make a difference by building something to fill the gap. |
As a | Conjur release manager |
I want | o know what changes have been made to components since the last suite release |
so that | I can decide if enough changes have been made to merit a new release. |
As a | Conjur release manager |
I want | to know how to create a new release, including any manual steps that are required |
so that | I can successfully create a new release without missing any steps. |
As a | Conjur release manager |
I want | to know the results of automated tests |
so that | I can be sure all included components work together as expecteed at the pinned versions. |
As a | developer on a downstream project that uses Conjur as its core |
I want | to know when there are new Conjur OSS suite releases |
so that | I can review the changes and update my project to use the latest OSS suite release version of Conjur. |
As a | developer on a downstream project that uses Conjur as its core |
I want | a machine readable summary of what is included in each OSS suite release |
so that | I can build automation around the OSS suite releases as needed. |
The OSS Suite Release Repo will include:
- A user-facing README with a high level overview of how Conjur Open Source end users should leverage the repo, with links to appropriate pages in the official documentation
- A VERSION file that includes the current version of the OSS suite release
- A machine-readable file with the pinned versions included in the current release
- Version tags for each OSS suite release version that correspond to GitHub releases that are comprised of auto-generated release notes with links to relevant artifacts
- Scripts for manually or automatically generating releases, which include:
- GitHub release notes, including change log release notes and links to artifacts for each component version included in the release
- Documentation website-friendly release description, including change log release notes and links to artifacts for each component version included in the release
- Note: when possible, links to artifacts should link directly to the canonical source, rather than linking to the component README (eg link directly to Dockerhub, etc)
- Bumping the version of Conjur pinned in the Conjur helm chart
- (optional) Build and publish the Conjur Open Source AMI
- A test suite that can be run manually or automatically to test the pinned versions
included in the release
- It will be designed so that new test cases can be added as needed going forward
- The initial test case will test deploying Conjur Open Source to GKE using the Helm Chart and enabling a sample app to connect to its database via Secretless using credentials pulled from Conjur
- (optional) A test suite that can be run manually or automatically, and that runs daily against the latest versions of all OSS suite components
- A CONTRIBUTING.md guide for contributors to OSS suite releases (including release
managers, component contributors, and component maintainers) that includes:
- Guidelines for building new releases, including any manual steps
- Guidelines for component repositories to ensure there is a consistent pattern for CHANGELOGs, tags, and versioning and tags are not added to component repositories unless the build is green
The GitHub landing page will include:
- An organized view of the GitHub repositories that are part of the Conjur OSS Suite Release
The Conjur Open Source documentation will include:
- A page for Conjur OSS Suite releases
- Updates to the "Get Started" flow and/or to OSS suite component pages directing end users to use
The GitHub repositories for OSS Suite components will include:
- Updated READMEs that include a snippet on using the versions available in the latest Conjur OSS Suite Release when using the given component
- Updated standards for creating component releases to ensure they are compatible with
the OSS suite release
- We will draft standards on GitHub tagging, creating GitHub releases, using releases vs prereleases, CHANGELOG structure, GitHub release notes, etc.
- For example:
- CHANGELOG.md files should follow the KeepAChangeLog format
- GitHub release notes should include:
- Notable changes
- Upgrade instructions
- Known issues
- Copy / paste of the CHANGELOG for this version
The Conjur Enterprise project will include:
- An automatic process for proposing a version bump in the Conjur core version when a new Conjur OSS suite release is published
As a Conjur open source user, if I find Conjur on GitHub:
- I am referred in each Conjur OSS Suite component repository to the suite release repo to determine which component version to use
- On the suite release repo page, the README:
- Describes what comprises an OSS suite release
- Explains the purpose of the suite release repository, and how to use the suite release
- Refers to the suite repo's GitHub releases to see the latest suite release, and also refers to the latest release page in the documentation
- Just getting started? Includes a link to the Conjur documentation for guides on your first steps
As a Conjur open source user
- If I visit conjur.org to learn about trying Conjur:
- The "Get started" flow funnels to the Conjur suite releases page
- In future work, the "Get started" flow can funnel users to use case guides that highlight the suite release pages for retrieving artifacts
- If I visit conjur.org as an existing user to see what's new:
- The homepage highlights the latest releases, and gives a link to the Conjur suite releases page
- The pages for individual integrations / tools refer to the suite release page, to ensure that if I am looking for a particular integration, I'll understand that I should look for the suite release to find out more about using it
The release notes include a table of contents so that I can immediately go to sections specific to the components that I use in my workflows.
Each component section includes the change log for that component and links to where the artifacts from this release live, which might be specific GitHub URLs (like https://github.com/cyberark/secretless-broker/releases/tag/v1.5.0) or DockerHub URLs (perhaps like https://hub.docker.com/layers/cyberark/secretless-broker/1.5.0/images/sha256-e92f5d2a6c7e9895b3edf78a6b3e84f58199ae205e5c5f81aaf2352b76eb53e5).
Sample release notes section for Secretless:
MSSQL beta is released!
None.
Update your application manifest to refer to
cyberark/secretless-broker:1.5.0
- Added option to specify MSSQL edition in tests (cyberark/secretless-broker#1093)
- Added debug image that can be used with a debugger like delve (cyberark/secretless-broker#1056)
- Added template READMEs to connector templates (cyberark/secretless-broker#1020)
- Updated release instructions (cyberark/secretless-broker#1080)
- Improved MSSQL connector tests (cyberark/secretless-broker#1107, cyberark/secretless-broker#1089, cyberark/secretless-broker#1098)
- Improved handling of
io.EOF
errors on TCPproxy_service
- Conjur authn-k8s client version bumped to v0.16.0
- Added links to SDK docs in README (cyberark/secretless-broker#1104)
- Ensure external connector plugins will not override built-in connectors (cyberark/secretless-broker#1085)
- MSSQL connector moved to beta
- Updated pg connector to better validate packet length (cyberark/secretless-broker#1095)
- MSSQL connector faithfully propagates login response (cyberark/secretless-broker#1106)
- MSSQL connector faithfully propagates login request (cyberark/secretless-broker#1107)
- How do we ensure new documented features available in the Conjur OSS Suite Release
are appropriately propagated to the Conjur Enterprise documentation?
- We propose this is out of scope for this effort, and should be decided in a follow-on effort by the Conjur Enterprise team together with the technical writers.
- Based on the way documentation currently works, it is likely that new features in the Conjur OSS suite will require additional testing and documentation to certify the new features for Conjur Enterprise in follow-on efforts.
- How will Conjur Enterprise (built on the open Conjur core) run tests against the
non-server components of the Conjur OSS suite to ensure the enterprise product
remains compatible with the OSS components that are certified for
Conjur Enterprise?
- We propose this is out of scope for this effort, and should be decided in a follow-on effort by the Conjur Enterprise team (similarly to how the documentation changes will work above).
- What should the initial scope of the automated tests for the Conjur OSS suite
release be?
- The OSS release suite should include an end-to-end test for a single use case: Deploy Conjur Open Source with Helm Chart to GKE and enable an app to connect to its database via Secretless using credentials pulled from Conjur.
- Individual repos are responsible for running their own integration tests against Conjur. The suite release test suite will enable integration testing multiple components together (not just Component X + Conjur), and as part of the initial effort we'll implement one such use case and ensure we're set up to add other such use cases as we identify them in the future.
- Should the scope of this project include evaluating the component repositories
to determine the state of the automated tests and whether additional integration
tests need to be added?
- This is a "nice to have", and if not completed during this effort should be completed in a separate, follow-on effort. A minimal evaluation of the component test suites will be completed in reviewing component certification levels, however.
- When a new suite release is being prepared, is there a way to run the automated
integration tests in each of the components such that the specific versions
that will be included in the release will be tested together? If so, is there
a way to visualize the status of this set of builds?
-
This does not yet exist, and can be included in scope for this release - but it is not straightforward. Designing a system like this may make it easier for the enterprise products built on the core to test against the OSS suite components, if we design it correctly.
But the scope of this effort is large enough that we may want to make this its own effort.
-
- What versions of each component will be included in the first release?
- This will be determined in the course of the release, as it may change while this project is being implemented.
- Assuming we follow semantic versioning as usual for the OSS suite release, what does
a major version bump mean?
-
Since the core of this suite is the Conjur server, we would not bump the major version of the suite unless the major version of Conjur changes.
When other components are updated with breaking changes (eg a complete redesign), rather than change the major version we may manually update the release to include the new version as well as the old one and announce a deprecation timeline for the old version before it is removed from the release entirely.
We will not add support for this out of the box in this effort - enabling support for this will happen in a future effort as needed, the first time we need to deprecate.
-
- Is there a consistent way to label / tag components in the OSS suite release so
that end users can pull them by the suite release version instead of the included
component version? For example, if the suite release v1.2.3 includes Secretless
v1.5.0, can end users update their manifests to refer to the Secretless
suite-1.2.3
image (or something) and pull based on the latest suite version?- For now, we are going to focus on making the release notes clear about the upgrade instructions, for example
-
What certification level will each component in the Conjur OSS Suite Release have? Should this be evaluated as part of this effort?
- This will be evaluated as part of this effort. More info on the certification level definitions will be shared when it's available.
-
Are all of the Summon providers part of the Conjur OSS Suite Release, or just the Summon Conjur Provider? If not, should we have a separate Summon Suite release? Should we consider moving to Summon2 (the version of Summon built into Secretless, that includes all providers)?
- Migrating to Summon2 is out of scope for this effort. As Conjur developers ourselves, we frequently use Summon with other providers in addition to using Summon with our internal Conjur instance. At current, we plan to include all Summon providers in the OSS suite release.