diff options
author | Luc Provoost <luc.provoost@intel.com> | 2021-03-15 20:49:40 +0100 |
---|---|---|
committer | Luc Provoost <luc.provoost@intel.com> | 2021-03-16 19:01:17 +0100 |
commit | d6dbd2b75d78d40e47d5a63fa5c5dd0d54a91307 (patch) | |
tree | 00ae2dfc5017add97cf9b1c5a06e5764c24be538 | |
parent | c8b5dd5aa379c9b8fd60a66be16351f62e5e5ebb (diff) |
build-image.sh is now taking parameters: -i -g
The -i option is now specifying the appendix for the the image name. The
name of the image will be rapid-<appendix>.qcow2. The -i option could then
be used to specify 'latest' or 'stable'.
The -g option specifies the google storage url where the qcow2 will be
stored.
The -v option is still existing in case we want to only verify the qcow2
image creation process.
An example:
buils-image.sh -g artifacts.opnfv.org/samplevnf/images -i latest -v
Change-Id: Ie07a89eff029f4e9fd3e1f2ebff1eaea05c580a6
Signed-off-by: Luc Provoost <luc.provoost@intel.com>
-rwxr-xr-x | rapidvm/dib/build-image.sh | 57 |
1 files changed, 29 insertions, 28 deletions
diff --git a/rapidvm/dib/build-image.sh b/rapidvm/dib/build-image.sh index 49086dec..63b0b6cf 100755 --- a/rapidvm/dib/build-image.sh +++ b/rapidvm/dib/build-image.sh @@ -15,32 +15,41 @@ # A shell script to build the PROX VM image using diskimage-builder # usage() { - echo "Usage: $0 [-v]" - echo " -v verify only (build but do not push to google storage)" + echo "Usage: $0 [-i image_name] [-g gs-url] [-v]" + echo " -i image_appendix image name to be pushed to google storage)" + echo " -g gs_url url to store the image" + echo " -v verify only (build but do not push to google storage)" exit 1 } -# Takes only 1 optional argument -if [ $# -gt 1 ]; then - usage -fi +# set -e +#default values +image_appendix="test" +gs_url="artifacts.opnfv.org/samplevnf/images" verify_only=0 +while getopts i:g:v flag +do + case "${flag}" in + i) image_appendix=${OPTARG};; + g) gs_url=${OPTARG};; + v) verify_only=1;; + *) usage;exit 1;; + esac +done +echo "gs_url: $gs_url"; +echo "Verify only: $verify_only"; +image_name=rapid-${image_appendix} +echo "image name: $image_name.qcow2" -if [ $# -eq 1 ]; then - if [ $1 = "-v" ]; then - verify_only=1 - else - usage - fi -fi -set -e - -# Artifact URL -gs_url=artifacts.opnfv.org/samplevnf/images +# install diskimage-builder -image_name=rapid-${GIT_BRANCH##*/} +python3 -m venv dib-rapid-venv +. dib-rapid-venv/bin/activate +pip3 install --upgrade pip +pip3 install six +pip3 install diskimage-builder +pip3 install gsutil -# if image exists skip building echo "Checking if image exists in google storage..." if command -v gsutil >/dev/null; then if gsutil -q stat gs://$gs_url/$image_name.qcow2; then @@ -52,14 +61,6 @@ else echo "Cannot check image availability in OPNFV artifact repository (gsutil not available)" fi -# install diskimage-builder -if [ -d dib-venv ]; then - . dib-venv/bin/activate -else - virtualenv dib-venv - . dib-venv/bin/activate - pip install diskimage-builder -fi # Add rapid elements directory to the DIB elements path export ELEMENTS_PATH=`pwd`/elements # canned user/password for direct login @@ -83,7 +84,7 @@ else if command -v gsutil >/dev/null; then echo "Uploading $image_name.qcow2..." gsutil cp $image_name.qcow2 gs://$gs_url/$image_name.qcow2 - echo "You can access to image at http://$gs_url/$image_name.qcow2" + echo "You can access image at http://$gs_url/$image_name.qcow2" else echo "Cannot upload new image to the OPNFV artifact repository (gsutil not available)" exit 1 |