-
Notifications
You must be signed in to change notification settings - Fork 271
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
helm unittests #462
base: main
Are you sure you want to change the base?
helm unittests #462
Conversation
Signed-off-by: Michael Sprauer <[email protected]>
Signed-off-by: Michael Sprauer <[email protected]>
Please explain what this does exactly. I'm not familiar with helm-unittest and don't even know what the tool is supposed to do. |
https://github.com/helm-unittest/helm-unittest is a tool to help write unit tests for helm charts. It allows to write unit tests which help ensure software quality on the unit level. Here is a very good article on what unit-tests actually are: https://martinfowler.com/bliki/UnitTest.html btw: I also added a check that runs during PR actions |
I know what unit tests are, but what is tested in the context of Helm Charts? |
In this https://github.com/nextcloud/helm/blob/2c871d9bdfbddc748cee7a0aa575fbc32a04b0f2/charts/nextcloud/tests/defaults_test.yaml I test the output of the helm-chart for a default value file. I only provide values to
This is necessary to generate stable output (it should not change between test runs even if the If a future change results in a desired change of the output, the snapshot can be updated: This is only a very basic test. You can increase coverage by defining more tests and more test-suites with different combinations of Using |
I agree tests are good, but I look at quite a few helm charts for a living and I haven't actually seen this tool in use before now. I feel like a test of just installing on k3s/k3d makes more sense and is easier to understand since we still don't actually have that across k8s distros other than kind. It would also be another thing that would then need to pass before we can merge things, and we already have some trouble doing that due to our other requirements such as DCO, linting, chart version bump, and base installation on kind.
The other issue is that we have to keep it up to date, though we could add this to the contributing docs? Still OK to merge this, because I agree, more feature test coverage would be nice, but wanted to note some very minor downsides. I'd have to spend some time with it before I could help add anything else. If the helm unit-tests are common enough, I guess we could put out some GitHub issues asking other community members to help us add specific features tests, but if we do that, there's also the question of how we run only necessary unit tests after each push? Otherwise, every push will take like 5+ minutes as we add more feature unit tests, which will also make the back and forth on PRs take a bit longer. I approved it for now, so that I am not blocking, but will wait till others chime in before merging. Update: after thinking about it more, it does make sense to have more tests though. I think I was just on about how long it can sometimes take to get things merged. Tests make sense though. |
The unit-tests even for larger test suites are pretty fast (<5sec). I bet they will be always faster than starting a kind-cluster and deploy it. |
I assume the unit tests just run |
awesome, then that really solve the bulk of my issues :) |
if/when this is merged, I've created #469 for a contributing doc to be updated as we need :) |
@jessebot @MichaelSp what is the status? I think it would be good to start adding tests soon, even if there are just a few in the beginning. |
I haven't tested this locally, but let me try! |
I'd say the |
generated via `helm unittest -u nextcloud` from `charts` dir Signed-off-by: JesseBot <[email protected]>
…ges filter Signed-off-by: JesseBot <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I regenerated the snapshot for today and rebased off of main, but I have one last comment below to take care of before we can merge this.
We also probably need to add a note about these tests to the |
@provokateurin do we still want to move this forward? 🤔 I know we have other ci tests, so not sure if we still want this. Up to you! |
I think this might still be a good idea to prevent any accidental issues with the templating that otherwise might go undetected. |
Okie dokie, we'll need the conflicts resolved, and then we can try it by doing a temporary test commit here like we did on the last PR? Update: Fixed conflicts and now it should run. I also still think we should have a section in the CONTRIBUTING.md on how to update the tests if they get out of date. @MichaelSp if could do that, I can get this merged, otherwise, I'll circle back to this PR and do it when I have a free moment 🙏 |
Signed-off-by: Jesse Hitch <[email protected]>
Oh, another thing before we merge, the 3 test scenarios we want to check were:
|
Signed-off-by: Michael Sprauer <[email protected]>
Signed-off-by: Michael Sprauer <[email protected]>
Signed-off-by: Michael Sprauer <[email protected]>
Finally I found the time to come back to this and:
|
Pull Request
Description of the change
run unittests for the helm-chart during PR checks
Benefits
better quality
Possible drawbacks
??
Applicable issues
no
Additional information
Checklist