Merge "Remove patch-iso-debian's xmllint pkg requirement"

This commit is contained in:
Zuul 2024-07-11 18:39:38 +00:00 committed by Gerrit Code Review
commit 1da9fa200f

View File

@ -38,6 +38,18 @@ function usage() {
echo "" echo ""
} }
function extract_ostree_commit_from_metadata_xml() {
local XML_PATH=$1
local XPATH="//contents/ostree/commit1/commit"
# Check if xmllint is available. Otherwise, use python's xml standard lib
if (which xmllint &>/dev/null); then
xmllint --xpath "string(${XPATH})" ${XML_PATH}
else
python3 -c "import xml.etree.ElementTree as ET ; print(ET.parse('${XML_PATH}').find('.${XPATH}').text, end='')"
fi
}
function extract_metadata() { function extract_metadata() {
local patchesdir=${BUILDDIR}/patches local patchesdir=${BUILDDIR}/patches
local patchfile=$1 local patchfile=$1
@ -53,11 +65,11 @@ function extract_metadata() {
fi fi
# Verify if top commit from metadata exist in ostree log # Verify if top commit from metadata exist in ostree log
xml_base=$(xmllint --xpath "string(//contents/ostree/commit1/commit)" ${patchesdir}/${patchid}-metadata.xml) ostree_commit=$(extract_ostree_commit_from_metadata_xml ${patchesdir}/${patchid}-metadata.xml)
if [[ "$ostree_log" != *"$xml_base"* ]]; then if [[ "$ostree_log" != *"$ostree_commit"* ]]; then
echo "Error, xml base commit does not exist in ostree log." echo "Error: Patch ${patchid} ostree commit does not exist in ISO ostree log."
echo "patch base: ${xml_base}" echo "patch's ostree commit: ${ostree_commit}"
echo "ostree log:" echo "ISO ostree log:"
ostree --repo=${BUILDDIR}/ostree_repo log starlingx ostree --repo=${BUILDDIR}/ostree_repo log starlingx
exit 1 exit 1
fi fi
@ -120,13 +132,15 @@ declare MNTDIR=
declare BUILDDIR= declare BUILDDIR=
function check_requirements { function check_requirements {
# Declare "require reqA or reqB" as "reqA__reqB"
local -a required_utils=( local -a required_utils=(
rsync rsync
mkisofs mkisofs
isohybrid isohybrid
implantisomd5 implantisomd5
ostree ostree
xmllint xmllint__python3
) )
if [ $UID -ne 0 ]; then if [ $UID -ne 0 ]; then
# If running as non-root user, additional utils are required # If running as non-root user, additional utils are required
@ -137,12 +151,24 @@ function check_requirements {
fi fi
local -i missing=0 local -i missing=0
local reqA
local reqB
for req in ${required_utils[@]}; do for req in ${required_utils[@]}; do
which ${req} >&/dev/null if [[ "$req" = *"__"* ]]; then
if [ $? -ne 0 ]; then reqA="${req%__*}" # select everything before "__"
echo "Unable to find required utility: ${req}" >&2 reqB="${req#*__}" # select everything after "__"
let missing++
if ! (which ${reqA} &>/dev/null) && ! (which ${reqB} &>/dev/null); then
echo "Unable to find required utility: either ${reqA} or ${reqB}" >&2
let missing++
fi
else
if ! (which ${req} &>/dev/null); then
echo "Unable to find required utility: ${req}" >&2
let missing++
fi
fi fi
done done
@ -236,7 +262,7 @@ mkdir -p ${BUILDDIR}/patches
chmod -R +w ${BUILDDIR}/patches chmod -R +w ${BUILDDIR}/patches
echo "Copying only the latest commit from ostree_repo..." echo "Copying only the latest commit from ostree_repo..."
ostree --repo=${BUILDDIR}/ostree_repo init --mode=archive-z2 ostree --repo=${BUILDDIR}/ostree_repo init --mode=archive-z2
ostree --repo=${BUILDDIR}/ostree_repo pull-local --depth=0 ${OSTREE_REPO} starlingx ostree --repo=${BUILDDIR}/ostree_repo pull-local --depth=0 ${OSTREE_REPO} starlingx
ostree --repo=${BUILDDIR}/ostree_repo summary --update ostree --repo=${BUILDDIR}/ostree_repo summary --update
echo "Updated iso ostree commit:" echo "Updated iso ostree commit:"