
This sets `$what_VERSION` and `$what_REPO` for runc, cni, containerd and kubernetes based on vendor.conf, removing the need to duplicate things in hack/versions. With this `update_hack_versions` becomes redundant so remove it and both calls. Since CONTAINERD_REPO is now unconditionally set we can also simplify the fetching of vendor.conf in update-vendor.sh a bit, so do so. Further since `*_REPO` are now unconditionally set we can support alternative clone paths for all of these repos by adjusting checkout_repo to make the 3rd argument non-optional and always passing it. Since `CRITOOL_VERSION` is not coming from `vendor.conf` (since it is not used from Go code) we manually set `CRITOOL_REPO` for consistency. The final wrinkle is that `k8s.io/kubernetes` is has a Go specific redirect in the form of HTML meta headers returned from https://k8s.io/kubernetes/?go-get=1 which point to the real repo to clone. Parsing that in shell is tricky so just hardcode that. Fixes #540. Signed-off-by: Ian Campbell <ijc@docker.com>
66 lines
2.2 KiB
Bash
Executable File
66 lines
2.2 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# Copyright 2017 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
|
|
|
|
source $(dirname "${BASH_SOURCE[0]}")/utils.sh
|
|
cd ${ROOT}
|
|
|
|
# hack/versions should be correct now.
|
|
echo "Compare vendor with containerd vendors..."
|
|
source hack/versions
|
|
containerd_vendor=$(mktemp /tmp/containerd-vendor.conf.XXXX)
|
|
curl -s https://raw.githubusercontent.com/${CONTAINERD_REPO#*/}/${CONTAINERD_VERSION}/vendor.conf > ${containerd_vendor}
|
|
# Create a temporary vendor file to update.
|
|
tmp_vendor=$(mktemp /tmp/vendor.conf.XXXX)
|
|
while read vendor; do
|
|
repo=$(echo ${vendor} | awk '{print $1}')
|
|
commit=$(echo ${vendor} | awk '{print $2}')
|
|
alias=$(echo ${vendor} | awk '{print $3}')
|
|
vendor_in_containerd=$(grep ${repo} ${containerd_vendor} || true)
|
|
if [ -z "${vendor_in_containerd}" ]; then
|
|
echo ${vendor} >> ${tmp_vendor}
|
|
continue
|
|
fi
|
|
commit_in_containerd=$(echo ${vendor_in_containerd} | awk '{print $2}')
|
|
alias_in_containerd=$(echo ${vendor_in_containerd} | awk '{print $3}')
|
|
if [[ "${commit}" != "${commit_in_containerd}" || "${alias}" != "${alias_in_containerd}" ]]; then
|
|
echo ${vendor_in_containerd} >> ${tmp_vendor}
|
|
else
|
|
echo ${vendor} >> ${tmp_vendor}
|
|
fi
|
|
done < vendor.conf
|
|
# Update vendors if temporary vendor.conf is different from the original one.
|
|
if ! diff vendor.conf ${tmp_vendor} > /dev/null; then
|
|
if [ $# -gt 0 ] && [ ${1} = "-only-verify" ]; then
|
|
echo "Need to update vendor.conf."
|
|
diff vendor.conf ${tmp_vendor}
|
|
rm ${tmp_vendor}
|
|
exit 1
|
|
else
|
|
echo "Updating vendor.conf."
|
|
mv ${tmp_vendor} vendor.conf
|
|
fi
|
|
fi
|
|
rm ${containerd_vendor}
|
|
|
|
echo "Sort vendor.conf..."
|
|
sort vendor.conf -o vendor.conf
|
|
|
|
echo "Please commit the change made by this file..."
|