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

Accommodate for k8s.io api/apimachinery/client-go not using semver go mod paths #43

Open
garomonegro opened this issue Jun 8, 2021 · 1 comment
Labels
enhancement New feature or request P0 Highest Priority - usually bugs

Comments

@garomonegro
Copy link
Collaborator

garomonegro commented Jun 8, 2021

These k8s Clients/APIs are in v0.x.x and they can break contract/signatures at any time. They do not follow the Golang semantic import version standard for their go modules paths.. This causes dependency issues when projects that use them import Kubedog for their BDDs.

kubedog/go.mod

Lines 14 to 16 in 018e64a

k8s.io/api v0.17.2
k8s.io/apimachinery v0.17.2
k8s.io/client-go v0.17.2

The discussion about this issue starts here. It contains some of the reasons why some of the k8s.io maintainers dont want to move to the standard.

Until the above issue is resolved, for each new release of Kubedog, we need to have several versions/tags that use different versions of these dependencies. Which ones or how? That has to be defined - maybe a CD would be needed for this, better testing as well.

@garomonegro garomonegro added enhancement New feature or request P0 Highest Priority - usually bugs labels Jun 8, 2021
@garomonegro garomonegro changed the title New versions need several releases to acomodate for k8s.io api/apimachinery/client-go not using proper semver go mod paths New releases need several versions to accommodate for k8s.io api/apimachinery/client-go not using proper semver go mod paths Jun 8, 2021
@garomonegro garomonegro changed the title New releases need several versions to accommodate for k8s.io api/apimachinery/client-go not using proper semver go mod paths Accommodate for k8s.io api/apimachinery/client-go not using semver go mod paths Jun 8, 2021
@garomonegro
Copy link
Collaborator Author

In some, if not most cases, BDDs are independent of the codebase of the project. So we can propose that BDD related code is kept in an independent go module to avoid diamond dependency problems. BUT this does not solve the problem of users needing new/deprecated features available in the different versions of those deps.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request P0 Highest Priority - usually bugs
Projects
None yet
Development

No branches or pull requests

1 participant