#!/usr/bin/env bash # Copyright 2023 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 KUBE_ROOT=$(dirname "${BASH_SOURCE[0]}")/.. source "${KUBE_ROOT}/hack/lib/init.sh" source "${KUBE_ROOT}/hack/lib/util.sh" # make sure everything is committed kube::util::ensure_clean_working_dir # This sets up the environment, like GOCACHE, which keeps the worktree cleaner. kube::golang::setup_env go install golang.org/x/vuln/cmd/govulncheck@v1.0.1 # KUBE_VERIFY_GIT_BRANCH is populated in verify CI jobs BRANCH="${KUBE_VERIFY_GIT_BRANCH:-master}" kube::util::ensure-temp-dir WORKTREE="${KUBE_TEMP}/worktree" # Create a copy of the repo with $BRANCH checked out git worktree add -f "${WORKTREE}" "${BRANCH}" # Clean up the copy on exit kube::util::trap_add "git worktree remove -f ${WORKTREE}" EXIT govulncheck -scan module ./... > "${KUBE_TEMP}/head.txt" pushd "${WORKTREE}" >/dev/null govulncheck -scan module ./... > "${KUBE_TEMP}/pr-base.txt" popd >/dev/null echo -e "\n HEAD: $(cat "${KUBE_TEMP}"/head.txt)" echo -e "\n PR_BASE: $(cat "${KUBE_TEMP}/pr-base.txt")" diff -s -u --ignore-all-space "${KUBE_TEMP}"/pr-base.txt "${KUBE_TEMP}"/head.txt || true