Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CI/CD and Docs: Switch to using official helm chart testing/release actions #2

Merged
merged 5 commits into from
May 17, 2024

Conversation

jessebot
Copy link

@jessebot jessebot commented May 16, 2024

Description

This is the beginning of addressing #1 so that we can begin releasing the chart locally. This PR contains a number of changes related to the CI/CD of this chart that I will list below. It looks like a lot of files, but most of it is just moving the helm chart into a new directory as per the helm chart standard.

Chart linting

Changes I've made to the linting and testing aspects of this chart/repo:

  • added a .github/workflows/lint-chart.yml to lint the chart on each pull request
  • removed .github/workflows/actionlint.yml as this referced the old release process

Chart release via github pages

I've done most of the work to allow for releases via github pages using the chart-releaser-action. This includes:

  • moving the chart files/directories (templates, Chart.yaml, .helmignore) under a new dir calledcharts/openbao/ so it's automatically picked up by the helm/chart-releaser-action
  • adding a .github/workflows/release-chart.yml to release on push to main and generated release notes with PR link
  • removing .github/workflows/update-helm-charts-index.yml as this was specific to hashicorp

To finish this, a maintainer of this repo needs to set up the following according to the helm/chart-releaser-action docs:

  1. Setup a GitHub branch called gh-pages to store the published charts.
  2. In your repo, go to Settings/Pages. Change the Source Branch to gh-pages.

Please let me know if you have any questions.

basic docs

I've generated some docs from the values.yaml using norwoodj/helm-docs so that ./charts/openbao/README.md has a readable chart for all parameters.

Misc

  • In Chart.yaml I've changed the name of the chart from Vault to OpenBao and reset the version to 0.1.0 since we have a lot of testing to do.
  • I removed .github/workflows/jira.yaml as it is related to hashicorp's jira instance and project workflow

Edit: moved open discussions/issues to #3 and #4

also begin massive change over to using helm's official chart release and testing actions

Signed-off-by: jessebot <[email protected]>
@jessebot jessebot force-pushed the feature/github-releases branch from 1c3252b to b44f81b Compare May 16, 2024 10:10
charts/openbao/Chart.yaml Outdated Show resolved Hide resolved
charts/openbao/Chart.yaml Outdated Show resolved Hide resolved
@jessebot jessebot changed the title begin changes to using openbao everywhere instead of vault; switch to using official helm chart testing actions begin changes to using openbao everywhere instead of vault; switch to using official helm chart testing/release actions May 16, 2024
charts/openbao/Chart.yaml Outdated Show resolved Hide resolved
@jessebot jessebot marked this pull request as ready for review May 16, 2024 12:31
@jessebot jessebot changed the title begin changes to using openbao everywhere instead of vault; switch to using official helm chart testing/release actions CI/CD and Docs: Switch to using official helm chart testing/release actions May 16, 2024
@jessebot
Copy link
Author

I don't know of a good title for this PR, but it's ready for review 👋

@naphelps naphelps self-requested a review May 16, 2024 20:08
@naphelps
Copy link
Member

@JanMa Is there a recommended way to merge this self-hosted Helm repo into our existing site?

charts/openbao/Chart.yaml Outdated Show resolved Hide resolved
@jessebot
Copy link
Author

Per Jan in the openbao/openbao-general matrix room (to keep anyone not on matrix in the loop):

Ah found it, thanks for the hint. I don't think it makes a lot of sense to integrate the generated HELM repo with our existing docs site. Those assets are only ever downloaded by the HELM CLI when you install the repository, and not something a user would look at.

The documentation for the HELM chart is already in our main repo, we just exclude it from the published site for now.
So for me it would be fine to just use the openbao.github.io/openbao-helm url for the HELM repo. Alternatively we could also configure it to use a subdomain like helm.openbao.org to serve all our assets from the same domain

I think we're going to have a similar discussion again soon when it comes to the question at which domain we want to host our DEB and RPM repos. I would like to host them via GitHub pages as well

Let me know how you'd like to proceed. I think it's easiest to move it forward with openbao.github.io/openbao-helm however, I still need a gh-pages branch setup for this repo. If you'd like it to go somewhere else, I'll need to spend time looking into this, as I have only ever used the official paved road path for helm/chart-releaser.

@naphelps
Copy link
Member

I am in favor of using the default pages domain to get this in. The project can look at sub-domain integration down the road.

Copy link
Member

@naphelps naphelps left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@naphelps naphelps merged commit ed58ce3 into openbao:main May 17, 2024
1 check passed
@jessebot jessebot deleted the feature/github-releases branch May 18, 2024 11:28
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants