mirror of
https://github.com/NVIDIA/nvidia-container-toolkit
synced 2024-11-22 00:08:11 +00:00
Publish generic deb and rpm repos.
This change ensures that the centos7 and ubuntu18.04 packages are published to the generic rpm and deb repos, respectively. All other packages except the centos8-ppc64le packages are skipped as these use cases are covered by the generic packages. Signed-off-by: Evan Lezar <elezar@nvidia.com>
This commit is contained in:
parent
22d7b52a58
commit
0d862efa9c
@ -49,15 +49,19 @@ function rpm-sign {
|
|||||||
function sign() {
|
function sign() {
|
||||||
local target=$1
|
local target=$1
|
||||||
local dst_root=$2
|
local dst_root=$2
|
||||||
|
local by_package_type=$3
|
||||||
|
|
||||||
local src_dist=${target%-*}
|
local src_dist=${target%-*}
|
||||||
local dist=${src_dist/amazonlinux/amzn}
|
local dst_dist=${src_dist/amazonlinux/amzn}
|
||||||
|
|
||||||
|
local pkg_type=unknown
|
||||||
|
local arch=${target##*-}
|
||||||
|
local dst_arch=${arch}
|
||||||
|
|
||||||
local pkg_type
|
|
||||||
case ${src_dist} in
|
case ${src_dist} in
|
||||||
amazonlinux*) pkg_type=rpm
|
amazonlinux*) pkg_type=rpm
|
||||||
;;
|
;;
|
||||||
centos*) pkg_type=rpm
|
centos* | rpm) pkg_type=rpm
|
||||||
;;
|
;;
|
||||||
debian*) pkg_type=deb
|
debian*) pkg_type=deb
|
||||||
;;
|
;;
|
||||||
@ -65,18 +69,18 @@ function sign() {
|
|||||||
;;
|
;;
|
||||||
opensuse-leap*) pkg_type=rpm
|
opensuse-leap*) pkg_type=rpm
|
||||||
;;
|
;;
|
||||||
ubuntu*) pkg_type=deb
|
ubuntu* | deb) pkg_type=deb
|
||||||
|
arch=${arch//ppc64le/ppc64el}
|
||||||
;;
|
;;
|
||||||
*) echo "ERROR: unexpected distribution ${src_dist}"
|
*) echo "ERROR: unexpected distribution ${src_dist}"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
local arch=${target##*-}
|
if [[ x"${by_package_type}" == x"true" ]]; then
|
||||||
case ${src_dist} in
|
dst_dist=${pkg_type}
|
||||||
ubuntu*) arch=${arch//ppc64le/ppc64el}
|
fi
|
||||||
esac
|
|
||||||
|
|
||||||
local dst=${dst_root}/${dist}/${arch}
|
local dst=${dst_root}/${dst_dist}/${arch}
|
||||||
|
|
||||||
if [[ ! -d ${dst} ]]; then
|
if [[ ! -d ${dst} ]]; then
|
||||||
echo "Directory ${dst} not found. Skipping"
|
echo "Directory ${dst} not found. Skipping"
|
||||||
@ -93,5 +97,19 @@ function sign() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for target in ${TARGETS[@]}; do
|
for target in ${TARGETS[@]}; do
|
||||||
sign "${target}" "$(pwd)"
|
echo "checking target=${target}"
|
||||||
|
by_package_type=
|
||||||
|
case ${target} in
|
||||||
|
ubuntu18.04-* | centos7-*)
|
||||||
|
by_package_type="true"
|
||||||
|
;;
|
||||||
|
centos8-ppc64le)
|
||||||
|
by_package_type="false"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Skipping target ${target}"
|
||||||
|
continue
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
sign "${target}" "$(pwd)" ${by_package_type}
|
||||||
done
|
done
|
||||||
|
@ -48,7 +48,7 @@ SHA=$(git rev-parse --short=8 ${REFERENCE})
|
|||||||
IMAGE_NAME="registry.gitlab.com/nvidia/container-toolkit/container-toolkit/staging/container-toolkit"
|
IMAGE_NAME="registry.gitlab.com/nvidia/container-toolkit/container-toolkit/staging/container-toolkit"
|
||||||
IMAGE_TAG=${SHA}-packaging
|
IMAGE_TAG=${SHA}-packaging
|
||||||
|
|
||||||
VERSION="$(get_version_from_image ${IMAGE_NAME}:${IMAGE_TAG} ${SHA})"
|
: ${VERSION:="$(get_version_from_image ${IMAGE_NAME}:${IMAGE_TAG} ${SHA})"}
|
||||||
|
|
||||||
REPO="experimental"
|
REPO="experimental"
|
||||||
if [[ ${VERSION/rc./} == ${VERSION} ]]; then
|
if [[ ${VERSION/rc./} == ${VERSION} ]]; then
|
||||||
@ -83,11 +83,15 @@ function sync() {
|
|||||||
local target=$1
|
local target=$1
|
||||||
local src_root=$2
|
local src_root=$2
|
||||||
local dst_root=$3
|
local dst_root=$3
|
||||||
|
local by_package_type=$4
|
||||||
|
|
||||||
local src_dist=${target%-*}
|
local src_dist=${target%-*}
|
||||||
local dst_dist=${src_dist/amazonlinux/amzn}
|
local dst_dist=${src_dist/amazonlinux/amzn}
|
||||||
|
|
||||||
local pkg_type
|
local pkg_type=unknown
|
||||||
|
local arch=${target##*-}
|
||||||
|
local dst_arch=${arch}
|
||||||
|
|
||||||
case ${src_dist} in
|
case ${src_dist} in
|
||||||
amazonlinux*) pkg_type=rpm
|
amazonlinux*) pkg_type=rpm
|
||||||
;;
|
;;
|
||||||
@ -100,27 +104,16 @@ function sync() {
|
|||||||
opensuse-leap*) pkg_type=rpm
|
opensuse-leap*) pkg_type=rpm
|
||||||
;;
|
;;
|
||||||
ubuntu*) pkg_type=deb
|
ubuntu*) pkg_type=deb
|
||||||
|
dst_arch=${arch//ppc64le/ppc64el}
|
||||||
;;
|
;;
|
||||||
*) echo "ERROR: unexpected distribution ${src_dist}"
|
*) echo "ERROR: unexpected distribution ${src_dist}"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
if [[ $# -ge 4 && $4 == "package_type" ]] ; then
|
if [[ x"${by_package_type}" == x"true" ]]; then
|
||||||
if [[ "${src_dist}" != "ubuntu18.04" && "${src_dist}" != "centos7" ]]; then
|
dst_dist=${pkg_type}
|
||||||
echo "Package type repos require ubuntu18.04 or centos7 as the source"
|
|
||||||
echo "skipping"
|
|
||||||
return
|
|
||||||
fi
|
fi
|
||||||
dst_dist=$pkg_type
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
local arch=${target##*-}
|
|
||||||
local dst_arch=${arch}
|
|
||||||
case ${src_dist} in
|
|
||||||
ubuntu*) dst_arch=${arch//ppc64le/ppc64el}
|
|
||||||
esac
|
|
||||||
|
|
||||||
local src=${src_root}/${src_dist}/${arch}
|
local src=${src_root}/${src_dist}/${arch}
|
||||||
local dst=${dst_root}/${dst_dist}/${dst_arch}
|
local dst=${dst_root}/${dst_dist}/${dst_arch}
|
||||||
@ -173,20 +166,27 @@ if [[ x"${_current_branch}" != x"gh-pages" ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
: ${UPSTREAM_REMOTE:="origin"}
|
: ${UPSTREAM_REMOTE:="origin"}
|
||||||
_remote_name=$( git remote -v | grep "git@gitlab.com:nvidia/container-toolkit/libnvidia-container.git (push)" | cut -d$'\t' -f1 )
|
|
||||||
if [[ x"${_remote_name}" != x"${UPSTREAM_REMOTE}" ]]; then
|
|
||||||
echo "Identified ${_remote_name} as git@gitlab.com:nvidia/container-toolkit/libnvidia-container.git remote."
|
|
||||||
echo "Set UPSTREAM_REMOTE=${_remote_name} instead of ${UPSTREAM_REMOTE}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
: ${UPSTREAM_REFERENCE:="${UPSTREAM_REMOTE}/gh-pages"}
|
: ${UPSTREAM_REFERENCE:="${UPSTREAM_REMOTE}/gh-pages"}
|
||||||
git -C ${PACKAGE_REPO_ROOT} reset --hard ${UPSTREAM_REFERENCE}
|
git -C ${PACKAGE_REPO_ROOT} reset --hard ${UPSTREAM_REFERENCE}
|
||||||
git -C ${PACKAGE_REPO_ROOT} clean -fdx ${REPO}
|
git -C ${PACKAGE_REPO_ROOT} clean -fdx ${REPO}
|
||||||
|
|
||||||
for target in ${targets[@]}; do
|
for target in ${targets[@]}; do
|
||||||
sync ${target} ${PACKAGE_CACHE}/packages ${PACKAGE_REPO_ROOT}/${REPO}
|
echo "checking target=${target}"
|
||||||
# We also create a `package_type` repo; internally we skip this for non-ubuntu18.04 or centos7 distributions
|
by_package_type=
|
||||||
sync ${target} ${PACKAGE_CACHE}/packages ${PACKAGE_REPO_ROOT}/${REPO} "package_type"
|
case ${target} in
|
||||||
|
ubuntu18.04-* | centos7-*)
|
||||||
|
by_package_type="true"
|
||||||
|
;;
|
||||||
|
centos8-ppc64le)
|
||||||
|
by_package_type="false"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Skipping target ${target}"
|
||||||
|
continue
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
sync ${target} ${PACKAGE_CACHE}/packages ${PACKAGE_REPO_ROOT}/${REPO} ${by_package_type}
|
||||||
done
|
done
|
||||||
|
|
||||||
git -C ${PACKAGE_REPO_ROOT} add ${REPO}
|
git -C ${PACKAGE_REPO_ROOT} add ${REPO}
|
||||||
@ -237,7 +237,6 @@ function sign() {
|
|||||||
gpg --import /keys/sub.key;
|
gpg --import /keys/sub.key;
|
||||||
/helpers/packages-sign-all.sh;
|
/helpers/packages-sign-all.sh;
|
||||||
"
|
"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sign deb
|
sign deb
|
||||||
|
Loading…
Reference in New Issue
Block a user