mirror of
https://github.com/coder/coder.git
synced 2025-07-13 21:36:50 +00:00
fix: Add --yes and --use-previous-options to config-ssh (#2458)
This commit is contained in:
committed by
GitHub
parent
7cce7a9c69
commit
18b0effa83
@ -138,6 +138,7 @@ func configSSH() *cobra.Command {
|
|||||||
var (
|
var (
|
||||||
sshConfigFile string
|
sshConfigFile string
|
||||||
sshConfigOpts sshConfigOptions
|
sshConfigOpts sshConfigOptions
|
||||||
|
usePreviousOpts bool
|
||||||
coderConfigFile string
|
coderConfigFile string
|
||||||
showDiff bool
|
showDiff bool
|
||||||
skipProxyCommand bool
|
skipProxyCommand bool
|
||||||
@ -218,7 +219,9 @@ func configSSH() *cobra.Command {
|
|||||||
|
|
||||||
// Avoid prompting in diff mode (unexpected behavior)
|
// Avoid prompting in diff mode (unexpected behavior)
|
||||||
// or when a previous config does not exist.
|
// or when a previous config does not exist.
|
||||||
if !showDiff && lastConfig != nil && !sshConfigOpts.equal(*lastConfig) {
|
if usePreviousOpts && lastConfig != nil {
|
||||||
|
sshConfigOpts = *lastConfig
|
||||||
|
} else if !showDiff && lastConfig != nil && !sshConfigOpts.equal(*lastConfig) {
|
||||||
newOpts := sshConfigOpts.asList()
|
newOpts := sshConfigOpts.asList()
|
||||||
newOptsMsg := "\n\n New options: none"
|
newOptsMsg := "\n\n New options: none"
|
||||||
if len(newOpts) > 0 {
|
if len(newOpts) > 0 {
|
||||||
@ -394,11 +397,14 @@ func configSSH() *cobra.Command {
|
|||||||
cmd.Flags().BoolVarP(&showDiff, "diff", "D", false, "Show diff of changes that will be made.")
|
cmd.Flags().BoolVarP(&showDiff, "diff", "D", false, "Show diff of changes that will be made.")
|
||||||
cmd.Flags().BoolVarP(&skipProxyCommand, "skip-proxy-command", "", false, "Specifies whether the ProxyCommand option should be skipped. Useful for testing.")
|
cmd.Flags().BoolVarP(&skipProxyCommand, "skip-proxy-command", "", false, "Specifies whether the ProxyCommand option should be skipped. Useful for testing.")
|
||||||
_ = cmd.Flags().MarkHidden("skip-proxy-command")
|
_ = cmd.Flags().MarkHidden("skip-proxy-command")
|
||||||
|
cliflag.BoolVarP(cmd.Flags(), &usePreviousOpts, "use-previous-options", "", "CODER_SSH_USE_PREVIOUS_OPTIONS", false, "Specifies whether or not to keep options from previous run of config-ssh.")
|
||||||
|
|
||||||
// Deprecated: Remove after migration period.
|
// Deprecated: Remove after migration period.
|
||||||
cmd.Flags().StringVar(&coderConfigFile, "test.ssh-coder-config-file", sshDefaultCoderConfigFileName, "Specifies the path to an Coder SSH config file. Useful for testing.")
|
cmd.Flags().StringVar(&coderConfigFile, "test.ssh-coder-config-file", sshDefaultCoderConfigFileName, "Specifies the path to an Coder SSH config file. Useful for testing.")
|
||||||
_ = cmd.Flags().MarkHidden("test.ssh-coder-config-file")
|
_ = cmd.Flags().MarkHidden("test.ssh-coder-config-file")
|
||||||
|
|
||||||
|
cliui.AllowSkipPrompt(cmd)
|
||||||
|
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -446,6 +446,54 @@ func TestConfigSSH_FileWriteAndOptionsFlow(t *testing.T) {
|
|||||||
{match: "Continue?", write: "no"},
|
{match: "Continue?", write: "no"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "Do not prompt when using --yes",
|
||||||
|
writeConfig: writeConfig{
|
||||||
|
ssh: strings.Join([]string{
|
||||||
|
headerStart,
|
||||||
|
"# Last config-ssh options:",
|
||||||
|
"# :ssh-option=ForwardAgent=yes",
|
||||||
|
"#",
|
||||||
|
headerEnd,
|
||||||
|
"",
|
||||||
|
}, "\n"),
|
||||||
|
},
|
||||||
|
wantConfig: wantConfig{
|
||||||
|
ssh: strings.Join([]string{
|
||||||
|
// Last options overwritten.
|
||||||
|
baseHeader,
|
||||||
|
"",
|
||||||
|
}, "\n"),
|
||||||
|
},
|
||||||
|
args: []string{"--yes"},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Do not prompt for new options when prev opts flag is set",
|
||||||
|
writeConfig: writeConfig{
|
||||||
|
ssh: strings.Join([]string{
|
||||||
|
headerStart,
|
||||||
|
"# Last config-ssh options:",
|
||||||
|
"# :ssh-option=ForwardAgent=yes",
|
||||||
|
"#",
|
||||||
|
headerEnd,
|
||||||
|
"",
|
||||||
|
}, "\n"),
|
||||||
|
},
|
||||||
|
wantConfig: wantConfig{
|
||||||
|
ssh: strings.Join([]string{
|
||||||
|
headerStart,
|
||||||
|
"# Last config-ssh options:",
|
||||||
|
"# :ssh-option=ForwardAgent=yes",
|
||||||
|
"#",
|
||||||
|
headerEnd,
|
||||||
|
"",
|
||||||
|
}, "\n"),
|
||||||
|
},
|
||||||
|
args: []string{
|
||||||
|
"--use-previous-options",
|
||||||
|
"--yes",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
// Tests for deprecated split coder config.
|
// Tests for deprecated split coder config.
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user