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

Manage adapter dependencies in mixed packages #1397

Open
christophenne opened this issue Nov 12, 2024 · 0 comments
Open

Manage adapter dependencies in mixed packages #1397

christophenne opened this issue Nov 12, 2024 · 0 comments

Comments

@christophenne
Copy link
Member

christophenne commented Nov 12, 2024

Is your feature request related to a problem? Please describe.
There are mixed packages like k8sgpt-operator, that use both a helm chart and an additional manifest.
The first reconciliation of such a package can lead to an erroneous InstallationFailed status, that usually self-heals on a followup reconciliation.

Example: When installing k8sgpt-operator, during the first reconciliation, the controller sets the status to InstallationFailed, because the plain adapter fails, because it cannot apply the K8sGPT resource, because the helm adapter has not run yet.

set condition to failed: could not apply resource: the server could not find the requested resource (patch k8sgpts.core.k8sgpt.ai k8sgpt) 

This is easily reproducible by running glasskube install k8sgpt-operator, it will always fail directly at the installation, but fix itself afterwards. Also see here: glasskube/packages#521

Describe the solution you'd like

We could think about a strategy for mixed packages, where when an error occurs in one adapter, we check if some of the other adapters have a "waiting" result, but it would be very easy to get into deadlocks that way.
We could also say for mixed packages helm always comes first, and the plain adapter will only be run once the helm one succeeded or is at least in progress?
Or maybe we simply run all of them no matter what "depends" on what, and say, if one adapter returned an error, but at least one other adapter has status waiting, then we suppress the error and set the overall status to waiting too.

Describe alternatives you've considered

In the packages pipeline, we could use the --no-wait flag, but then we would also need to run the followup check in a loop until the status switches to ready. There was already a PR like that a while ago, but we decided against it because we explicitly want the installation to succeed "immediately": glasskube/packages#232

Additional context
This blocks:

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant