fi
# Default optional variables
-INSTANCE_START_TIMEOUT="${INSTANCE_START_TIMEOUT:-60}"
+INSTANCE_START_TIMEOUT="${INSTANCE_START_TIMEOUT:-120}"
NETWORK_SLEEP="${NETWORK_SLEEP:-15}"
# Dependencies
set -e
CLEANUP+=(
- "lxc stop ${INSTANCE_NAME}"
+ "lxc stop -f ${INSTANCE_NAME}"
)
# VMs may take more time to start, wait until instance is running
# Wait for cloud-init to finish
if [[ "${VARIANT}" == "cloud" ]] ; then
- lxc exec "${INSTANCE_NAME}" -- cloud-init status -w
+ # It's possible for cloud-init to fail, but to still be able to continue.
+ # Eg., a profile asks for netplan.io on a system that doesn't have that
+ # package available.
+ lxc exec "${INSTANCE_NAME}" -- cloud-init status -w || true
fi
# Wait for instance to have an ip address (@TODO: is there a better approach?)
-l "${INSTANCE_IP}" -i fake-inventory
# Publish
-lxc publish "${INSTANCE_NAME}" --alias "${TARGET_IMAGE_NAME}" -f
+if FINGERPRINT=$(lxc publish "${INSTANCE_NAME}" -f 2>&1 | grep -E -o '[A-Fa-f0-9]{64}') ; then
+ echo "Published instance with fingerprint '${FINGERPRINT}'"
+else
+ fail 1 "No fingerprint for published instance"
+fi
TRIES=0
if [[ "${TEST}" == "true" ]] ; then
set +e
while [[ "${TRIES}" -lt "${TRIES_MAX}" ]] ; do
- if ! INSTANCE_NAME=$(lxc -q launch -e "${VM_ARG[@]}" -p default -p "${LXD_INSTANCE_PROFILE}" "${TARGET_IMAGE_NAME}") ; then
+ if ! INSTANCE_NAME=$(lxc -q launch -e "${VM_ARG[@]}" -p default -p "${LXD_INSTANCE_PROFILE}" "${FINGERPRINT}") ; then
TRIES=$((TRIES + 1))
echo "Failed to launch instance try ${TRIES}/${TRIES_MAX}"
if [[ "${TRIES}" -lt "${TRIES_MAX}" ]] ; then
sleep $((1 + RANDOM % 10))
continue
fi
- fail 1 "Failed to launch an instance using newly published image '${TARGET_IMAGE_NAME}'"
+ fail 1 "Failed to launch an instance using newly published image '${FINGERPRINT}'"
else
INSTANCE_NAME="$(echo "${INSTANCE_NAME}" | cut -d':' -f2 | tr -d ' ')"
CLEANUP+=(
done
set -e
fi
+
+lxc image alias delete "${TARGET_IMAGE_NAME}" || true
+lxc image alias create "${TARGET_IMAGE_NAME}" "${FINGERPRINT}"