Use version from manifest to extract packages

Signed-off-by: Evan Lezar <elezar@nvidia.com>
This commit is contained in:
Evan Lezar 2023-05-08 15:40:42 +02:00
parent 39b0830a66
commit 1c1ce2c6f7
3 changed files with 72 additions and 21 deletions

View File

@ -67,13 +67,6 @@ fi
KITMAKER_SCRATCH="${KITMAKER_DIR}/.scratch" KITMAKER_SCRATCH="${KITMAKER_DIR}/.scratch"
# extract_info extracts the value of the specified variable from the manifest.txt file.
function extract_info() {
local variable=$1
local value=$(cat "${ARTIFACTS_DIR}/manifest.txt" | grep "#${variable}=" | sed -e "s/#${variable}=//" | tr -d '\r')
echo $value
}
IMAGE_EPOCH=$(extract_info "IMAGE_EPOCH") IMAGE_EPOCH=$(extract_info "IMAGE_EPOCH")
# Note we use the main branch for the kitmaker archive. # Note we use the main branch for the kitmaker archive.
GIT_BRANCH=main GIT_BRANCH=main
@ -129,8 +122,6 @@ function create_archive() {
rmdir "${scratch_dir}" rmdir "${scratch_dir}"
} }
function join_by { local IFS="$1"; shift; echo "$*"; }
function optionally_add_property() { function optionally_add_property() {
local property=$1 local property=$1
local value=$2 local value=$2

View File

@ -31,6 +31,8 @@ if [[ $# -lt 1 || $# -gt 2 ]]; then
assert_usage $* assert_usage $*
fi fi
source "${SCRIPTS_DIR}"/utils.sh
PACKAGE_REPO_ROOT=$1 PACKAGE_REPO_ROOT=$1
if [[ ! -d ${PACKAGE_REPO_ROOT} ]]; then if [[ ! -d ${PACKAGE_REPO_ROOT} ]]; then
echo "The specified PACKAGE_REPO_ROOT '${PACKAGE_REPO_ROOT}' must exist" echo "The specified PACKAGE_REPO_ROOT '${PACKAGE_REPO_ROOT}' must exist"
@ -42,21 +44,20 @@ if [[ $# -ge 2 ]]; then
REFERENCE=$2 REFERENCE=$2
fi fi
eval $(${SCRIPTS_DIR}/get-component-versions.sh)
TAG=v"${NVIDIA_CONTAINER_TOOLKIT_PACKAGE_VERSION}"
SHA=$(git rev-parse --short=8 ${REFERENCE}) SHA=$(git rev-parse --short=8 ${REFERENCE})
IMAGE_NAME="registry.gitlab.com/nvidia/container-toolkit/container-toolkit/staging/container-toolkit"
IMAGE_TAG=${SHA}-packaging
VERSION="$(get_version_from_image ${IMAGE_NAME}:${IMAGE_TAG} ${SHA})"
REPO="experimental" REPO="experimental"
if [[ ${TAG/rc./} == ${TAG} ]]; then if [[ ${VERSION/rc./} == ${VERSION} ]]; then
REPO="stable" REPO="stable"
fi fi
PACKAGE_CACHE=release-${TAG}-${REPO} PACKAGE_CACHE=release-${VERSION}-${REPO}
echo "Fetching packages with SHA '${SHA}' as tag '${TAG}' to ${PACKAGE_CACHE}" echo "Fetching packages with SHA '${SHA}' as tag '${VERSION}' to ${PACKAGE_CACHE}"
IMAGE_NAME="registry.gitlab.com/nvidia/container-toolkit/container-toolkit/staging/container-toolkit"
IMAGE_TAG=${SHA}-packaging
${SCRIPTS_DIR}/pull-packages.sh \ ${SCRIPTS_DIR}/pull-packages.sh \
${IMAGE_NAME}:${IMAGE_TAG} \ ${IMAGE_NAME}:${IMAGE_TAG} \
${PACKAGE_CACHE} ${PACKAGE_CACHE}
@ -197,7 +198,7 @@ git -C ${PACKAGE_REPO_ROOT} add ${REPO}
if [[ ${REPO} == "stable" ]]; then if [[ ${REPO} == "stable" ]]; then
# Stable release # Stable release
git -C ${PACKAGE_REPO_ROOT} commit -s -F- <<EOF git -C ${PACKAGE_REPO_ROOT} commit -s -F- <<EOF
Add packages for NVIDIA Container Toolkit ${TAG} release Add packages for NVIDIA Container Toolkit ${VERSION} release
These include: These include:
* libnvidia-container* ${LIBNVIDIA_CONTAINER_PACKAGE_VERSION} * libnvidia-container* ${LIBNVIDIA_CONTAINER_PACKAGE_VERSION}
@ -208,7 +209,7 @@ EOF
else else
# Experimental / release candidate release # Experimental / release candidate release
git -C ${PACKAGE_REPO_ROOT} commit -s -F- <<EOF git -C ${PACKAGE_REPO_ROOT} commit -s -F- <<EOF
Add packages for NVIDIA Container Toolkit ${TAG} ${REPO} release Add packages for NVIDIA Container Toolkit ${VERSION} ${REPO} release
These include: These include:
* libnvidia-container* ${LIBNVIDIA_CONTAINER_PACKAGE_VERSION} * libnvidia-container* ${LIBNVIDIA_CONTAINER_PACKAGE_VERSION}
@ -246,12 +247,12 @@ function sign() {
sign deb sign deb
git -C ${PACKAGE_REPO_ROOT} add ${REPO} git -C ${PACKAGE_REPO_ROOT} add ${REPO}
git -C ${PACKAGE_REPO_ROOT} commit -s -m "TOFIX: Sign deb packages for ${TAG} in ${REPO}" git -C ${PACKAGE_REPO_ROOT} commit -s -m "TOFIX: Sign deb packages for ${VERSION} in ${REPO}"
sign rpm sign rpm
git -C ${PACKAGE_REPO_ROOT} add ${REPO} git -C ${PACKAGE_REPO_ROOT} add ${REPO}
git -C ${PACKAGE_REPO_ROOT} commit -s -m "TOFIX: Sign rpm packages for ${TAG} in ${REPO}" git -C ${PACKAGE_REPO_ROOT} commit -s -m "TOFIX: Sign rpm packages for ${VERSION} in ${REPO}"
echo "To publish changes, go to ${PACKAGE_REPO_ROOT} and run: " echo "To publish changes, go to ${PACKAGE_REPO_ROOT} and run: "
echo " git rebase -i ${UPSTREAM_REFERENCE}" echo " git rebase -i ${UPSTREAM_REFERENCE}"

View File

@ -1,3 +1,17 @@
# Copyright (c) NVIDIA CORPORATION. All rights reserved.
#
# 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.
# package_type returns the packaging type (deb or rpm) for the specfied distribution. # package_type returns the packaging type (deb or rpm) for the specfied distribution.
# An error is returned if the ditribution is unsupported. # An error is returned if the ditribution is unsupported.
@ -53,3 +67,48 @@ function get_package_target() {
;; ;;
esac esac
} }
# extract-file copies a file from a specified image.
# If regctl is available this is used, otherwise a docker container is run and the file is copied from
# there.
function copy_file() {
local image=$1
local path_in_image=$2
local path_on_host=$3
if command -v regctl > /dev/null; then
regctl image get-file "${image}" "${path_in_image}" "${path_on_host}"
else
# Note this will only work for destinations where the `path_on_host` is in `pwd`
docker run --rm \
-v "$(pwd):$(pwd)" \
-w "$(pwd)" \
-u "$(id -u):$(id -g)" \
--entrypoint="bash" \
"${image}" \
-c "cp ${path_in_image} ${path_on_host}"
fi
}
# extract_info extracts the value of the specified variable from the manifest.txt file.
function extract_from_manifest() {
local variable=$1
local manifest=$2
local value=$(cat ${manifest} | grep "#${variable}=" | sed -e "s/#${variable}=//" | tr -d '\r')
echo $value
}
# extract_info extracts the value of the specified variable from the manifest.txt file.
function extract_info() {
extract_from_manifest $1 "${ARTIFACTS_DIR}/manifest.txt"
}
function get_version_from_image() {
local image=$1
local manifest="manifest-${2}.txt"
copy_file ${image} "/artifacts/manifest.txt" ${manifest}
version=$(extract_from_manifest "PACKAGE_VERSION" ${manifest})
echo "v${version/\~/-}"
rm -f ${manifest}
}
function join_by { local IFS="$1"; shift; echo "$*"; }