Merge "Update vsphere image filename pattern"

This commit is contained in:
Jenkins 2013-11-22 16:19:01 +00:00 committed by Gerrit Code Review
commit 1fe3fc0457

View File

@ -1392,11 +1392,15 @@ function upload_image() {
# We take these values from the vmdk file if populated. Otherwise, we use # We take these values from the vmdk file if populated. Otherwise, we use
# vmdk filename, which is expected in the following format: # vmdk filename, which is expected in the following format:
# #
# <name>-<disk type>:<storage adapter>:<network adapter> # <name>-<disk type>;<storage adapter>;<network adapter>
# #
# If the filename does not follow the above format then the vsphere # If the filename does not follow the above format then the vsphere
# driver will supply default values. # driver will supply default values.
vmdk_adapter_type=""
vmdk_disktype=""
vmdk_net_adapter=""
# vmdk adapter type # vmdk adapter type
vmdk_adapter_type="$(head -25 $IMAGE | grep -a -F -m 1 'ddb.adapterType =' $IMAGE)" vmdk_adapter_type="$(head -25 $IMAGE | grep -a -F -m 1 'ddb.adapterType =' $IMAGE)"
vmdk_adapter_type="${vmdk_adapter_type#*\"}" vmdk_adapter_type="${vmdk_adapter_type#*\"}"
@ -1415,17 +1419,15 @@ function upload_image() {
#TODO(alegendre): handle streamOptimized once supported by VMware driver. #TODO(alegendre): handle streamOptimized once supported by VMware driver.
vmdk_disktype="preallocated" vmdk_disktype="preallocated"
fi fi
property_string=`echo "$IMAGE_NAME" | grep -oP '(?<=-)(?!.*-).+:.+:.+$'`
if [[ ! -z "$property_string" ]]; then # NOTE: For backwards compatibility reasons, colons may be used in place
IFS=':' read -a props <<< "$property_string" # of semi-colons for property delimiters but they are not permitted
if [[ ! -z "${props[0]}" ]]; then # characters in NTFS filesystems.
vmdk_disktype="${props[0]}" property_string=`echo "$IMAGE_NAME" | grep -oP '(?<=-)(?!.*-).+[:;].+[:;].+$'`
fi IFS=':;' read -a props <<< "$property_string"
if [[ ! -z "${props[1]}" ]]; then vmdk_disktype="${props[0]:-$vmdk_disktype}"
vmdk_adapter_type="${props[1]}" vmdk_adapter_type="${props[1]:-$vmdk_adapter_type}"
fi vmdk_net_adapter="${props[2]:-$vmdk_net_adapter}"
vmdk_net_adapter="${props[2]}"
fi
glance --os-auth-token $token --os-image-url http://$GLANCE_HOSTPORT image-create --name "$IMAGE_NAME" --is-public=True --container-format bare --disk-format vmdk --property vmware_disktype="$vmdk_disktype" --property vmware_adaptertype="$vmdk_adapter_type" --property hw_vif_model="$vmdk_net_adapter" < "${IMAGE}" glance --os-auth-token $token --os-image-url http://$GLANCE_HOSTPORT image-create --name "$IMAGE_NAME" --is-public=True --container-format bare --disk-format vmdk --property vmware_disktype="$vmdk_disktype" --property vmware_adaptertype="$vmdk_adapter_type" --property hw_vif_model="$vmdk_net_adapter" < "${IMAGE}"
return return