diff --git a/l4v-deploy/common.py b/l4v-deploy/common.py index 28b3cc1e..f1c85ada 100644 --- a/l4v-deploy/common.py +++ b/l4v-deploy/common.py @@ -7,6 +7,7 @@ import subprocess + def run_command(*args, **kwargs): '''Trivial wrapper for subprocess.check_output''' return subprocess.check_output(*args, **kwargs) diff --git a/l4v-deploy/steps.sh b/l4v-deploy/steps.sh index 4dc5cc2c..1f4d6b75 100755 --- a/l4v-deploy/steps.sh +++ b/l4v-deploy/steps.sh @@ -22,14 +22,23 @@ echo "::endgroup::" if [ -z "${INPUT_PREPROCESS}" ] then - # As a safeguard, we insist that INPUT_MANIFEST is - # only set for preprocess updates. - if [ -n "${INPUT_MANIFEST}" ] + # For deployment after test, we can only deal with the default devel.xml and a + # potentially provided mcs-devel.xml, but no other input manifests. + if [ -n "${INPUT_MANIFEST}" ] && [ "${INPUT_MANIFEST}" != "mcs-devel.xml" ] then - echo "Error: INPUT_MANIFEST was set for a non-preprocess deployment" >&2 + echo "Error: INPUT_MANIFEST was set, but not mcs-devel.xml for a non-preprocess deployment" >&2 exit 1 fi + if [ "${INPUT_MANIFEST}" == "mcs-devel.xml" ]; then + # for checkout-manifest.sh; read input from mcs-devel.xml + export REPO_MANIFEST="$INPUT_MANIFEST" + # deploy hashes to mcs.xml + declare -a MANIFEST_FILE=("--manifest-file" "mcs.xml") + else + declare -a MANIFEST_FILE + fi + echo "::group::Repo checkout" export REPO_DEPTH=0 checkout-manifest.sh @@ -43,10 +52,13 @@ then echo "::endgroup::" echo "::group::Deploy" - staging-manifest ssh://git@github.com/seL4/verification-manifest.git + staging-manifest "${MANIFEST_FILE[@]}" ssh://git@github.com/seL4/verification-manifest.git echo "::endgroup::" else if [ -n "${INPUT_MANIFEST}" ]; then + # for checkout-manifest.sh + export REPO_MANIFEST="$MANIFEST_FILE" + # for sel4-pp declare -a MANIFEST_FILE=("--manifest-file" "${INPUT_MANIFEST}") else declare -a MANIFEST_FILE