-
Notifications
You must be signed in to change notification settings - Fork 174
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
Add test coverage #292
Comments
Thanks for taking the time to write up the issue! We've had these in the backlog for quite a while actually:
Let's leave this issue open as well for now, for the sake of public record.
Yes, there are more internal tests happening on each change. But indeed, automating this is a problem that I've been wanting to get to for a long time. Now that we are spending more time on k6-operator, there's some hope that we'll be able to start resolving this. |
I can port our KEDA's approach to this repo if you want. It doesn't require external resources and newcomers can add e2e test cases. |
Hi @JorTurFer, Thanks for the offer to help! I've looked a bit into the approach you linked and worked on: it could certainly work but this is not exactly what I had in mind for e2e tests here... I see this is a multi-layer problem which shouldn't be done ad-hoc; otherwise, I'll just end up re-doing it in a couple of quarters. A part of what I've wanted to setup is not public at the moment (might become public soon-ish if I'm lucky). OTOH, it'd also bring additional complexity so there is some balancing act here of keeping complexity manageable. So I'm grokking now what kind of testing pipelines we would need and where. Last but not least, my next most pressing TODO is actually a refactoring of the controller and that work will likely impact decision making here. So there are multiple factors I try to take into account. I appreciate your offer to help, but I'll need a bit of time to be certain what can be done externally in this manner. Either way, it's a WIP from my perspective. I'll probably have more info on the next week! |
Hi @yorugac
This is the most important reason for adding e2e/black box test cases, a refactor without testing is not a refactor, is the hoping of not breaking anything. In the mid term (once all those refactors are done), integration tests are a really good idea and envtest allows using a local cluster (such as kind) enabling We are in the road of integrating this awesome tool, and now we're planning to fork and and use our own supply chain (adding e2e tests in our side) to prevent unexpected changes from the upstream, but honestly, I prefer to contribute here directly rather than forking the repo just to adding e2e tests. |
@JorTurFer, how are you updating the operator? We've recently added new installation methods: bundle addition and Helm addition which should help prevent unexpected changes. From my viewpoint, far worse is lack of understanding of all the possible ways people use the k6-operator. We had an incident of "broken" functionality once because nobody knew that the operator was being used in a certain specific way. No amount of tests, be it integration or E2E, could have prevented it as the cause was in lack of knowledge. We even have a public issue for that here: #194 |
First of all, I'd include a tests for validating changes on generated manifests and informers/listers/clientset (I know that we don't use them currently, but as it's the best approach at scale, if we introduce them we should test them) because otherwise, I could have introduced the change in the
It depends, you have asked about what I would tested on this #274. Let's say that we missed the part of CRD update and due to the lack of coverage, CI didn't detect it either. Any user updating the operator, doesn't matter if they use helm/kustomize/bundle would have faced with breaking change unexpected, and that's why I said that as user, I can face with unexpected changes introduced by error. In this case, I updated the CRD and you checked it, but what if not? that's my point
Sorry, but I have to disagree here, I don't think that this is a valid reason for not adding/improving test coverage. Any software can have edge cases and everybody can break something by error, but in that case (IMHO), the solution must cover that edge case with a test for the future.
I expect a reliable software as I can assume from other things such as nginx, prometheus, etc. Of course, it doesn't mean that it never fails (in fact, I think that in this topic, my attitude is always trying to help patching/fixing the issues), but currently, errors not coverable with unit tests aren't coverable, so we can face with regressions easily, which reduces the trust on this operator |
Feature Description
Working on this PR, I have tried to add some integration test for this changes but there isn't any wait to do it with current setup because
envtest
doesn't have built-in controllers (such as job controller) and currently there isn't any e2e test as far as I can see :/envtest
allows to use a real cluster for executing the integration tests, maybe we can add a documentation about the topic and use theenvtest
feature to execute an integration test suite. For local development and CI, we can use Kind and that should be all.Currently any change in the operator can literally break the whole operator because there is just a single e2e test with the happy path. This is an example from KEDA HTTP Add-on, where just using kind, we execute multiple e2e test cases easily and where newcomers can add new e2e test cases easily. It can be executed on GH Runners without any other requirement and in our case, we execute the e2e test on different k8s versions and architectures super easy
I'd like to see something like that in k6-operator because as I said, any change is potentially a bug because the e2e isn't tested but either the integrations (at least not publicly, maybe internally it's covered with other tests)
Suggested Solution (optional)
No response
Already existing or connected issues / PRs (optional)
No response
The text was updated successfully, but these errors were encountered: