Merge pull request #107044 from pohly/cli-invalid-command

cli: avoid logging command line errors in more cases
This commit is contained in:
Kubernetes Prow Robot
2022-01-11 09:46:37 -08:00
committed by GitHub
6 changed files with 183 additions and 44 deletions

View File

@@ -421,7 +421,7 @@ run_deprecated_api_tests() {
kube::test::if_has_string "${output_message}" 'PodSecurityPolicy is deprecated'
output_message=$(! kubectl get podsecuritypolicies.v1beta1.policy --warnings-as-errors 2>&1 "${kube_flags[@]}")
kube::test::if_has_string "${output_message}" 'PodSecurityPolicy is deprecated'
kube::test::if_has_string "${output_message}" 'err="1 warning received"'
kube::test::if_has_string "${output_message}" 'error: 1 warning received'
set +o nounset
set +o errexit

View File

@@ -50,6 +50,7 @@ source "${KUBE_ROOT}/test/cmd/plugins.sh"
source "${KUBE_ROOT}/test/cmd/proxy.sh"
source "${KUBE_ROOT}/test/cmd/rbac.sh"
source "${KUBE_ROOT}/test/cmd/request-timeout.sh"
source "${KUBE_ROOT}/test/cmd/results.sh"
source "${KUBE_ROOT}/test/cmd/run.sh"
source "${KUBE_ROOT}/test/cmd/save-config.sh"
source "${KUBE_ROOT}/test/cmd/storage.sh"
@@ -436,6 +437,12 @@ runTests() {
record_command run_kubectl_version_tests
############################
# Kubectl result reporting #
############################
record_command run_kubectl_results_tests
#######################
# kubectl config set #
#######################

58
test/cmd/results.sh Normal file
View File

@@ -0,0 +1,58 @@
#!/usr/bin/env bash
# Copyright 2022 The Kubernetes Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
set -o errexit
set -o nounset
set -o pipefail
############################################################
# Kubectl result reporting for different failure scenarios #
############################################################
run_kubectl_results_tests() {
set -o nounset
set -o errexit
kube::log::status "Testing kubectl result output"
TEMP="${KUBE_TEMP}"
rm -f "${TEMP}/empty"
touch "${TEMP}/empty"
set +o errexit
kubectl list >"${TEMP}/actual_stdout" 2>"${TEMP}/actual_stderr"
res=$?
set -o errexit
cat >"${TEMP}/expected_stderr" <<EOF
error: unknown command "list" for "kubectl"
Did you mean this?
get
wait
EOF
kube::test::results::diff "${TEMP}/actual_stdout" "${TEMP}/actual_stderr" "$res" "${TEMP}/empty" "${TEMP}/expected_stderr" 1 "kubectl list"
set +o errexit
kubectl get pod/no-such-pod >"${TEMP}/actual_stdout" 2>"${TEMP}/actual_stderr"
res=$?
set -o errexit
cat >"${TEMP}/expected_stderr" <<EOF
Error from server (NotFound): pods "no-such-pod" not found
EOF
kube::test::results::diff "${TEMP}/actual_stdout" "${TEMP}/actual_stderr" "$res" "${TEMP}/empty" "${TEMP}/expected_stderr" 1 "kubectl get pod/no-such-pod"
set +o nounset
set +o errexit
}