-
Notifications
You must be signed in to change notification settings - Fork 4.9k
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
New flag to allow option for passing a config file for addon configure command. #20255
base: master
Are you sure you want to change the base?
Conversation
instead of forcing prompts Fixes kubernetes#20124
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: panyam The full list of commands accepted by this bot can be found here.
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
Hi @panyam. Thanks for your PR. I'm waiting for a kubernetes member to verify that this patch is reasonable to test. If it is, they should reply with Once the patch is verified, the new status will be reflected by the I understand the commands that are listed here. Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository. |
/ok-to-test |
Can one of the admins verify this patch? |
This comment has been minimized.
This comment has been minimized.
cmd/minikube/cmd/config/configure.go
Outdated
// Processes registry-creds addon config from configFile if it exists otherwise resorts to default behavior | ||
func processRegistryCredsConfig(profile string, configFileData map[string]any) { | ||
// Default values | ||
awsAccessID := "changeme" |
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.
is there reason for "changeme" default value? seems unconventional, I would prefer either "" or something very explicit that has no chance of clodiing with users real values, like "MINIKUBE_DEFAULT_VALUE"
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.
Ah I like the MINIKUBE_DEFAULT_VALUE as a default. Updated it. PTAL
…ance to interfere with other possible user defaults
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
Keywords which can automatically close issues and at(@) or hashtag(#) mentions are not allowed in commit messages. The list of commits with invalid commit messages:
Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository. I understand the commands that are listed here. |
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.
this PR is exciting and its getting closer ! just a few more changes
cmd/minikube/cmd/config/configure.go
Outdated
@@ -38,6 +42,7 @@ import ( | |||
"k8s.io/minikube/pkg/minikube/sysinit" | |||
) | |||
|
|||
var AddonConfigFile = "" |
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.
lets make this private
out.Ln("Reading %s configs from %s", addon, configFilePath) | ||
if confData, err := os.ReadFile(configFilePath); err != nil && errors.Is(err, os.ErrNotExist) { | ||
exit.Message(reason.Usage, "config file does not exist") | ||
return nil, err |
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.
klog.warnf err before exis
exit.Message(reason.Usage, "config file does not exist") | ||
return nil, err | ||
} else if err != nil { | ||
exit.Message(reason.Kind{ExitCode: reason.ExProgramConfig, Advice: "provide a valid config file"}, |
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.
klog.Errof(...)
} else if err != nil { | ||
exit.Message(reason.Kind{ExitCode: reason.ExProgramConfig, Advice: "provide a valid config file"}, | ||
fmt.Sprintf("error opening config file: %v", err)) | ||
return nil, err |
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.
"wrap" the error
fmt.Sprintf("error opening config file: %v", err)) | ||
return nil, err | ||
} else if err = json.Unmarshal(confData, &configFileData); err != nil { | ||
exit.Message(reason.Kind{ExitCode: reason.ExProgramConfig, Advice: "provide a valid config file"}, |
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.
"ensure the json format of the config file is valid"
return nil, err | ||
} else if err = json.Unmarshal(confData, &configFileData); err != nil { | ||
exit.Message(reason.Kind{ExitCode: reason.ExProgramConfig, Advice: "provide a valid config file"}, | ||
fmt.Sprintf("error opening config file: %v", err)) |
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.
error wrap
errors.Wrapf(err, "addon config %s" ... )
} else if err = json.Unmarshal(confData, &configFileData); err != nil { | ||
exit.Message(reason.Kind{ExitCode: reason.ExProgramConfig, Advice: "provide a valid config file"}, | ||
fmt.Sprintf("error opening config file: %v", err)) | ||
return nil, err |
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.
if exit no need to return
return nil, err | ||
} | ||
|
||
// Make sure the addon specific config exists and it is a map |
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.
make a helper function and put the nested ifs in there
@@ -304,6 +305,64 @@ func validateIngressAddon(ctx context.Context, t *testing.T, profile string) { | |||
} | |||
} | |||
|
|||
// validateRegistryCredsAddon tests the registry-creds addon by trying to load its configs | |||
func validateRegistryCredsAddon(ctx context.Context, t *testing.T, profile string) { |
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.
lets use a struct for the regsitry cred addons so it can be typed checked
kvm2 driver with docker runtime
Times for minikube start: 49.9s 50.9s 49.9s 48.1s 50.5s Times for minikube (PR 20255) ingress: 14.9s 14.9s 14.9s 14.9s 15.0s docker driver with docker runtime
Times for minikube start: 21.2s 20.9s 20.2s 21.1s 20.7s Times for minikube ingress: 12.3s 12.2s 12.2s 12.2s 12.7s docker driver with containerd runtime
Times for minikube (PR 20255) start: 19.2s 23.1s 19.3s 20.2s 22.5s Times for minikube ingress: 23.2s 22.7s 38.7s 39.2s 22.7s |
Here are the number of top 10 failed tests in each environments with lowest flake rate.
Besides the following environments also have failed tests:
To see the flake rates of all tests by environment, click here. |
Minor UI Change (Before and After described in the ticket) but tl;dr:
BEFORE
Currently when configuring addons with the command:
eg:
The user is prompted to input the values one by one, eg:
and so on. This makes it hard to store/load values in a scripted environemnt. Some times it easier to provide a config file containing so that the values can be read from this.
AFTER
Add a "-f" local flag to the addon configure command, eg:
etc
Fixes #20124