diff --git a/contrib/completions/bash/oc b/contrib/completions/bash/oc index bfb72a74276b..842728a07acf 100644 --- a/contrib/completions/bash/oc +++ b/contrib/completions/bash/oc @@ -2353,10 +2353,1219 @@ _oc_adm_create-provider-selection-template() noun_aliases=() } +_oc_adm_diagnostics_AggregatedLogging() +{ + last_command="oc_adm_diagnostics_AggregatedLogging" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_AnalyzeLogs() +{ + last_command="oc_adm_diagnostics_AnalyzeLogs" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ClusterRegistry() +{ + last_command="oc_adm_diagnostics_ClusterRegistry" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ClusterRoleBindings() +{ + last_command="oc_adm_diagnostics_ClusterRoleBindings" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ClusterRoles() +{ + last_command="oc_adm_diagnostics_ClusterRoles" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ClusterRouter() +{ + last_command="oc_adm_diagnostics_ClusterRouter" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ConfigContexts() +{ + last_command="oc_adm_diagnostics_ConfigContexts" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_DiagnosticPod() +{ + last_command="oc_adm_diagnostics_DiagnosticPod" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--images=") + local_nonpersistent_flags+=("--images=") + flags+=("--latest-images") + local_nonpersistent_flags+=("--latest-images") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_EtcdWriteVolume() +{ + last_command="oc_adm_diagnostics_EtcdWriteVolume" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--duration=") + local_nonpersistent_flags+=("--duration=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_MasterConfigCheck() +{ + last_command="oc_adm_diagnostics_MasterConfigCheck" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_MasterNode() +{ + last_command="oc_adm_diagnostics_MasterNode" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_MetricsApiProxy() +{ + last_command="oc_adm_diagnostics_MetricsApiProxy" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_NetworkCheck() +{ + last_command="oc_adm_diagnostics_NetworkCheck" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--logdir=") + local_nonpersistent_flags+=("--logdir=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--pod-image=") + local_nonpersistent_flags+=("--pod-image=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--test-pod-image=") + local_nonpersistent_flags+=("--test-pod-image=") + flags+=("--test-pod-port=") + local_nonpersistent_flags+=("--test-pod-port=") + flags+=("--test-pod-protocol=") + local_nonpersistent_flags+=("--test-pod-protocol=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_NodeConfigCheck() +{ + last_command="oc_adm_diagnostics_NodeConfigCheck" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_NodeDefinitions() +{ + last_command="oc_adm_diagnostics_NodeDefinitions" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_RouteCertificateValidation() +{ + last_command="oc_adm_diagnostics_RouteCertificateValidation" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ServiceExternalIPs() +{ + last_command="oc_adm_diagnostics_ServiceExternalIPs" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_UnitStatus() +{ + last_command="oc_adm_diagnostics_UnitStatus" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_all() +{ + last_command="oc_adm_diagnostics_all" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--diagnosticpod-images=") + local_nonpersistent_flags+=("--diagnosticpod-images=") + flags+=("--diagnosticpod-latest-images") + local_nonpersistent_flags+=("--diagnosticpod-latest-images") + flags+=("--etcdwritevolume-duration=") + local_nonpersistent_flags+=("--etcdwritevolume-duration=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--networkcheck-logdir=") + local_nonpersistent_flags+=("--networkcheck-logdir=") + flags+=("--networkcheck-pod-image=") + local_nonpersistent_flags+=("--networkcheck-pod-image=") + flags+=("--networkcheck-test-pod-image=") + local_nonpersistent_flags+=("--networkcheck-test-pod-image=") + flags+=("--networkcheck-test-pod-port=") + local_nonpersistent_flags+=("--networkcheck-test-pod-port=") + flags+=("--networkcheck-test-pod-protocol=") + local_nonpersistent_flags+=("--networkcheck-test-pod-protocol=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + _oc_adm_diagnostics() { last_command="oc_adm_diagnostics" commands=() + commands+=("AggregatedLogging") + commands+=("AnalyzeLogs") + commands+=("ClusterRegistry") + commands+=("ClusterRoleBindings") + commands+=("ClusterRoles") + commands+=("ClusterRouter") + commands+=("ConfigContexts") + commands+=("DiagnosticPod") + commands+=("EtcdWriteVolume") + commands+=("MasterConfigCheck") + commands+=("MasterNode") + commands+=("MetricsApiProxy") + commands+=("NetworkCheck") + commands+=("NodeConfigCheck") + commands+=("NodeDefinitions") + commands+=("RouteCertificateValidation") + commands+=("ServiceExternalIPs") + commands+=("UnitStatus") + commands+=("all") flags=() two_word_flags=() @@ -2377,26 +3586,12 @@ _oc_adm_diagnostics() local_nonpersistent_flags+=("--diaglevel=") flags+=("--host") local_nonpersistent_flags+=("--host") - flags+=("--images=") - local_nonpersistent_flags+=("--images=") - flags+=("--latest-images") - local_nonpersistent_flags+=("--latest-images") flags+=("--loglevel=") local_nonpersistent_flags+=("--loglevel=") flags+=("--logspec=") local_nonpersistent_flags+=("--logspec=") flags+=("--master-config=") local_nonpersistent_flags+=("--master-config=") - flags+=("--network-logdir=") - local_nonpersistent_flags+=("--network-logdir=") - flags+=("--network-pod-image=") - local_nonpersistent_flags+=("--network-pod-image=") - flags+=("--network-test-pod-image=") - local_nonpersistent_flags+=("--network-test-pod-image=") - flags+=("--network-test-pod-port=") - local_nonpersistent_flags+=("--network-test-pod-port=") - flags+=("--network-test-pod-protocol=") - local_nonpersistent_flags+=("--network-test-pod-protocol=") flags+=("--node-config=") local_nonpersistent_flags+=("--node-config=") flags+=("--prevent-modification") diff --git a/contrib/completions/zsh/oc b/contrib/completions/zsh/oc index 002856bd7b92..d1329043e066 100644 --- a/contrib/completions/zsh/oc +++ b/contrib/completions/zsh/oc @@ -2495,10 +2495,1219 @@ _oc_adm_create-provider-selection-template() noun_aliases=() } +_oc_adm_diagnostics_AggregatedLogging() +{ + last_command="oc_adm_diagnostics_AggregatedLogging" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_AnalyzeLogs() +{ + last_command="oc_adm_diagnostics_AnalyzeLogs" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ClusterRegistry() +{ + last_command="oc_adm_diagnostics_ClusterRegistry" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ClusterRoleBindings() +{ + last_command="oc_adm_diagnostics_ClusterRoleBindings" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ClusterRoles() +{ + last_command="oc_adm_diagnostics_ClusterRoles" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ClusterRouter() +{ + last_command="oc_adm_diagnostics_ClusterRouter" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ConfigContexts() +{ + last_command="oc_adm_diagnostics_ConfigContexts" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_DiagnosticPod() +{ + last_command="oc_adm_diagnostics_DiagnosticPod" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--images=") + local_nonpersistent_flags+=("--images=") + flags+=("--latest-images") + local_nonpersistent_flags+=("--latest-images") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_EtcdWriteVolume() +{ + last_command="oc_adm_diagnostics_EtcdWriteVolume" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--duration=") + local_nonpersistent_flags+=("--duration=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_MasterConfigCheck() +{ + last_command="oc_adm_diagnostics_MasterConfigCheck" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_MasterNode() +{ + last_command="oc_adm_diagnostics_MasterNode" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_MetricsApiProxy() +{ + last_command="oc_adm_diagnostics_MetricsApiProxy" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_NetworkCheck() +{ + last_command="oc_adm_diagnostics_NetworkCheck" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--logdir=") + local_nonpersistent_flags+=("--logdir=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--pod-image=") + local_nonpersistent_flags+=("--pod-image=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--test-pod-image=") + local_nonpersistent_flags+=("--test-pod-image=") + flags+=("--test-pod-port=") + local_nonpersistent_flags+=("--test-pod-port=") + flags+=("--test-pod-protocol=") + local_nonpersistent_flags+=("--test-pod-protocol=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_NodeConfigCheck() +{ + last_command="oc_adm_diagnostics_NodeConfigCheck" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_NodeDefinitions() +{ + last_command="oc_adm_diagnostics_NodeDefinitions" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_RouteCertificateValidation() +{ + last_command="oc_adm_diagnostics_RouteCertificateValidation" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_ServiceExternalIPs() +{ + last_command="oc_adm_diagnostics_ServiceExternalIPs" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_UnitStatus() +{ + last_command="oc_adm_diagnostics_UnitStatus" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + flags+=("--context=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + +_oc_adm_diagnostics_all() +{ + last_command="oc_adm_diagnostics_all" + commands=() + + flags=() + two_word_flags=() + local_nonpersistent_flags=() + flags_with_completion=() + flags_completion=() + + flags+=("--cluster-context=") + local_nonpersistent_flags+=("--cluster-context=") + flags+=("--config=") + flags_with_completion+=("--config") + flags_completion+=("_filedir") + local_nonpersistent_flags+=("--config=") + flags+=("--context=") + local_nonpersistent_flags+=("--context=") + flags+=("--diaglevel=") + two_word_flags+=("-l") + local_nonpersistent_flags+=("--diaglevel=") + flags+=("--diagnosticpod-images=") + local_nonpersistent_flags+=("--diagnosticpod-images=") + flags+=("--diagnosticpod-latest-images") + local_nonpersistent_flags+=("--diagnosticpod-latest-images") + flags+=("--etcdwritevolume-duration=") + local_nonpersistent_flags+=("--etcdwritevolume-duration=") + flags+=("--host") + local_nonpersistent_flags+=("--host") + flags+=("--loglevel=") + local_nonpersistent_flags+=("--loglevel=") + flags+=("--logspec=") + local_nonpersistent_flags+=("--logspec=") + flags+=("--master-config=") + local_nonpersistent_flags+=("--master-config=") + flags+=("--networkcheck-logdir=") + local_nonpersistent_flags+=("--networkcheck-logdir=") + flags+=("--networkcheck-pod-image=") + local_nonpersistent_flags+=("--networkcheck-pod-image=") + flags+=("--networkcheck-test-pod-image=") + local_nonpersistent_flags+=("--networkcheck-test-pod-image=") + flags+=("--networkcheck-test-pod-port=") + local_nonpersistent_flags+=("--networkcheck-test-pod-port=") + flags+=("--networkcheck-test-pod-protocol=") + local_nonpersistent_flags+=("--networkcheck-test-pod-protocol=") + flags+=("--node-config=") + local_nonpersistent_flags+=("--node-config=") + flags+=("--prevent-modification") + local_nonpersistent_flags+=("--prevent-modification") + flags+=("--v=") + local_nonpersistent_flags+=("--v=") + flags+=("--vmodule=") + local_nonpersistent_flags+=("--vmodule=") + flags+=("--as=") + flags+=("--as-group=") + flags+=("--cache-dir=") + flags+=("--certificate-authority=") + flags_with_completion+=("--certificate-authority") + flags_completion+=("_filedir") + flags+=("--client-certificate=") + flags_with_completion+=("--client-certificate") + flags_completion+=("_filedir") + flags+=("--client-key=") + flags_with_completion+=("--client-key") + flags_completion+=("_filedir") + flags+=("--cluster=") + flags+=("--insecure-skip-tls-verify") + flags+=("--log-flush-frequency=") + flags+=("--match-server-version") + flags+=("--namespace=") + two_word_flags+=("-n") + flags+=("--request-timeout=") + flags+=("--server=") + flags+=("--token=") + flags+=("--user=") + + must_have_one_flag=() + must_have_one_noun=() + noun_aliases=() +} + _oc_adm_diagnostics() { last_command="oc_adm_diagnostics" commands=() + commands+=("AggregatedLogging") + commands+=("AnalyzeLogs") + commands+=("ClusterRegistry") + commands+=("ClusterRoleBindings") + commands+=("ClusterRoles") + commands+=("ClusterRouter") + commands+=("ConfigContexts") + commands+=("DiagnosticPod") + commands+=("EtcdWriteVolume") + commands+=("MasterConfigCheck") + commands+=("MasterNode") + commands+=("MetricsApiProxy") + commands+=("NetworkCheck") + commands+=("NodeConfigCheck") + commands+=("NodeDefinitions") + commands+=("RouteCertificateValidation") + commands+=("ServiceExternalIPs") + commands+=("UnitStatus") + commands+=("all") flags=() two_word_flags=() @@ -2519,26 +3728,12 @@ _oc_adm_diagnostics() local_nonpersistent_flags+=("--diaglevel=") flags+=("--host") local_nonpersistent_flags+=("--host") - flags+=("--images=") - local_nonpersistent_flags+=("--images=") - flags+=("--latest-images") - local_nonpersistent_flags+=("--latest-images") flags+=("--loglevel=") local_nonpersistent_flags+=("--loglevel=") flags+=("--logspec=") local_nonpersistent_flags+=("--logspec=") flags+=("--master-config=") local_nonpersistent_flags+=("--master-config=") - flags+=("--network-logdir=") - local_nonpersistent_flags+=("--network-logdir=") - flags+=("--network-pod-image=") - local_nonpersistent_flags+=("--network-pod-image=") - flags+=("--network-test-pod-image=") - local_nonpersistent_flags+=("--network-test-pod-image=") - flags+=("--network-test-pod-port=") - local_nonpersistent_flags+=("--network-test-pod-port=") - flags+=("--network-test-pod-protocol=") - local_nonpersistent_flags+=("--network-test-pod-protocol=") flags+=("--node-config=") local_nonpersistent_flags+=("--node-config=") flags+=("--prevent-modification") diff --git a/docs/man/man1/.files_generated_oc b/docs/man/man1/.files_generated_oc index dbea9fbcabcb..2ae9c16da197 100644 --- a/docs/man/man1/.files_generated_oc +++ b/docs/man/man1/.files_generated_oc @@ -37,6 +37,25 @@ oc-adm-create-node-config.1 oc-adm-create-provider-selection-template.1 oc-adm-create-server-cert.1 oc-adm-create-signer-cert.1 +oc-adm-diagnostics-AggregatedLogging.1 +oc-adm-diagnostics-AnalyzeLogs.1 +oc-adm-diagnostics-ClusterRegistry.1 +oc-adm-diagnostics-ClusterRoleBindings.1 +oc-adm-diagnostics-ClusterRoles.1 +oc-adm-diagnostics-ClusterRouter.1 +oc-adm-diagnostics-ConfigContexts.1 +oc-adm-diagnostics-DiagnosticPod.1 +oc-adm-diagnostics-EtcdWriteVolume.1 +oc-adm-diagnostics-MasterConfigCheck.1 +oc-adm-diagnostics-MasterNode.1 +oc-adm-diagnostics-MetricsApiProxy.1 +oc-adm-diagnostics-NetworkCheck.1 +oc-adm-diagnostics-NodeConfigCheck.1 +oc-adm-diagnostics-NodeDefinitions.1 +oc-adm-diagnostics-RouteCertificateValidation.1 +oc-adm-diagnostics-ServiceExternalIPs.1 +oc-adm-diagnostics-UnitStatus.1 +oc-adm-diagnostics-all.1 oc-adm-diagnostics.1 oc-adm-drain.1 oc-adm-groups-add-users.1 @@ -171,6 +190,25 @@ oc-env.1 oc-ex-build-chain.1 oc-ex-config-patch.1 oc-ex-config.1 +oc-ex-diagnostics-AggregatedLogging.1 +oc-ex-diagnostics-AnalyzeLogs.1 +oc-ex-diagnostics-ClusterRegistry.1 +oc-ex-diagnostics-ClusterRoleBindings.1 +oc-ex-diagnostics-ClusterRoles.1 +oc-ex-diagnostics-ClusterRouter.1 +oc-ex-diagnostics-ConfigContexts.1 +oc-ex-diagnostics-DiagnosticPod.1 +oc-ex-diagnostics-EtcdWriteVolume.1 +oc-ex-diagnostics-MasterConfigCheck.1 +oc-ex-diagnostics-MasterNode.1 +oc-ex-diagnostics-MetricsApiProxy.1 +oc-ex-diagnostics-NetworkCheck.1 +oc-ex-diagnostics-NodeConfigCheck.1 +oc-ex-diagnostics-NodeDefinitions.1 +oc-ex-diagnostics-RouteCertificateValidation.1 +oc-ex-diagnostics-ServiceExternalIPs.1 +oc-ex-diagnostics-UnitStatus.1 +oc-ex-diagnostics-all.1 oc-ex-diagnostics.1 oc-ex-dockergc.1 oc-ex-ipfailover.1 diff --git a/docs/man/man1/oc-adm-diagnostics-AggregatedLogging.1 b/docs/man/man1/oc-adm-diagnostics-AggregatedLogging.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-AggregatedLogging.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-AnalyzeLogs.1 b/docs/man/man1/oc-adm-diagnostics-AnalyzeLogs.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-AnalyzeLogs.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-ClusterRegistry.1 b/docs/man/man1/oc-adm-diagnostics-ClusterRegistry.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-ClusterRegistry.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-ClusterRoleBindings.1 b/docs/man/man1/oc-adm-diagnostics-ClusterRoleBindings.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-ClusterRoleBindings.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-ClusterRoles.1 b/docs/man/man1/oc-adm-diagnostics-ClusterRoles.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-ClusterRoles.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-ClusterRouter.1 b/docs/man/man1/oc-adm-diagnostics-ClusterRouter.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-ClusterRouter.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-ConfigContexts.1 b/docs/man/man1/oc-adm-diagnostics-ConfigContexts.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-ConfigContexts.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-DiagnosticPod.1 b/docs/man/man1/oc-adm-diagnostics-DiagnosticPod.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-DiagnosticPod.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-EtcdWriteVolume.1 b/docs/man/man1/oc-adm-diagnostics-EtcdWriteVolume.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-EtcdWriteVolume.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-MasterConfigCheck.1 b/docs/man/man1/oc-adm-diagnostics-MasterConfigCheck.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-MasterConfigCheck.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-MasterNode.1 b/docs/man/man1/oc-adm-diagnostics-MasterNode.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-MasterNode.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-MetricsApiProxy.1 b/docs/man/man1/oc-adm-diagnostics-MetricsApiProxy.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-MetricsApiProxy.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-NetworkCheck.1 b/docs/man/man1/oc-adm-diagnostics-NetworkCheck.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-NetworkCheck.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-NodeConfigCheck.1 b/docs/man/man1/oc-adm-diagnostics-NodeConfigCheck.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-NodeConfigCheck.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-NodeDefinitions.1 b/docs/man/man1/oc-adm-diagnostics-NodeDefinitions.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-NodeDefinitions.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-RouteCertificateValidation.1 b/docs/man/man1/oc-adm-diagnostics-RouteCertificateValidation.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-RouteCertificateValidation.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-ServiceExternalIPs.1 b/docs/man/man1/oc-adm-diagnostics-ServiceExternalIPs.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-ServiceExternalIPs.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-UnitStatus.1 b/docs/man/man1/oc-adm-diagnostics-UnitStatus.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-UnitStatus.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-adm-diagnostics-all.1 b/docs/man/man1/oc-adm-diagnostics-all.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-adm-diagnostics-all.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-AggregatedLogging.1 b/docs/man/man1/oc-ex-diagnostics-AggregatedLogging.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-AggregatedLogging.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-AnalyzeLogs.1 b/docs/man/man1/oc-ex-diagnostics-AnalyzeLogs.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-AnalyzeLogs.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-ClusterRegistry.1 b/docs/man/man1/oc-ex-diagnostics-ClusterRegistry.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-ClusterRegistry.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-ClusterRoleBindings.1 b/docs/man/man1/oc-ex-diagnostics-ClusterRoleBindings.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-ClusterRoleBindings.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-ClusterRoles.1 b/docs/man/man1/oc-ex-diagnostics-ClusterRoles.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-ClusterRoles.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-ClusterRouter.1 b/docs/man/man1/oc-ex-diagnostics-ClusterRouter.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-ClusterRouter.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-ConfigContexts.1 b/docs/man/man1/oc-ex-diagnostics-ConfigContexts.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-ConfigContexts.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-DiagnosticPod.1 b/docs/man/man1/oc-ex-diagnostics-DiagnosticPod.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-DiagnosticPod.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-EtcdWriteVolume.1 b/docs/man/man1/oc-ex-diagnostics-EtcdWriteVolume.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-EtcdWriteVolume.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-MasterConfigCheck.1 b/docs/man/man1/oc-ex-diagnostics-MasterConfigCheck.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-MasterConfigCheck.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-MasterNode.1 b/docs/man/man1/oc-ex-diagnostics-MasterNode.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-MasterNode.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-MetricsApiProxy.1 b/docs/man/man1/oc-ex-diagnostics-MetricsApiProxy.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-MetricsApiProxy.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-NetworkCheck.1 b/docs/man/man1/oc-ex-diagnostics-NetworkCheck.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-NetworkCheck.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-NodeConfigCheck.1 b/docs/man/man1/oc-ex-diagnostics-NodeConfigCheck.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-NodeConfigCheck.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-NodeDefinitions.1 b/docs/man/man1/oc-ex-diagnostics-NodeDefinitions.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-NodeDefinitions.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-RouteCertificateValidation.1 b/docs/man/man1/oc-ex-diagnostics-RouteCertificateValidation.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-RouteCertificateValidation.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-ServiceExternalIPs.1 b/docs/man/man1/oc-ex-diagnostics-ServiceExternalIPs.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-ServiceExternalIPs.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-UnitStatus.1 b/docs/man/man1/oc-ex-diagnostics-UnitStatus.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-UnitStatus.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/docs/man/man1/oc-ex-diagnostics-all.1 b/docs/man/man1/oc-ex-diagnostics-all.1 new file mode 100644 index 000000000000..b6fd7a0f9896 --- /dev/null +++ b/docs/man/man1/oc-ex-diagnostics-all.1 @@ -0,0 +1,3 @@ +This file is autogenerated, but we've stopped checking such files into the +repository to reduce the need for rebases. Please run hack/generate-docs.sh to +populate this file. diff --git a/pkg/oc/admin/diagnostics/client.go b/pkg/oc/admin/diagnostics/client.go index d497f3b21163..de0b6c363cb4 100644 --- a/pkg/oc/admin/diagnostics/client.go +++ b/pkg/oc/admin/diagnostics/client.go @@ -6,21 +6,22 @@ import ( "k8s.io/apimachinery/pkg/util/sets" clientcmdapi "k8s.io/client-go/tools/clientcmd/api" + "github.com/openshift/origin/pkg/cmd/util/variable" clientdiags "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/client" networkdiags "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/network" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" ) -var ( - // availableClientDiagnostics contains the names of client diagnostics that can be executed - // during a single run of diagnostics. Add more diagnostics to the list as they are defined. - availableClientDiagnostics = sets.NewString(clientdiags.ConfigContextsName, clientdiags.DiagnosticPodName, networkdiags.NetworkDiagnosticName) -) +// availableClientDiagnostics returns definitions of client diagnostics that can be executed +// during a single run of diagnostics. Add more diagnostics to the list as they are defined. +func availableClientDiagnostics() types.DiagnosticList { + return types.DiagnosticList{clientdiags.ConfigContext{}, &clientdiags.DiagnosticPod{}, &networkdiags.NetworkDiagnostic{}} +} // buildClientDiagnostics builds client Diagnostic objects based on the rawConfig passed in. // Returns the Diagnostics built, "ok" bool for whether to proceed or abort, and an error if any was encountered during the building of diagnostics.) { -func (o DiagnosticsOptions) buildClientDiagnostics(rawConfig *clientcmdapi.Config) ([]types.Diagnostic, bool, error) { - available := availableClientDiagnostics +func (o DiagnosticsConfig) buildClientDiagnostics(rawConfig *clientcmdapi.Config) ([]types.Diagnostic, bool, error) { + available := availableClientDiagnostics().Names() networkClient, err := o.Factory.OpenshiftInternalNetworkClient() kubeClient, clientErr := o.Factory.ClientSet() @@ -30,7 +31,7 @@ func (o DiagnosticsOptions) buildClientDiagnostics(rawConfig *clientcmdapi.Confi } diagnostics := []types.Diagnostic{} - requestedDiagnostics := available.Intersection(sets.NewString(o.RequestedDiagnostics...)).List() + requestedDiagnostics := available.Intersection(sets.NewString(o.RequestedDiagnostics.List()...)).List() for _, diagnosticName := range requestedDiagnostics { switch diagnosticName { case clientdiags.ConfigContextsName: @@ -52,23 +53,18 @@ func (o DiagnosticsOptions) buildClientDiagnostics(rawConfig *clientcmdapi.Confi Level: o.LogOptions.Level, Factory: o.Factory, PreventModification: o.PreventModification, - ImageTemplate: o.ImageTemplate, + ImageTemplate: variable.NewDefaultImageTemplate(), }) case networkdiags.NetworkDiagnosticName: - diagnostics = append(diagnostics, &networkdiags.NetworkDiagnostic{ - KubeClient: kubeClient, - NetNamespacesClient: networkClient.Network(), - ClusterNetworkClient: networkClient.Network(), - ClientFlags: o.ClientFlags, - Level: o.LogOptions.Level, - Factory: o.Factory, - PreventModification: o.PreventModification, - LogDir: o.NetworkOptions.LogDir, - PodImage: o.NetworkOptions.PodImage, - TestPodImage: o.NetworkOptions.TestPodImage, - TestPodProtocol: o.NetworkOptions.TestPodProtocol, - TestPodPort: o.NetworkOptions.TestPodPort, - }) + nd := o.ParameterizedDiagnostics[diagnosticName].(*networkdiags.NetworkDiagnostic) + nd.KubeClient = kubeClient + nd.NetNamespacesClient = networkClient.Network() + nd.ClusterNetworkClient = networkClient.Network() + nd.ClientFlags = o.ClientFlags + nd.Level = o.LogOptions.Level + nd.Factory = o.Factory + nd.PreventModification = o.PreventModification + diagnostics = append(diagnostics, nd) default: return nil, false, fmt.Errorf("unknown diagnostic: %v", diagnosticName) } diff --git a/pkg/oc/admin/diagnostics/cluster.go b/pkg/oc/admin/diagnostics/cluster.go index d1e4f3f3b7dd..f8b38766e7d2 100644 --- a/pkg/oc/admin/diagnostics/cluster.go +++ b/pkg/oc/admin/diagnostics/cluster.go @@ -25,27 +25,27 @@ import ( "k8s.io/kubernetes/pkg/apis/authorization" ) -var ( - // availableClusterDiagnostics contains the names of cluster diagnostics that can be executed - // during a single run of diagnostics. Add more diagnostics to the list as they are defined. - availableClusterDiagnostics = sets.NewString( - agldiags.AggregatedLoggingName, - clustdiags.ClusterRegistryName, - clustdiags.ClusterRouterName, - clustdiags.ClusterRolesName, - clustdiags.ClusterRoleBindingsName, - clustdiags.MasterNodeName, - clustdiags.MetricsApiProxyName, - clustdiags.NodeDefinitionsName, - clustdiags.RouteCertificateValidationName, - clustdiags.ServiceExternalIPsName, - ) -) +// availableClusterDiagnostics contains the names of cluster diagnostics that can be executed +// during a single run of diagnostics. Add more diagnostics to the list as they are defined. +func availableClusterDiagnostics() types.DiagnosticList { + return types.DiagnosticList{ + &agldiags.AggregatedLogging{}, + &clustdiags.ClusterRegistry{}, + &clustdiags.ClusterRouter{}, + &clustdiags.ClusterRoles{}, + &clustdiags.ClusterRoleBindings{}, + &clustdiags.MasterNode{}, + &clustdiags.MetricsApiProxy{}, + &clustdiags.NodeDefinitions{}, + &clustdiags.RouteCertificateValidation{}, + &clustdiags.ServiceExternalIPs{}, + } +} // buildClusterDiagnostics builds cluster Diagnostic objects if a cluster-admin client can be extracted from the rawConfig passed in. // Returns the Diagnostics built, "ok" bool for whether to proceed or abort, and an error if any was encountered during the building of diagnostics.) { -func (o DiagnosticsOptions) buildClusterDiagnostics(rawConfig *clientcmdapi.Config) ([]types.Diagnostic, bool, error) { - requestedDiagnostics := availableClusterDiagnostics.Intersection(sets.NewString(o.RequestedDiagnostics...)).List() +func (o DiagnosticsConfig) buildClusterDiagnostics(rawConfig *clientcmdapi.Config) ([]types.Diagnostic, bool, error) { + requestedDiagnostics := availableClusterDiagnostics().Names().Intersection(sets.NewString(o.RequestedDiagnostics.List()...)).List() if len(requestedDiagnostics) == 0 { // no diagnostics to run here return nil, true, nil // don't waste time on discovery } @@ -124,7 +124,7 @@ func (o DiagnosticsOptions) buildClusterDiagnostics(rawConfig *clientcmdapi.Conf } // attempts to find which context in the config might be a cluster-admin for the server in the current context. -func (o DiagnosticsOptions) findClusterClients(rawConfig *clientcmdapi.Config) (*rest.Config, kclientset.Interface, bool, string, error) { +func (o DiagnosticsConfig) findClusterClients(rawConfig *clientcmdapi.Config) (*rest.Config, kclientset.Interface, bool, string, error) { if o.ClientClusterContext != "" { // user has specified cluster context to use if context, exists := rawConfig.Contexts[o.ClientClusterContext]; exists { configErr := fmt.Errorf("Specified '%s' as cluster-admin context, but it was not found in your client configuration.", o.ClientClusterContext) @@ -160,7 +160,7 @@ func (o DiagnosticsOptions) findClusterClients(rawConfig *clientcmdapi.Config) ( } // makes the client from the specified context and determines whether it is a cluster-admin. -func (o DiagnosticsOptions) makeClusterClients(rawConfig *clientcmdapi.Config, contextName string, context *clientcmdapi.Context) (*rest.Config, kclientset.Interface, bool, string, error) { +func (o DiagnosticsConfig) makeClusterClients(rawConfig *clientcmdapi.Config, contextName string, context *clientcmdapi.Context) (*rest.Config, kclientset.Interface, bool, string, error) { overrides := &clientcmd.ConfigOverrides{Context: *context} clientConfig := clientcmd.NewDefaultClientConfig(*rawConfig, overrides) serverUrl := rawConfig.Clusters[context.Cluster].Server diff --git a/pkg/oc/admin/diagnostics/config.go b/pkg/oc/admin/diagnostics/config.go index 94f890695477..b21782fc544c 100644 --- a/pkg/oc/admin/diagnostics/config.go +++ b/pkg/oc/admin/diagnostics/config.go @@ -11,18 +11,21 @@ import ( ) // determine if we even have a client config -func (o DiagnosticsOptions) detectClientConfig() (bool, []types.DiagnosticError, []types.DiagnosticError) { +func (o DiagnosticsConfig) detectClientConfig() (bool, bool, []types.DiagnosticError, []types.DiagnosticError) { + if o.ClientFlags == nil { + return false, false, []types.DiagnosticError{}, []types.DiagnosticError{} + } diagnostic := &clientdiagnostics.ConfigLoading{ConfFlagName: config.OpenShiftConfigFlagName, ClientFlags: o.ClientFlags} o.Logger.Notice("CED2011", "Determining if client configuration exists for client/cluster diagnostics") result := diagnostic.Check() for _, entry := range result.Logs() { o.Logger.LogEntry(entry) } - return diagnostic.SuccessfulLoad(), result.Warnings(), result.Errors() + return true, diagnostic.SuccessfulLoad(), result.Warnings(), result.Errors() } // use the base factory to return a raw config (not specific to a context) -func (o DiagnosticsOptions) buildRawConfig() (*clientcmdapi.Config, error) { +func (o DiagnosticsConfig) buildRawConfig() (*clientcmdapi.Config, error) { kubeConfig, configErr := o.Factory.OpenShiftClientConfig().RawConfig() if configErr != nil { return nil, configErr diff --git a/pkg/oc/admin/diagnostics/diagnostics.go b/pkg/oc/admin/diagnostics/diagnostics.go index 7445b7866b65..177fc83950ce 100644 --- a/pkg/oc/admin/diagnostics/diagnostics.go +++ b/pkg/oc/admin/diagnostics/diagnostics.go @@ -4,7 +4,6 @@ import ( "fmt" "io" "os" - "path/filepath" "runtime/debug" "strings" @@ -13,35 +12,32 @@ import ( kutilerrors "k8s.io/apimachinery/pkg/util/errors" "k8s.io/apimachinery/pkg/util/sets" - kvalidation "k8s.io/apimachinery/pkg/util/validation" - kapi "k8s.io/kubernetes/pkg/apis/core" "k8s.io/kubernetes/pkg/kubectl/cmd/templates" kcmdutil "k8s.io/kubernetes/pkg/kubectl/cmd/util" "github.com/openshift/origin/pkg/client/config" "github.com/openshift/origin/pkg/cmd/flagtypes" - "github.com/openshift/origin/pkg/cmd/util/variable" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/log" - netutil "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/networkpod/util" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" "github.com/openshift/origin/pkg/oc/admin/diagnostics/options" osclientcmd "github.com/openshift/origin/pkg/oc/cli/util/clientcmd" ) -// DiagnosticsOptions holds values received from command line flags as well as +// DiagnosticsConfig holds values received from command line flags as well as // other objects generated for the command to operate. -type DiagnosticsOptions struct { - // list of diagnostic names to limit what is run - RequestedDiagnostics []string +type DiagnosticsConfig struct { + // list of diagnostic name(s) to run + RequestedDiagnostics sets.String + // flag bindings for any diagnostics that require them + ParameterizedDiagnostics types.ParameterizedDiagnosticMap + + // list available diagnostics and exit + ListAll bool // specify locations of host config files MasterConfigLocation string NodeConfigLocation string - // specify context name to be used for cluster-admin access - ClientClusterContext string // indicate this is an openshift host despite lack of other indicators IsHost bool - // specify the image template to use for DiagnosticPod - ImageTemplate variable.ImageTemplate // When true, prevent diagnostics from changing API state (e.g. creating something) PreventModification bool // We need a factory for creating clients. Creating a factory @@ -49,16 +45,16 @@ type DiagnosticsOptions struct { // The command creates these and binds only the flags we want. ClientFlags *flag.FlagSet Factory *osclientcmd.Factory + // specify context name to be used for cluster-admin access + ClientClusterContext string // LogOptions determine globally what the user wants to see and how. LogOptions *log.LoggerOptions // The Logger is built with the options and should be used for all diagnostic output. Logger *log.Logger - // Options specific to network diagnostics - NetworkOptions *NetworkDiagnosticsOptions } // NetworkDiagnosticsOptions holds additional values received from command line flags that -// are specify to network diagnostics. +// are specific to network diagnostics. type NetworkDiagnosticsOptions struct { // Path to store network diagnostic results in case of errors LogDir string @@ -73,7 +69,9 @@ type NetworkDiagnosticsOptions struct { } const ( - DiagnosticsRecommendedName = "diagnostics" + // Command name + DiagnosticsRecommendedName = "diagnostics" + AllDiagnosticsRecommendedName = "all" // Standard locations for the host config files OpenShift uses. StandardMasterConfigPath string = "/etc/origin/master/master-config.yaml" @@ -82,50 +80,100 @@ const ( var ( longDescription = templates.LongDesc(` - This utility helps troubleshoot and diagnose known problems. It runs - diagnostics using a client and/or the state of a running master / - node host. + This utility helps troubleshoot and diagnose known problems for an OpenShift cluster + and/or local host. The base command runs a standard set of diagnostics: %[1]s - If run without flags, it will check for standard config files for - client, master, and node, and if found, use them for diagnostics. - You may also specify config files explicitly with flags, in which case - you will receive an error if they are not found. For example: + Available diagnostics vary based on client config and local OpenShift host config. + Config files in standard locations for client, master, and node are used, or + you may specify config files explicitly with flags. For example: %[1]s --master-config=/etc/origin/master/master-config.yaml - * If master/node config files are not found and the --host flag is not - present, host diagnostics are skipped. - * If the client has cluster-admin access, this access enables cluster - diagnostics to run which regular users cannot. - * If a client config file is not found, client and cluster diagnostics - are skipped. + * Explicitly specifying a config file raises an error if it is not found. + * A client config with cluster-admin access is required for most cluster diagnostics. + * Diagnostics that require a config file are skipped if it is not found. + * The standard set also skips diagnostics considered too heavyweight. - Diagnostics may be individually run by passing diagnostic name as arguments. + An individual diagnostic may be run as a subcommand which may have flags + for specifying options specific to that diagnostic. + + Finally, the "all" subcommand runs all available diagnostics (including heavyweight + ones skipped in the standard set) and provides all individual diagnostic flags. + `) + longDescriptionAll = templates.LongDesc(` + This utility helps troubleshoot and diagnose known problems for an OpenShift cluster + and/or local host. This subcommand exists to run all available diagnostics: + + %[1]s - %[1]s + Available diagnostics vary based on client config and local OpenShift host config. + All flags from the base command work similarly here, but all possible flags for + individual diagnostics are also available. + `) + longDescriptionIndividual = templates.LongDesc(` + Runs the %s diagnostic. - The available diagnostic names are: %[2]s.`) + %s + `) ) // NewCmdDiagnostics is the base command for running any diagnostics. func NewCmdDiagnostics(name string, fullName string, out io.Writer) *cobra.Command { - o := &DiagnosticsOptions{ - RequestedDiagnostics: []string{}, - LogOptions: &log.LoggerOptions{Out: out}, - ImageTemplate: variable.NewDefaultImageTemplate(), - NetworkOptions: &NetworkDiagnosticsOptions{}, + available := availableDiagnostics() + o := &DiagnosticsConfig{ + RequestedDiagnostics: available.Names().Difference(defaultSkipDiagnostics()), + ParameterizedDiagnostics: types.NewParameterizedDiagnosticMap(available...), + LogOptions: &log.LoggerOptions{Out: out}, } cmd := &cobra.Command{ Use: name, Short: "Diagnose common cluster problems", - Long: fmt.Sprintf(longDescription, fullName, strings.Join(availableDiagnostics().List(), ", ")), + Long: fmt.Sprintf(longDescription, fullName), Run: func(c *cobra.Command, args []string) { - kcmdutil.CheckErr(o.Complete(args)) + kcmdutil.CheckErr(o.Complete(c, args)) + + failed, err, warnCount, errorCount := o.RunDiagnostics() + o.Logger.Summary(warnCount, errorCount) + + kcmdutil.CheckErr(err) + if failed { + os.Exit(255) + } + + }, + } + cmd.SetOutput(out) // for output re: usage / help + o.bindCommonFlags(cmd.Flags()) + o.bindClientFlags(cmd.Flags()) + o.bindHostFlags(cmd.Flags()) + + // add "all" subcommand + cmd.AddCommand(NewCmdDiagnosticsAll(AllDiagnosticsRecommendedName, fullName+" "+AllDiagnosticsRecommendedName, out, available)) + // add individual diagnostic subcommands + for _, diag := range available { + cmd.AddCommand(NewCmdDiagnosticsIndividual(diag.Name(), fullName+" "+diag.Name(), out, diag)) + } - kcmdutil.CheckErr(o.Validate()) + return cmd +} + +// NewCmdDiagnosticsAll is the command for running ALL diagnostics and providing all flags. +func NewCmdDiagnosticsAll(name string, fullName string, out io.Writer, available types.DiagnosticList) *cobra.Command { + o := &DiagnosticsConfig{ + RequestedDiagnostics: available.Names(), + ParameterizedDiagnostics: types.NewParameterizedDiagnosticMap(available...), + LogOptions: &log.LoggerOptions{Out: out}, + } + + cmd := &cobra.Command{ + Use: name, + Short: "Diagnose common cluster problems", + Long: fmt.Sprintf(longDescriptionAll, fullName), + Run: func(c *cobra.Command, args []string) { + kcmdutil.CheckErr(o.Complete(c, args)) failed, err, warnCount, errorCount := o.RunDiagnostics() o.Logger.Summary(warnCount, errorCount) @@ -138,37 +186,130 @@ func NewCmdDiagnostics(name string, fullName string, out io.Writer) *cobra.Comma }, } cmd.SetOutput(out) // for output re: usage / help + o.bindCommonFlags(cmd.Flags()) + o.bindClientFlags(cmd.Flags()) + o.bindHostFlags(cmd.Flags()) + o.bindRequestedIndividualFlags(cmd.Flags()) + return cmd +} + +// NewCmdDiagnosticsIndividual is a generic subcommand providing a single diagnostic and its flags. +func NewCmdDiagnosticsIndividual(name string, fullName string, out io.Writer, diagnostic types.Diagnostic) *cobra.Command { + o := &DiagnosticsConfig{ + RequestedDiagnostics: sets.NewString(diagnostic.Name()), + ParameterizedDiagnostics: types.NewParameterizedDiagnosticMap(diagnostic), + LogOptions: &log.LoggerOptions{Out: out}, + } + + cmd := &cobra.Command{ + Use: name, + Short: diagnostic.Description(), + Long: fmt.Sprintf(longDescriptionIndividual, name, diagnostic.Description()), + Run: func(c *cobra.Command, args []string) { + kcmdutil.CheckErr(o.Complete(c, args)) + + failed, err, warnCount, errorCount := o.RunDiagnostics() + o.Logger.Summary(warnCount, errorCount) + + kcmdutil.CheckErr(err) + if failed { + os.Exit(255) + } + + }, + } + cmd.SetOutput(out) // for output re: usage / help + o.bindCommonFlags(cmd.Flags()) + needClient, needHost := diagnostic.Requirements() + if pd, ok := diagnostic.(types.ParameterizedDiagnostic); ok { + bindIndividualFlags(pd, "", cmd.Flags()) + } + if needClient { + o.bindClientFlags(cmd.Flags()) + } + if needHost { + o.bindHostFlags(cmd.Flags()) + } + return cmd +} +// gather a list of all diagnostics that are available to be invoked by the main command +func availableDiagnostics() types.DiagnosticList { + available := availableClientDiagnostics() + available = append(available, availableClusterDiagnostics()...) + available = append(available, availableHostDiagnostics()...) + return available +} + +// gather a list of diagnostic names to skip when running the main command +func defaultSkipDiagnostics() sets.String { + toSkip := sets.NewString() + toSkip.Insert(defaultSkipHostDiagnostics.List()...) + return toSkip +} + +// bind flags that are available on all user-facing commands +func (o *DiagnosticsConfig) bindCommonFlags(flags *flag.FlagSet) { + flagtypes.GLog(flags) + options.BindLoggerOptionFlags(flags, o.LogOptions, options.RecommendedLoggerOptionFlags()) +} + +// bind flags that are necessary for setting up an API client +func (o *DiagnosticsConfig) bindClientFlags(flags *flag.FlagSet) { o.ClientFlags = flag.NewFlagSet("client", flag.ContinueOnError) // hide the extensive set of client flags o.Factory = osclientcmd.New(o.ClientFlags) // that would otherwise be added to this command - cmd.Flags().AddFlag(o.ClientFlags.Lookup(config.OpenShiftConfigFlagName)) - cmd.Flags().AddFlag(o.ClientFlags.Lookup("context")) // TODO: find k8s constant - cmd.Flags().StringVar(&o.ClientClusterContext, options.FlagClusterContextName, "", "Client context to use for cluster administrator") - cmd.Flags().StringVar(&o.MasterConfigLocation, options.FlagMasterConfigName, "", "Path to master config file (implies --host)") - cmd.Flags().StringVar(&o.NodeConfigLocation, options.FlagNodeConfigName, "", "Path to node config file (implies --host)") - cmd.Flags().BoolVar(&o.IsHost, options.FlagIsHostName, false, "If true, look for systemd and journald units even without master/node config") - cmd.Flags().StringVar(&o.ImageTemplate.Format, options.FlagImageTemplateName, o.ImageTemplate.Format, "Image template for DiagnosticPod to use in creating a pod") - cmd.Flags().BoolVar(&o.ImageTemplate.Latest, options.FlagLatestImageName, false, "If true, when expanding the image template, use latest version, not release version") - cmd.Flags().BoolVar(&o.PreventModification, options.FlagPreventModificationName, false, "If true, may be set to prevent diagnostics making any changes via the API") - cmd.Flags().StringVar(&o.NetworkOptions.LogDir, options.FlagNetworkDiagLogDir, netutil.NetworkDiagDefaultLogDir, "Path to store network diagnostic results in case of errors") - cmd.Flags().StringVar(&o.NetworkOptions.PodImage, options.FlagNetworkDiagPodImage, netutil.GetNetworkDiagDefaultPodImage(), "Image to use for network diagnostic pod") - cmd.Flags().StringVar(&o.NetworkOptions.TestPodImage, options.FlagNetworkDiagTestPodImage, netutil.GetNetworkDiagDefaultTestPodImage(), "Image to use for network diagnostic test pod") - cmd.Flags().StringVar(&o.NetworkOptions.TestPodProtocol, options.FlagNetworkDiagTestPodProtocol, netutil.NetworkDiagDefaultTestPodProtocol, "Protocol used to connect to network diagnostic test pod") - cmd.Flags().IntVar(&o.NetworkOptions.TestPodPort, options.FlagNetworkDiagTestPodPort, netutil.NetworkDiagDefaultTestPodPort, "Serving port on the network diagnostic test pod") - flagtypes.GLog(cmd.Flags()) - options.BindLoggerOptionFlags(cmd.Flags(), o.LogOptions, options.RecommendedLoggerOptionFlags()) + flags.AddFlag(o.ClientFlags.Lookup(config.OpenShiftConfigFlagName)) + flags.AddFlag(o.ClientFlags.Lookup("context")) // TODO: find k8s constant + flags.StringVar(&o.ClientClusterContext, options.FlagClusterContextName, "", "Client context to use for cluster administrator") + flags.BoolVar(&o.PreventModification, options.FlagPreventModificationName, false, "If true, may be set to prevent diagnostics making any changes via the API") +} - return cmd +// bind flags that are used by host diagnostics +func (o *DiagnosticsConfig) bindHostFlags(flags *flag.FlagSet) { + flags.StringVar(&o.MasterConfigLocation, options.FlagMasterConfigName, "", "Path to master config file (implies --host)") + flags.StringVar(&o.NodeConfigLocation, options.FlagNodeConfigName, "", "Path to node config file (implies --host)") + flags.BoolVar(&o.IsHost, options.FlagIsHostName, false, "If true, look for systemd and journald units even without master/node config") +} + +// bind flags for all diagnostics that have their own parameters +func (o *DiagnosticsConfig) bindRequestedIndividualFlags(flags *flag.FlagSet) { + for name, diag := range o.ParameterizedDiagnostics { + if o.RequestedDiagnostics.Has(name) { + bindIndividualFlags(diag, strings.ToLower(diag.Name()+"-"), flags) + } + } } -// Complete fills in DiagnosticsOptions needed if the command is actually invoked. -func (o *DiagnosticsOptions) Complete(args []string) error { +// bind flags for parameters on a single diagnostic +func bindIndividualFlags(diag types.ParameterizedDiagnostic, prefix string, flags *flag.FlagSet) { + for _, param := range diag.AvailableParameters() { + name := prefix + param.Name + switch target := param.Target.(type) { + case *string: + flags.StringVar(target, name, param.Default.(string), param.Description) + case *int: + flags.IntVar(target, name, param.Default.(int), param.Description) + case *bool: + flags.BoolVar(target, name, param.Default.(bool), param.Description) + default: + panic("Don't know what to do with parameter") + } + } +} + +// Complete fills in DiagnosticsConfig needed if the command is actually invoked. +func (o *DiagnosticsConfig) Complete(c *cobra.Command, args []string) error { var err error o.Logger, err = o.LogOptions.NewLogger() if err != nil { return err } + if len(args) > 0 { + c.Usage() + return fmt.Errorf("\nUnexpected command line argument(s): %v", args) + } + // If not given master/client config file locations, check if the defaults exist // and adjust the options accordingly: if len(o.MasterConfigLocation) == 0 { @@ -182,85 +323,11 @@ func (o *DiagnosticsOptions) Complete(args []string) error { } } - if len(o.NetworkOptions.LogDir) == 0 { - o.NetworkOptions.LogDir = netutil.NetworkDiagDefaultLogDir - } else { - logdir, err := filepath.Abs(o.NetworkOptions.LogDir) - if err != nil { - return err - } - if path, err := os.Stat(o.NetworkOptions.LogDir); err == nil && !path.Mode().IsDir() { - return fmt.Errorf("Network log path %q exists but is not a directory", o.NetworkOptions.LogDir) - } - o.NetworkOptions.LogDir = logdir - } - if len(o.NetworkOptions.PodImage) == 0 { - o.NetworkOptions.PodImage = netutil.GetNetworkDiagDefaultPodImage() - } - if len(o.NetworkOptions.TestPodImage) == 0 { - o.NetworkOptions.TestPodImage = netutil.GetNetworkDiagDefaultTestPodImage() - } - - supportedProtocols := sets.NewString(string(kapi.ProtocolTCP), string(kapi.ProtocolUDP)) - if !supportedProtocols.Has(o.NetworkOptions.TestPodProtocol) { - return fmt.Errorf("invalid protocol for network diagnostic test pod. Supported protocols: %s", strings.Join(supportedProtocols.List(), ",")) - } - if kvalidation.IsValidPortNum(o.NetworkOptions.TestPodPort) != nil { - return fmt.Errorf("invalid port for network diagnostic test pod. Must be in the range 1 to 65535.") - } - - o.RequestedDiagnostics = append(o.RequestedDiagnostics, args...) - if len(o.RequestedDiagnostics) == 0 { - o.RequestedDiagnostics = availableDiagnostics().Difference(defaultSkipDiagnostics()).List() - } - - return nil -} - -func (o *DiagnosticsOptions) Validate() error { - available := availableDiagnostics() - - if common := available.Intersection(sets.NewString(o.RequestedDiagnostics...)); len(common) == 0 { - o.Logger.Error("CED3012", log.EvalTemplate("CED3012", "None of the requested diagnostics are available:\n {{.requested}}\nPlease try from the following:\n {{.available}}", - log.Hash{"requested": o.RequestedDiagnostics, "available": available.List()})) - return fmt.Errorf("No requested diagnostics are available: requested=%s available=%s", strings.Join(o.RequestedDiagnostics, " "), strings.Join(available.List(), " ")) - - } else if len(common) < len(o.RequestedDiagnostics) { - o.Logger.Error("CED3013", log.EvalTemplate("CED3013", ` -Of the requested diagnostics: - {{.requested}} -only these are available: - {{.common}} -The list of all possible is: - {{.available}} - `, log.Hash{"requested": o.RequestedDiagnostics, "common": common.List(), "available": available.List()})) - - return fmt.Errorf("Not all requested diagnostics are available: missing=%s requested=%s available=%s", - strings.Join(sets.NewString(o.RequestedDiagnostics...).Difference(available).List(), " "), - strings.Join(o.RequestedDiagnostics, " "), - strings.Join(available.List(), " ")) - } - return nil } -func availableDiagnostics() sets.String { - available := sets.NewString() - available.Insert(availableClientDiagnostics.List()...) - available.Insert(availableClusterDiagnostics.List()...) - available.Insert(availableEtcdDiagnostics.List()...) - available.Insert(availableHostDiagnostics.List()...) - return available -} - -func defaultSkipDiagnostics() sets.String { - available := sets.NewString() - available.Insert(defaultSkipEtcdDiagnostics.List()...) - return available -} - // RunDiagnostics builds diagnostics based on the options and executes them, returning a summary. -func (o DiagnosticsOptions) RunDiagnostics() (bool, error, int, int) { +func (o DiagnosticsConfig) RunDiagnostics() (bool, error, int, int) { failed := false warnings := []error{} errors := []error{} @@ -274,14 +341,19 @@ func (o DiagnosticsOptions) RunDiagnostics() (bool, error, int, int) { errors = append(errors, fmt.Errorf("While building the diagnostics, a panic was encountered.\nThis is a bug in diagnostics. Error and stack trace follow: \n%v\n%s", r, stack)) } }() - detected, detectWarnings, detectErrors := o.detectClientConfig() // may log and return problems + + // build client/cluster diags if there is a client config for them to use + expected, detected, detectWarnings, detectErrors := o.detectClientConfig() // may log and return problems for _, warn := range detectWarnings { warnings = append(warnings, warn) } for _, err := range detectErrors { errors = append(errors, err) } - if !detected { // there just plain isn't any client config file available + if !expected { + // no diagnostic required a client config, nothing to do + } else if !detected { + // there just plain isn't any client config file available o.Logger.Notice("CED3014", "No client configuration specified; skipping client and cluster diagnostics.") } else if rawConfig, err := o.buildRawConfig(); err != nil { // client config is totally broken - won't parse etc (problems may have been detected and logged) o.Logger.Error("CED3015", fmt.Sprintf("Client configuration failed to load; skipping client and cluster diagnostics due to error: %s", err.Error())) @@ -306,12 +378,7 @@ func (o DiagnosticsOptions) RunDiagnostics() (bool, error, int, int) { } } - etcdDiags, ok, err := o.buildEtcdDiagnostics() - failed = failed || !ok - if ok { - diagnostics = append(diagnostics, etcdDiags...) - } - + // build host diagnostics if config is available hostDiags, ok, err := o.buildHostDiagnostics() failed = failed || !ok if ok { @@ -320,6 +387,16 @@ func (o DiagnosticsOptions) RunDiagnostics() (bool, error, int, int) { if err != nil { errors = append(errors, err) } + + // complete any diagnostics that require it + for _, d := range diagnostics { + if toComplete, ok := d.(types.IncompleteDiagnostic); ok { + if err := toComplete.Complete(o.Logger); err != nil { + errors = append(errors, err) + failed = true + } + } + } }() if failed { @@ -333,7 +410,7 @@ func (o DiagnosticsOptions) RunDiagnostics() (bool, error, int, int) { } // Run performs the actual execution of diagnostics once they're built. -func (o DiagnosticsOptions) Run(diagnostics []types.Diagnostic) (bool, error, int, int) { +func (o DiagnosticsConfig) Run(diagnostics []types.Diagnostic) (bool, error, int, int) { warnCount := 0 errorCount := 0 for _, diagnostic := range diagnostics { diff --git a/pkg/oc/admin/diagnostics/diagnostics/client/config_contexts.go b/pkg/oc/admin/diagnostics/diagnostics/client/config_contexts.go index 753029c2e0f5..30d4eacc9f11 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/client/config_contexts.go +++ b/pkg/oc/admin/diagnostics/diagnostics/client/config_contexts.go @@ -154,6 +154,9 @@ var ( // Name is part of the Diagnostic interface and just returns name. func (d ConfigContext) Name() string { + if d.ContextName == "" { + return ConfigContextsName + } return fmt.Sprintf("%s[%s]", ConfigContextsName, d.ContextName) } @@ -162,6 +165,10 @@ func (d ConfigContext) Description() string { return "Validate client config context is complete and has connectivity" } +func (d ConfigContext) Requirements() (client bool, host bool) { + return true, false +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d ConfigContext) CanRun() (bool, error) { if d.RawConfig == nil { diff --git a/pkg/oc/admin/diagnostics/diagnostics/client/run_diagnostics_pod.go b/pkg/oc/admin/diagnostics/diagnostics/client/run_diagnostics_pod.go index c42beb25e2d3..4b051854011d 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/client/run_diagnostics_pod.go +++ b/pkg/oc/admin/diagnostics/diagnostics/client/run_diagnostics_pod.go @@ -20,7 +20,9 @@ import ( ) const ( - DiagnosticPodName = "DiagnosticPod" + DiagnosticPodName = "DiagnosticPod" + ImageTemplateParam = "images" + LatestImageParam = "latest-images" ) // DiagnosticPod is a diagnostic that runs a diagnostic pod and relays the results. @@ -43,6 +45,17 @@ func (d *DiagnosticPod) Description() string { return "Create a pod to run diagnostics from the application standpoint" } +func (d *DiagnosticPod) Requirements() (client bool, host bool) { + return true, false +} + +func (d *DiagnosticPod) AvailableParameters() []types.Parameter { + return []types.Parameter{ + {ImageTemplateParam, "Image template to use in creating a pod", &d.ImageTemplate.Format, variable.NewDefaultImageTemplate().Format}, + {LatestImageParam, "If true, when expanding the image template, use latest version, not release version", &d.ImageTemplate.Latest, false}, + } +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d *DiagnosticPod) CanRun() (bool, error) { if d.PreventModification { diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/aggregated_logging/diagnostic.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/aggregated_logging/diagnostic.go index 0063214451ec..bbaa7257bfd8 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/aggregated_logging/diagnostic.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/aggregated_logging/diagnostic.go @@ -18,6 +18,7 @@ import ( configapi "github.com/openshift/origin/pkg/cmd/server/api" oauthtypedclient "github.com/openshift/origin/pkg/oauth/generated/internalclientset/typed/oauth/internalversion" hostdiag "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/host" + "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/log" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" projecttypedclient "github.com/openshift/origin/pkg/project/generated/internalclientset/typed/project/internalversion" routesapi "github.com/openshift/origin/pkg/route/apis/route" @@ -144,8 +145,23 @@ func (d *AggregatedLogging) Description() string { return "Check aggregated logging integration for proper configuration" } +func (d *AggregatedLogging) Requirements() (client bool, host bool) { + return true, false +} + +func (d *AggregatedLogging) Complete(logger *log.Logger) error { + if len(d.MasterConfigFile) > 0 { + var err error + d.masterConfig, err = hostdiag.GetMasterConfig(d.MasterConfigFile, logger) + if err != nil { + return err + } + } + return nil +} + func (d *AggregatedLogging) CanRun() (bool, error) { - if len(d.MasterConfigFile) == 0 { + if len(d.MasterConfigFile) == 0 || d.masterConfig == nil { return false, errors.New("No master config file was provided") } if d.OAuthClientClient == nil || d.ProjectClient == nil || d.RouteClient == nil || d.CRBClient == nil || d.DCClient == nil { @@ -154,11 +170,6 @@ func (d *AggregatedLogging) CanRun() (bool, error) { if d.KubeClient == nil { return false, errors.New("Config must include a cluster-admin context to run this diagnostic") } - var err error - d.masterConfig, err = hostdiag.GetMasterConfig(d.result, d.MasterConfigFile) - if err != nil { - return false, errors.New("Master configuration is unreadable") - } if d.masterConfig.AssetConfig.LoggingPublicURL == "" { return false, errors.New("No LoggingPublicURL is defined in the master configuration") } diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/master_node.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/master_node.go index e0593ffea1ca..1375b66ca19c 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/master_node.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/master_node.go @@ -41,6 +41,10 @@ func (d *MasterNode) Description() string { return "Check if master is also running node (for Open vSwitch)" } +func (d *MasterNode) Requirements() (client bool, host bool) { + return true, true +} + func (d *MasterNode) CanRun() (bool, error) { if d.KubeClient == nil { return false, errors.New("must have kube client") diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/metrics.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/metrics.go index c60921684cdd..533cf30558f5 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/metrics.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/metrics.go @@ -40,6 +40,10 @@ func (d *MetricsApiProxy) Description() string { return "Check the integrated heapster metrics can be reached via the API proxy" } +func (d *MetricsApiProxy) Requirements() (client bool, host bool) { + return true, false +} + func (d *MetricsApiProxy) CanRun() (bool, error) { if d.KubeClient == nil { return false, errors.New("must have kube client") diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/node_definitions.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/node_definitions.go index edc732455418..fd224ea6c001 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/node_definitions.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/node_definitions.go @@ -60,9 +60,13 @@ func (d *NodeDefinitions) Description() string { return "Check node records on master" } +func (d *NodeDefinitions) Requirements() (client bool, host bool) { + return true, false +} + func (d *NodeDefinitions) CanRun() (bool, error) { if d.KubeClient == nil { - return false, errors.New("must have kube client") + return false, errors.New("must have kube client") } can, err := userCan(d.KubeClient.Authorization(), &authorization.ResourceAttributes{ Verb: "list", diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/registry.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/registry.go index 59dc33c54704..dd280f5a4db4 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/registry.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/registry.go @@ -154,6 +154,10 @@ func (d *ClusterRegistry) Description() string { return "Check that there is a working Docker registry" } +func (d *ClusterRegistry) Requirements() (client bool, host bool) { + return true, false +} + func (d *ClusterRegistry) CanRun() (bool, error) { if d.ImageStreamClient == nil || d.KubeClient == nil { return false, fmt.Errorf("must have kube and os clients") diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/rolebindings.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/rolebindings.go index 80da245c59cd..f5723d497701 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/rolebindings.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/rolebindings.go @@ -34,6 +34,10 @@ func (d *ClusterRoleBindings) Description() string { return "Check that the default ClusterRoleBindings are present and contain the expected subjects" } +func (d *ClusterRoleBindings) Requirements() (client bool, host bool) { + return true, false +} + func (d *ClusterRoleBindings) CanRun() (bool, error) { if d.ClusterRoleBindingsClient == nil { return false, fmt.Errorf("must have client.ClusterRoleBindingsInterface") diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/roles.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/roles.go index 7f962ec22746..30b0880b2531 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/roles.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/roles.go @@ -62,6 +62,10 @@ func (d *ClusterRoles) Description() string { return "Check that the default ClusterRoles are present and contain the expected permissions" } +func (d *ClusterRoles) Requirements() (client bool, host bool) { + return true, false +} + func (d *ClusterRoles) CanRun() (bool, error) { if d.ClusterRolesClient == nil { return false, fmt.Errorf("must have client.ClusterRolesInterface") diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/route_validation.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/route_validation.go index 8adbb1732cab..1af00befde63 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/route_validation.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/route_validation.go @@ -44,6 +44,10 @@ func (d *RouteCertificateValidation) Description() string { return "Check all route certificates for certificates that might be rejected by extended validation." } +func (d *RouteCertificateValidation) Requirements() (client bool, host bool) { + return true, false +} + func (d *RouteCertificateValidation) CanRun() (bool, error) { if d.RESTConfig == nil || d.SARClient == nil { return false, errors.New("must have Kube client configuration") diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/router.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/router.go index b9e76b3be29e..d2f9668b41f5 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/router.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/router.go @@ -84,13 +84,17 @@ Time: %s` ) func (d *ClusterRouter) Name() string { - return "ClusterRouterName" + return ClusterRouterName } func (d *ClusterRouter) Description() string { return "Check there is a working router" } +func (d *ClusterRouter) Requirements() (client bool, host bool) { + return true, false +} + func (d *ClusterRouter) CanRun() (bool, error) { if d.KubeClient == nil || d.DCClient == nil { return false, errors.New("must have kube and os client") diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/service_externalip.go b/pkg/oc/admin/diagnostics/diagnostics/cluster/service_externalip.go index 2eb5781d91a3..3dcc23dc7e55 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/service_externalip.go +++ b/pkg/oc/admin/diagnostics/diagnostics/cluster/service_externalip.go @@ -9,7 +9,9 @@ import ( metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" kclientset "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset" + master "github.com/openshift/origin/pkg/cmd/server/api" hostdiag "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/host" + "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/log" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" "github.com/openshift/origin/pkg/service/admission" ) @@ -19,6 +21,7 @@ import ( // Background: https://github.com/openshift/origin/issues/7808 type ServiceExternalIPs struct { MasterConfigFile string + masterConfig *master.MasterConfig KclusterClient kclientset.Interface } @@ -32,8 +35,23 @@ func (d *ServiceExternalIPs) Description() string { return "Check for existing services with ExternalIPs that are disallowed by master config" } +func (d *ServiceExternalIPs) Requirements() (client bool, host bool) { + return true, true +} + +func (d *ServiceExternalIPs) Complete(logger *log.Logger) error { + if len(d.MasterConfigFile) > 0 { + masterConfig, err := hostdiag.GetMasterConfig(d.MasterConfigFile, logger) + if err != nil { + return err + } + d.masterConfig = masterConfig + } + return nil +} + func (d *ServiceExternalIPs) CanRun() (bool, error) { - if len(d.MasterConfigFile) == 0 { + if len(d.MasterConfigFile) == 0 || d.masterConfig == nil { return false, errors.New("No master config file was detected") } if d.KclusterClient == nil { @@ -45,14 +63,10 @@ func (d *ServiceExternalIPs) CanRun() (bool, error) { func (d *ServiceExternalIPs) Check() types.DiagnosticResult { r := types.NewDiagnosticResult(ServiceExternalIPsName) - masterConfig, err := hostdiag.GetMasterConfig(r, d.MasterConfigFile) - if err != nil { - r.Info("DH2004", "Unreadable master config; skipping this diagnostic.") - return r - } admit, reject := []*net.IPNet{}, []*net.IPNet{} - if cidrs := masterConfig.NetworkConfig.ExternalIPNetworkCIDRs; cidrs != nil { + var err error + if cidrs := d.masterConfig.NetworkConfig.ExternalIPNetworkCIDRs; cidrs != nil { reject, admit, err = admission.ParseRejectAdmitCIDRRules(cidrs) if err != nil { r.Error("DH2007", err, fmt.Sprintf("Could not parse master config NetworkConfig.ExternalIPNetworkCIDRs: (%[1]T) %[1]v", err)) diff --git a/pkg/oc/admin/diagnostics/diagnostics/host/check_master_config.go b/pkg/oc/admin/diagnostics/diagnostics/host/check_master_config.go index a66ce7c40e91..58a96941db2d 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/host/check_master_config.go +++ b/pkg/oc/admin/diagnostics/diagnostics/host/check_master_config.go @@ -4,37 +4,51 @@ import ( "errors" "fmt" + master "github.com/openshift/origin/pkg/cmd/server/api" configvalidation "github.com/openshift/origin/pkg/cmd/server/api/validation" + "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/log" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" ) // MasterConfigCheck is a Diagnostic to check that the master config file is valid type MasterConfigCheck struct { MasterConfigFile string + masterConfig *master.MasterConfig } const MasterConfigCheckName = "MasterConfigCheck" -func (d MasterConfigCheck) Name() string { +func (d *MasterConfigCheck) Name() string { return MasterConfigCheckName } -func (d MasterConfigCheck) Description() string { +func (d *MasterConfigCheck) Description() string { return "Check the master config file" } -func (d MasterConfigCheck) CanRun() (bool, error) { + +func (d *MasterConfigCheck) Requirements() (client bool, host bool) { + return false, true +} + +func (d *MasterConfigCheck) Complete(logger *log.Logger) error { + masterConfig, err := GetMasterConfig(d.MasterConfigFile, logger) + if err != nil { + return err + } + d.masterConfig = masterConfig + return nil +} + +func (d *MasterConfigCheck) CanRun() (bool, error) { if len(d.MasterConfigFile) == 0 { return false, errors.New("No master config file was detected") } return true, nil } -func (d MasterConfigCheck) Check() types.DiagnosticResult { + +func (d *MasterConfigCheck) Check() types.DiagnosticResult { r := types.NewDiagnosticResult(MasterConfigCheckName) - masterConfig, err := GetMasterConfig(r, d.MasterConfigFile) - if err != nil { - return r - } results := configvalidation.ValidateMasterConfig(masterConfig, nil) if len(results.Errors) > 0 { diff --git a/pkg/oc/admin/diagnostics/diagnostics/host/check_node_config.go b/pkg/oc/admin/diagnostics/diagnostics/host/check_node_config.go index 475fcf389459..7ff0ad22d226 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/host/check_node_config.go +++ b/pkg/oc/admin/diagnostics/diagnostics/host/check_node_config.go @@ -23,6 +23,11 @@ func (d NodeConfigCheck) Name() string { func (d NodeConfigCheck) Description() string { return "Check the node config file" } + +func (d NodeConfigCheck) Requirements() (client bool, host bool) { + return false, true +} + func (d NodeConfigCheck) CanRun() (bool, error) { if len(d.NodeConfigFile) == 0 { return false, errors.New("No node config file was detected") @@ -30,6 +35,7 @@ func (d NodeConfigCheck) CanRun() (bool, error) { return true, nil } + func (d NodeConfigCheck) Check() types.DiagnosticResult { r := types.NewDiagnosticResult(NodeConfigCheckName) r.Debug("DH1001", fmt.Sprintf("Looking for node config file at '%s'", d.NodeConfigFile)) diff --git a/pkg/oc/admin/diagnostics/diagnostics/cluster/etcd.go b/pkg/oc/admin/diagnostics/diagnostics/host/etcd.go similarity index 55% rename from pkg/oc/admin/diagnostics/diagnostics/cluster/etcd.go rename to pkg/oc/admin/diagnostics/diagnostics/host/etcd.go index 1c8ba8bdac6b..86febda32011 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/cluster/etcd.go +++ b/pkg/oc/admin/diagnostics/diagnostics/host/etcd.go @@ -1,4 +1,4 @@ -package cluster +package host import ( "context" @@ -15,38 +15,66 @@ import ( "bytes" + "github.com/openshift/origin/pkg/cmd/server/etcd" + "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/log" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" ) // EtcdWriteVolume is a Diagnostic to check the writes occurring against etcd // and organize them by volume. type EtcdWriteVolume struct { - V2Client etcdclient.Client - V3Client *clientv3.Client + MasterConfigLocation string + V2Client etcdclient.Client + V3Client *clientv3.Client + durationSpec string + duration time.Duration } const ( - EtcdWriteName = "EtcdWriteVolume" + EtcdWriteName = "EtcdWriteVolume" + DurationParam = "duration" + DurationDefault = "1m" ) -func (d *EtcdWriteVolume) duration() time.Duration { - s := os.Getenv("ETCD_WRITE_VOLUME_DURATION") - if len(s) == 0 { - s = "1m" - } - duration, err := time.ParseDuration(s) - if err != nil { - panic(fmt.Errorf("ETCD_WRITE_VOLUME_DURATION could not be parsed: %v", err)) - } - return duration -} - func (d *EtcdWriteVolume) Name() string { return EtcdWriteName } func (d *EtcdWriteVolume) Description() string { - return fmt.Sprintf("Check the volume of writes against etcd and classify them by operation and key for %s", d.duration()) + return fmt.Sprintf("Check the volume of writes against etcd over a time period and classify them by operation and key") +} + +func (d *EtcdWriteVolume) Requirements() (client bool, host bool) { + return false, true +} + +func (d *EtcdWriteVolume) AvailableParameters() []types.Parameter { + return []types.Parameter{ + {DurationParam, "How long to perform the write test", &d.durationSpec, DurationDefault}, + } +} + +func (d *EtcdWriteVolume) Complete(logger *log.Logger) error { + v2Client, v3Client, found, err := findEtcdClients(d.MasterConfigLocation, logger) + if err != nil || !found { + return err + } + d.V2Client, d.V3Client = v2Client, v3Client + + // determine the duration to run the check from either the deprecated env var, the flag, or the default + s := os.Getenv("ETCD_WRITE_VOLUME_DURATION") // deprecated way + if d.durationSpec != "" { + s = d.durationSpec + } + if s == "" { + s = DurationDefault + } + duration, err := time.ParseDuration(s) + if err != nil { + return fmt.Errorf("EtcdWriteVolume duration '%s' could not be parsed: %v", s, err) + } + d.duration = duration + return nil } func (d *EtcdWriteVolume) CanRun() (bool, error) { @@ -64,9 +92,8 @@ func (d *EtcdWriteVolume) Check() types.DiagnosticResult { var wg sync.WaitGroup - duration := d.duration() ctx := context.Background() - ctx, cancel := context.WithDeadline(ctx, time.Now().Add(duration)) + ctx, cancel := context.WithDeadline(ctx, time.Now().Add(d.duration)) defer cancel() keyStats := &keyCounter{} @@ -121,11 +148,46 @@ func (d *EtcdWriteVolume) Check() types.DiagnosticResult { fmt.Fprintf(tw, "%s\t%6d\t%5.1f%%\n", b.Name, b.Count, float64(b.Count)/float64(keyStats.count)*100) } tw.Flush() - r.Info("DEw2004", fmt.Sprintf("Measured %.1f writes/sec\n", float64(keyStats.count)/float64(duration/time.Second))+buf.String()) + r.Info("DEw2004", fmt.Sprintf("Measured %.1f writes/sec\n", float64(keyStats.count)/float64(d.duration/time.Second))+buf.String()) return r } +// findEtcdClients finds and loads etcd clients +func findEtcdClients(configFile string, logger *log.Logger) (etcdclient.Client, *clientv3.Client, bool, error) { + masterConfig, err := GetMasterConfig(configFile, logger) + if err != nil { + configErr := fmt.Errorf("Unreadable master config; skipping this diagnostic.") + logger.Error("DE2001", configErr.Error()) + return nil, nil, false, configErr + } + if len(masterConfig.EtcdClientInfo.URLs) == 0 { + configErr := fmt.Errorf("No etcdClientInfo.urls defined; can't contact etcd") + logger.Error("DE2002", configErr.Error()) + return nil, nil, false, configErr + } + v2Client, err := etcd.MakeEtcdClient(masterConfig.EtcdClientInfo) + if err != nil { + configErr := fmt.Errorf("Unable to create an etcd v2 client: %v", err) + logger.Error("DE2003", configErr.Error()) + return nil, nil, false, configErr + } + config, err := etcd.MakeEtcdClientV3Config(masterConfig.EtcdClientInfo) + if err != nil { + configErr := fmt.Errorf("Unable to create an etcd v3 client config: %v", err) + logger.Error("DE2004", configErr.Error()) + return nil, nil, false, configErr + } + config.DialTimeout = 5 * time.Second + v3Client, err := clientv3.New(*config) + if err != nil { + configErr := fmt.Errorf("Unable to create an etcd v3 client: %v", err) + logger.Error("DE2005", configErr.Error()) + return nil, nil, false, configErr + } + return v2Client, v3Client, true, nil +} + type KeyCounter interface { Inc(key []string) } diff --git a/pkg/oc/admin/diagnostics/diagnostics/host/util.go b/pkg/oc/admin/diagnostics/diagnostics/host/util.go index fa6d2219a607..327d5f86a42f 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/host/util.go +++ b/pkg/oc/admin/diagnostics/diagnostics/host/util.go @@ -5,7 +5,7 @@ import ( configapi "github.com/openshift/origin/pkg/cmd/server/api" configapilatest "github.com/openshift/origin/pkg/cmd/server/api/latest" - "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" + "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/log" ) // this would be bad practice if there were ever a need to load more than one master config for diagnostics. @@ -16,24 +16,24 @@ var ( masterConfigLoadError error ) -func GetMasterConfig(r types.DiagnosticResult, masterConfigFile string) (*configapi.MasterConfig, error) { +func GetMasterConfig(masterConfigFile string, logger *log.Logger) (*configapi.MasterConfig, error) { if masterConfigLoaded { // no need to do this more than once if masterConfigLoadError != nil { - printMasterConfigLoadError(r, masterConfigFile) + printMasterConfigLoadError(masterConfigFile, logger) } return masterConfig, masterConfigLoadError } - r.Debug("DH0001", fmt.Sprintf("Looking for master config file at '%s'", masterConfigFile)) + logger.Debug("DH0001", fmt.Sprintf("Looking for master config file at '%s'", masterConfigFile)) masterConfigLoaded = true masterConfig, masterConfigLoadError = configapilatest.ReadAndResolveMasterConfig(masterConfigFile) if masterConfigLoadError != nil { - printMasterConfigLoadError(r, masterConfigFile) + printMasterConfigLoadError(masterConfigFile, logger) } else { - r.Debug("DH0003", fmt.Sprintf("Found a master config file: %[1]s", masterConfigFile)) + logger.Debug("DH0003", fmt.Sprintf("Found a master config file: %[1]s", masterConfigFile)) } return masterConfig, masterConfigLoadError } -func printMasterConfigLoadError(r types.DiagnosticResult, masterConfigFile string) { - r.Error("DH0002", masterConfigLoadError, fmt.Sprintf("Could not read master config file '%s':\n(%T) %[2]v", masterConfigFile, masterConfigLoadError)) +func printMasterConfigLoadError(masterConfigFile string, logger *log.Logger) { + logger.Error("DH0002", fmt.Sprintf("Could not read master config file '%s':\n(%T) %[2]v", masterConfigFile, masterConfigLoadError)) } diff --git a/pkg/oc/admin/diagnostics/diagnostics/network/run_pod.go b/pkg/oc/admin/diagnostics/diagnostics/network/run_pod.go index c662a2aa1860..7dba73f01f1f 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/network/run_pod.go +++ b/pkg/oc/admin/diagnostics/diagnostics/network/run_pod.go @@ -5,24 +5,34 @@ import ( "fmt" "os" "os/signal" + "path/filepath" + "strings" "syscall" "time" flag "github.com/spf13/pflag" + "k8s.io/apimachinery/pkg/util/sets" + kvalidation "k8s.io/apimachinery/pkg/util/validation" "k8s.io/apimachinery/pkg/util/wait" "k8s.io/apiserver/pkg/storage/names" kapi "k8s.io/kubernetes/pkg/apis/core" kclientset "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset" networktypedclient "github.com/openshift/origin/pkg/network/generated/internalclientset/typed/network/internalversion" + "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/log" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/networkpod/util" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" osclientcmd "github.com/openshift/origin/pkg/oc/cli/util/clientcmd" ) const ( - NetworkDiagnosticName = "NetworkCheck" + NetworkDiagnosticName = "NetworkCheck" + FlagNetworkDiagLogDir = "logdir" + FlagNetworkDiagPodImage = "pod-image" + FlagNetworkDiagTestPodImage = "test-pod-image" + FlagNetworkDiagTestPodProtocol = "test-pod-protocol" + FlagNetworkDiagTestPodPort = "test-pod-port" ) // NetworkDiagnostic is a diagnostic that runs a network diagnostic pod and relays the results. @@ -59,6 +69,40 @@ func (d *NetworkDiagnostic) Description() string { return "Create a pod on all schedulable nodes and run network diagnostics from the application standpoint" } +func (d *NetworkDiagnostic) Requirements() (client bool, host bool) { + return true, false +} + +func (d *NetworkDiagnostic) AvailableParameters() []types.Parameter { + return []types.Parameter{ + {FlagNetworkDiagLogDir, "Path to store diagnostic results in case of errors", &d.LogDir, util.NetworkDiagDefaultLogDir}, + {FlagNetworkDiagPodImage, "Image to use for diagnostic pod", &d.PodImage, util.GetNetworkDiagDefaultPodImage()}, + {FlagNetworkDiagTestPodImage, "Image to use for diagnostic test pod", &d.TestPodImage, util.GetNetworkDiagDefaultTestPodImage()}, + {FlagNetworkDiagTestPodProtocol, "Protocol used to connect to diagnostic test pod", &d.TestPodProtocol, util.NetworkDiagDefaultTestPodProtocol}, + {FlagNetworkDiagTestPodPort, "Serving port on the diagnostic test pod", &d.TestPodPort, util.NetworkDiagDefaultTestPodPort}, + } +} + +func (d *NetworkDiagnostic) Complete(logger *log.Logger) error { + logdir, err := filepath.Abs(d.LogDir) + if err != nil { + return err + } + if path, err := os.Stat(d.LogDir); err == nil && !path.Mode().IsDir() { + return fmt.Errorf("Network log path %q exists but is not a directory", d.LogDir) + } + d.LogDir = logdir + + supportedProtocols := sets.NewString(string(kapi.ProtocolTCP), string(kapi.ProtocolUDP)) + if !supportedProtocols.Has(d.TestPodProtocol) { + return fmt.Errorf("invalid protocol for network diagnostic test pod. Supported protocols: %s", strings.Join(supportedProtocols.List(), ",")) + } + if kvalidation.IsValidPortNum(d.TestPodPort) != nil { + return fmt.Errorf("invalid port for network diagnostic test pod. Must be in the range 1 to 65535.") + } + return nil +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d *NetworkDiagnostic) CanRun() (bool, error) { if d.PreventModification { diff --git a/pkg/oc/admin/diagnostics/diagnostics/networkpod/collect.go b/pkg/oc/admin/diagnostics/diagnostics/networkpod/collect.go index a2dabe946fbf..521e52c8f07c 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/networkpod/collect.go +++ b/pkg/oc/admin/diagnostics/diagnostics/networkpod/collect.go @@ -30,6 +30,10 @@ func (d CollectNetworkInfo) Description() string { return "Collect network information in the cluster." } +func (d CollectNetworkInfo) Requirements() (client bool, host bool) { + return true, false +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d CollectNetworkInfo) CanRun() (bool, error) { if d.KubeClient == nil { diff --git a/pkg/oc/admin/diagnostics/diagnostics/networkpod/external.go b/pkg/oc/admin/diagnostics/diagnostics/networkpod/external.go index 816927a6c661..d7ea0db41602 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/networkpod/external.go +++ b/pkg/oc/admin/diagnostics/diagnostics/networkpod/external.go @@ -26,6 +26,10 @@ func (d CheckExternalNetwork) Description() string { return "Check that external network is accessible within a pod" } +func (d CheckExternalNetwork) Requirements() (client bool, host bool) { + return true, false +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d CheckExternalNetwork) CanRun() (bool, error) { return true, nil diff --git a/pkg/oc/admin/diagnostics/diagnostics/networkpod/node.go b/pkg/oc/admin/diagnostics/diagnostics/networkpod/node.go index f44e4c8717b9..560d679f233c 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/networkpod/node.go +++ b/pkg/oc/admin/diagnostics/diagnostics/networkpod/node.go @@ -33,6 +33,10 @@ func (d CheckNodeNetwork) Description() string { return "Check that pods in the cluster can access its own node." } +func (d CheckNodeNetwork) Requirements() (client bool, host bool) { + return true, false +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d CheckNodeNetwork) CanRun() (bool, error) { if d.KubeClient == nil { diff --git a/pkg/oc/admin/diagnostics/diagnostics/networkpod/pod.go b/pkg/oc/admin/diagnostics/diagnostics/networkpod/pod.go index 73abdccb4258..f4e88969d065 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/networkpod/pod.go +++ b/pkg/oc/admin/diagnostics/diagnostics/networkpod/pod.go @@ -41,6 +41,10 @@ func (d CheckPodNetwork) Description() string { return "Check pod to pod communication in the cluster. In case of ovs-subnet network plugin, all pods should be able to communicate with each other and in case of multitenant network plugin, pods in non-global projects should be isolated and pods in global projects should be able to access any pod in the cluster and vice versa." } +func (d CheckPodNetwork) Requirements() (client bool, host bool) { + return true, false +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d CheckPodNetwork) CanRun() (bool, error) { if d.KubeClient == nil { diff --git a/pkg/oc/admin/diagnostics/diagnostics/networkpod/service.go b/pkg/oc/admin/diagnostics/diagnostics/networkpod/service.go index 40f59f59c107..33e37ad768c9 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/networkpod/service.go +++ b/pkg/oc/admin/diagnostics/diagnostics/networkpod/service.go @@ -41,6 +41,10 @@ func (d CheckServiceNetwork) Description() string { return "Check pod to service communication in the cluster. In case of ovs-subnet network plugin, all pods should be able to communicate with all services and in case of multitenant network plugin, services in non-global projects should be isolated and pods in global projects should be able to access any service in the cluster." } +func (d CheckServiceNetwork) Requirements() (client bool, host bool) { + return true, false +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d CheckServiceNetwork) CanRun() (bool, error) { if d.KubeClient == nil { diff --git a/pkg/oc/admin/diagnostics/diagnostics/pod/auth.go b/pkg/oc/admin/diagnostics/diagnostics/pod/auth.go index a5056281b054..17cd353a2931 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/pod/auth.go +++ b/pkg/oc/admin/diagnostics/diagnostics/pod/auth.go @@ -42,6 +42,10 @@ func (d PodCheckAuth) Description() string { return "Check that service account credentials authenticate as expected" } +func (d PodCheckAuth) Requirements() (client bool, host bool) { + return true, false +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d PodCheckAuth) CanRun() (bool, error) { return true, nil diff --git a/pkg/oc/admin/diagnostics/diagnostics/pod/dns.go b/pkg/oc/admin/diagnostics/diagnostics/pod/dns.go index 0d701c6df29b..0f1adb28b3d1 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/pod/dns.go +++ b/pkg/oc/admin/diagnostics/diagnostics/pod/dns.go @@ -38,6 +38,10 @@ func (d PodCheckDns) Description() string { return "Check that DNS within a pod works as expected" } +func (d PodCheckDns) Requirements() (client bool, host bool) { + return true, false +} + // CanRun is part of the Diagnostic interface; it determines if the conditions are right to run this diagnostic. func (d PodCheckDns) CanRun() (bool, error) { return true, nil diff --git a/pkg/oc/admin/diagnostics/diagnostics/systemd/analyze_logs.go b/pkg/oc/admin/diagnostics/diagnostics/systemd/analyze_logs.go index 2b38287e963b..8bfe88994961 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/systemd/analyze_logs.go +++ b/pkg/oc/admin/diagnostics/diagnostics/systemd/analyze_logs.go @@ -47,6 +47,10 @@ func (d AnalyzeLogs) Description() string { return "Check for recent problems in systemd service logs" } +func (d AnalyzeLogs) Requirements() (client bool, host bool) { + return false, true +} + func (d AnalyzeLogs) CanRun() (bool, error) { if HasJournalctl() { return true, nil diff --git a/pkg/oc/admin/diagnostics/diagnostics/systemd/unit_status.go b/pkg/oc/admin/diagnostics/diagnostics/systemd/unit_status.go index 68dbea24be07..e030b8cb9943 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/systemd/unit_status.go +++ b/pkg/oc/admin/diagnostics/diagnostics/systemd/unit_status.go @@ -21,12 +21,18 @@ func (d UnitStatus) Name() string { func (d UnitStatus) Description() string { return "Check status for related systemd units" } + +func (d UnitStatus) Requirements() (client bool, host bool) { + return false, true +} + func (d UnitStatus) CanRun() (bool, error) { if HasSystemctl() { return true, nil } return false, errors.New("systemd is not present/functional on this host") } + func (d UnitStatus) Check() types.DiagnosticResult { r := types.NewDiagnosticResult(UnitStatusName) diff --git a/pkg/oc/admin/diagnostics/diagnostics/types/diagnostic.go b/pkg/oc/admin/diagnostics/diagnostics/types/diagnostic.go index 7c3517426e42..1489c5ac8325 100644 --- a/pkg/oc/admin/diagnostics/diagnostics/types/diagnostic.go +++ b/pkg/oc/admin/diagnostics/diagnostics/types/diagnostic.go @@ -7,12 +7,14 @@ import ( "sync" "github.com/golang/glog" + "k8s.io/apimachinery/pkg/util/sets" "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/log" ) // Diagnostic provides the interface for building diagnostics that can execute as part of the diagnostic framework. // The Name and Description methods are used to identify which diagnostic is running in the output. +// Requirements() identifies the common parameters this diagnostic may require. // The CanRun() method provides a pre-execution check for whether the diagnostic is relevant and runnable as constructed. // If not, a user-facing reason for skipping the diagnostic can be given. // Finally, the Check() method runs the diagnostic with the resulting messages and errors returned in a result object. @@ -20,10 +22,62 @@ import ( type Diagnostic interface { Name() string Description() string + Requirements() (client bool, host bool) CanRun() (canRun bool, reason error) Check() DiagnosticResult } +// DiagnosticsList is a simple list type for providing the Names() method +type DiagnosticList []Diagnostic + +// Names returns a set of the names of the diagnostics in the list +func (d DiagnosticList) Names() sets.String { + names := sets.NewString() + for _, diag := range d { + names.Insert(diag.Name()) + } + return names +} + +// Diagnostic provides an interface for finishing initialization of a diagnostic. +type IncompleteDiagnostic interface { + // Complete runs just before CanRun; it can log issues to the logger. Returns error on misconfiguration. + Complete(*log.Logger) error +} + +// Parameter is used by an individual diagnostic to specify non-shared parameters for itself +// Name is a lowercase string that will be used to generate a CLI flag +// Description is used to describe the same flag +// Target is a pointer to what the flag should fill in +// Default is the default value for the flag description +type Parameter struct { + Name string + Description string + Target interface{} + Default interface{} +} + +// ParameterizedDiagnostic is a Diagnostic that can accept arbitrary parameters specifically for it. +// AvailableParameters is used to describe or validate the parameters given on the command line. +type ParameterizedDiagnostic interface { + Diagnostic + AvailableParameters() []Parameter +} + +// ParameterizedDiagnosticMap holds PDs by name for later lookup +type ParameterizedDiagnosticMap map[string]ParameterizedDiagnostic + +// NewParameterizedDiagnosticMap filters PDs from a list of diagnostics into a PDMap. +func NewParameterizedDiagnosticMap(diags ...Diagnostic) ParameterizedDiagnosticMap { + m := ParameterizedDiagnosticMap{} + for _, diag := range diags { + if pd, ok := diag.(ParameterizedDiagnostic); ok { + m[diag.Name()] = pd + } + } + return m +} + // DiagnosticResult provides a result object for diagnostics, accumulating the messages and errors // that the diagnostic generates as it runs. type DiagnosticResult interface { diff --git a/pkg/oc/admin/diagnostics/etcd.go b/pkg/oc/admin/diagnostics/etcd.go deleted file mode 100644 index 0e5432e31757..000000000000 --- a/pkg/oc/admin/diagnostics/etcd.go +++ /dev/null @@ -1,91 +0,0 @@ -package diagnostics - -import ( - "fmt" - "time" - - "k8s.io/apimachinery/pkg/util/sets" - - etcdclient "github.com/coreos/etcd/client" - "github.com/coreos/etcd/clientv3" - - "github.com/openshift/origin/pkg/cmd/server/etcd" - clustdiags "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/cluster" - "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/host" - "github.com/openshift/origin/pkg/oc/admin/diagnostics/diagnostics/types" -) - -var ( - // availableEtcdDiagnostics contains the names of etcd diagnostics that can be executed - // during a single run of diagnostics. Add more diagnostics to the list as they are defined. - availableEtcdDiagnostics = sets.NewString( - clustdiags.EtcdWriteName, - ) - // defaultSkipEtcdDiagnostics is a list of diagnostics to skip by default - defaultSkipEtcdDiagnostics = sets.NewString( - clustdiags.EtcdWriteName, - ) -) - -// buildEtcdDiagnostics builds cluster Diagnostic objects if etcd is configured -func (o DiagnosticsOptions) buildEtcdDiagnostics() ([]types.Diagnostic, bool, error) { - requestedDiagnostics := availableEtcdDiagnostics.Intersection(sets.NewString(o.RequestedDiagnostics...)).List() - if len(requestedDiagnostics) == 0 { // no diagnostics to run here - return nil, true, nil // don't waste time on discovery - } - - v2Client, v3Client, found, err := o.findEtcdClients(o.MasterConfigLocation) - if !found { - o.Logger.Notice("DE2000", "Could not configure etcd clients against the current config, so etcd diagnostics will be skipped") - return nil, true, err - } - - diagnostics := []types.Diagnostic{} - for _, diagnosticName := range requestedDiagnostics { - var d types.Diagnostic - switch diagnosticName { - case clustdiags.EtcdWriteName: - d = &clustdiags.EtcdWriteVolume{V2Client: v2Client, V3Client: v3Client} - default: - return nil, false, fmt.Errorf("unknown diagnostic: %v", diagnosticName) - } - diagnostics = append(diagnostics, d) - } - return diagnostics, true, nil -} - -// findEtcdClients finds and loads etcd clients -func (o DiagnosticsOptions) findEtcdClients(configFile string) (etcdclient.Client, *clientv3.Client, bool, error) { - r := types.NewDiagnosticResult("") - masterConfig, err := host.GetMasterConfig(r, configFile) - if err != nil { - configErr := fmt.Errorf("Unreadable master config; skipping this diagnostic.") - o.Logger.Error("DE2001", configErr.Error()) - return nil, nil, false, configErr - } - if len(masterConfig.EtcdClientInfo.URLs) == 0 { - configErr := fmt.Errorf("No etcdClientInfo.urls defined; can't contact etcd") - o.Logger.Error("DE2002", configErr.Error()) - return nil, nil, false, configErr - } - v2Client, err := etcd.MakeEtcdClient(masterConfig.EtcdClientInfo) - if err != nil { - configErr := fmt.Errorf("Unable to create an etcd v2 client: %v", err) - o.Logger.Error("DE2003", configErr.Error()) - return nil, nil, false, configErr - } - config, err := etcd.MakeEtcdClientV3Config(masterConfig.EtcdClientInfo) - if err != nil { - configErr := fmt.Errorf("Unable to create an etcd v3 client config: %v", err) - o.Logger.Error("DE2004", configErr.Error()) - return nil, nil, false, configErr - } - config.DialTimeout = 5 * time.Second - v3Client, err := clientv3.New(*config) - if err != nil { - configErr := fmt.Errorf("Unable to create an etcd v3 client: %v", err) - o.Logger.Error("DE2005", configErr.Error()) - return nil, nil, false, configErr - } - return v2Client, v3Client, true, nil -} diff --git a/pkg/oc/admin/diagnostics/host.go b/pkg/oc/admin/diagnostics/host.go index e8f27b8abca4..d99427309e22 100644 --- a/pkg/oc/admin/diagnostics/host.go +++ b/pkg/oc/admin/diagnostics/host.go @@ -11,15 +11,28 @@ import ( ) var ( - // availableHostDiagnostics contains the names of host diagnostics that can be executed - // during a single run of diagnostics. Add more diagnostics to the list as they are defined. - availableHostDiagnostics = sets.NewString(systemddiags.AnalyzeLogsName, systemddiags.UnitStatusName, hostdiags.MasterConfigCheckName, hostdiags.NodeConfigCheckName) + // defaultSkipHostDiagnostics is a list of diagnostics to skip by default + defaultSkipHostDiagnostics = sets.NewString( + hostdiags.EtcdWriteName, + ) ) +// availableHostDiagnostics contains the names of host diagnostics that can be executed +// during a single run of diagnostics. Add more diagnostics to the list as they are defined. +func availableHostDiagnostics() types.DiagnosticList { + return types.DiagnosticList{ + &systemddiags.AnalyzeLogs{}, + &systemddiags.UnitStatus{}, + &hostdiags.MasterConfigCheck{}, + &hostdiags.NodeConfigCheck{}, + &hostdiags.EtcdWriteVolume{}, + } +} + // buildHostDiagnostics builds host Diagnostic objects based on the host environment. // Returns the Diagnostics built, "ok" bool for whether to proceed or abort, and an error if any was encountered during the building of diagnostics.) { -func (o DiagnosticsOptions) buildHostDiagnostics() ([]types.Diagnostic, bool, error) { - requestedDiagnostics := availableHostDiagnostics.Intersection(sets.NewString(o.RequestedDiagnostics...)).List() +func (o DiagnosticsConfig) buildHostDiagnostics() ([]types.Diagnostic, bool, error) { + requestedDiagnostics := availableHostDiagnostics().Names().Intersection(sets.NewString(o.RequestedDiagnostics.List()...)).List() if len(requestedDiagnostics) == 0 { // no diagnostics to run here return nil, true, nil // don't waste time on discovery } @@ -39,13 +52,17 @@ func (o DiagnosticsOptions) buildHostDiagnostics() ([]types.Diagnostic, bool, er var d types.Diagnostic switch diagnosticName { case systemddiags.AnalyzeLogsName: - d = systemddiags.AnalyzeLogs{SystemdUnits: systemdUnits} + d = &systemddiags.AnalyzeLogs{SystemdUnits: systemdUnits} case systemddiags.UnitStatusName: - d = systemddiags.UnitStatus{SystemdUnits: systemdUnits} + d = &systemddiags.UnitStatus{SystemdUnits: systemdUnits} case hostdiags.MasterConfigCheckName: - d = hostdiags.MasterConfigCheck{MasterConfigFile: o.MasterConfigLocation} + d = &hostdiags.MasterConfigCheck{MasterConfigFile: o.MasterConfigLocation} case hostdiags.NodeConfigCheckName: - d = hostdiags.NodeConfigCheck{NodeConfigFile: o.NodeConfigLocation} + d = &hostdiags.NodeConfigCheck{NodeConfigFile: o.NodeConfigLocation} + case hostdiags.EtcdWriteName: + etcd := o.ParameterizedDiagnostics[hostdiags.EtcdWriteName].(*hostdiags.EtcdWriteVolume) + etcd.MasterConfigLocation = o.MasterConfigLocation + d = etcd default: return diagnostics, false, fmt.Errorf("unknown diagnostic: %v", diagnosticName) } diff --git a/pkg/oc/admin/diagnostics/options/flaginfo.go b/pkg/oc/admin/diagnostics/options/flaginfo.go index 0470b941ef97..4ea4662a9634 100644 --- a/pkg/oc/admin/diagnostics/options/flaginfo.go +++ b/pkg/oc/admin/diagnostics/options/flaginfo.go @@ -50,13 +50,5 @@ const ( FlagClusterContextName = "cluster-context" FlagLevelName = "diaglevel" FlagIsHostName = "host" - FlagImageTemplateName = "images" - FlagLatestImageName = "latest-images" FlagPreventModificationName = "prevent-modification" - - FlagNetworkDiagLogDir = "network-logdir" - FlagNetworkDiagPodImage = "network-pod-image" - FlagNetworkDiagTestPodImage = "network-test-pod-image" - FlagNetworkDiagTestPodProtocol = "network-test-pod-protocol" - FlagNetworkDiagTestPodPort = "network-test-pod-port" ) diff --git a/test/cmd/diagnostics.sh b/test/cmd/diagnostics.sh index ddb8f487552e..c95606fdf782 100755 --- a/test/cmd/diagnostics.sh +++ b/test/cmd/diagnostics.sh @@ -5,7 +5,7 @@ trap os::test::junit::reconcile_output EXIT # This test validates the diagnostics command # available diagnostics (2016-09-01): -# AnalyzeLogs ClusterRegistry ClusterRoleBindings ClusterRoles ClusterRouter ConfigContexts DiagnosticPod MasterConfigCheck MasterNode NetworkCheck NodeConfigCheck NodeDefinitions UnitStatus MetricsApiProxy ServiceExternalIPs +# AnalyzeLogs ClusterRegistry ClusterRoleBindings ClusterRoles ClusterRouter ConfigContexts DiagnosticPod EtcdWriteVolume MasterConfigCheck MasterNode NetworkCheck NodeConfigCheck NodeDefinitions UnitStatus MetricsApiProxy ServiceExternalIPs # Without things feeding into systemd, AnalyzeLogs and UnitStatus are irrelevant. # The rest should be included in some fashion. @@ -25,10 +25,16 @@ os::cmd::expect_failure_and_text "oc adm diagnostics NodeConfigCheck --node-conf os::cmd::expect_success 'oc adm policy reconcile-cluster-roles --additive-only=false --confirm' -os::cmd::expect_success 'oc adm diagnostics ClusterRoleBindings ClusterRoles ConfigContexts ' +os::cmd::expect_success 'oc adm diagnostics ClusterRoleBindings ' +os::cmd::expect_success 'oc adm diagnostics ClusterRoles ' +os::cmd::expect_success 'oc adm diagnostics ConfigContexts ' # DiagnosticPod can't run without Docker, would just time out. Exercise flags instead. os::cmd::expect_success "oc adm diagnostics DiagnosticPod --prevent-modification --images=foo" -os::cmd::expect_success "oc adm diagnostics MasterConfigCheck NodeConfigCheck ServiceExternalIPs --master-config=${MASTER_CONFIG_DIR}/master-config.yaml --node-config=${NODE_CONFIG_DIR}/node-config.yaml" +# EtcdWriteVolume can't run without etcd. Just exercise flags. +os::cmd::expect_success "oc adm diagnostics EtcdWriteVolume --duration=10s --help" +os::cmd::expect_success "oc adm diagnostics MasterConfigCheck --master-config=${MASTER_CONFIG_DIR}/master-config.yaml" +os::cmd::expect_success "oc adm diagnostics NodeConfigCheck --node-config=${NODE_CONFIG_DIR}/node-config.yaml" +os::cmd::expect_success "oc adm diagnostics ServiceExternalIPs --master-config=${MASTER_CONFIG_DIR}/master-config.yaml" os::cmd::expect_failure_and_text 'oc adm diagnostics ClusterRegistry' "DClu1006 from diagnostic ClusterRegistry" # MasterNode fails in test, possibly because the hostname doesn't resolve? Disabled #os::cmd::expect_success_and_text 'oc adm diagnostics MasterNode' 'Network plugin does not require master to also run node' @@ -36,12 +42,13 @@ os::cmd::expect_failure_and_text 'oc adm diagnostics ClusterRegistry' "DClu1006 # no ordering allowed #os::cmd::expect_failure 'oc adm diagnostics ClusterRouter' # "DClu2001 from diagnostic ClusterRouter" os::cmd::expect_failure 'oc adm diagnostics NodeDefinitions' -os::cmd::expect_failure_and_text 'oc adm diagnostics FakeDiagnostic AlsoMissing' 'No requested diagnostics are available: requested=FakeDiagnostic AlsoMissing' -os::cmd::expect_failure_and_text 'oc adm diagnostics AnalyzeLogs AlsoMissing' 'Not all requested diagnostics are available: missing=AlsoMissing requested=AnalyzeLogs AlsoMissing available=' +os::cmd::expect_failure_and_text 'oc adm diagnostics FakeDiagnostic' 'Unexpected command line argument.*FakeDiagnostic' +os::cmd::expect_failure_and_text 'oc adm diagnostics AnalyzeLogs FakeDiagnostic' 'Unexpected command line argument.*FakeDiagnostic' +os::cmd::expect_failure_and_text 'oc adm diagnostics all FakeDiagnostic' 'Unexpected command line argument.*FakeDiagnostic' os::cmd::expect_success_and_text 'oc adm diagnostics MetricsApiProxy' 'Skipping diagnostic: MetricsApiProxy' os::cmd::expect_success_and_text 'oc adm diagnostics NetworkCheck --prevent-modification' 'Skipping diagnostic: NetworkCheck' # oc ex diagnostics is deprecated but not removed. Make sure it works until we consciously remove it. -os::cmd::expect_success 'oc ex diagnostics ClusterRoleBindings ClusterRoles ConfigContexts ' +os::cmd::expect_success 'oc ex diagnostics ConfigContexts' echo "diagnostics: ok" os::test::junit::declare_suite_end