mirror of
https://github.com/siderolabs/talos.git
synced 2025-08-18 12:37:05 +02:00
This changes installer image/iso output to be tar via stdout (optionally), so that we can copy back artifacts back from remote docker daemon. Fixes #2776 Signed-off-by: Andrey Smirnov <smirnov.andrey@gmail.com>
64 lines
2.6 KiB
Bash
Executable File
64 lines
2.6 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -eou pipefail
|
|
|
|
source ./hack/test/e2e.sh
|
|
|
|
REGION="us-east-1"
|
|
BUCKET="talos-ci-e2e"
|
|
|
|
function setup {
|
|
# Setup svc account
|
|
mkdir -p ${TMP}
|
|
|
|
# Untar image
|
|
tar -C ${TMP} -xf ${ARTIFACTS}/aws-amd64.tar.gz
|
|
|
|
# Upload Image
|
|
echo "uploading image to s3"
|
|
aws s3 cp --quiet ${TMP}/disk.raw s3://${BUCKET}/aws-${TAG}.raw
|
|
|
|
# Create snapshot from image
|
|
echo "importing snapshot from s3"
|
|
import_task_id=$(aws ec2 import-snapshot --region ${REGION} --description "talos e2e ${TAG}" --disk-container "Format=raw,UserBucket={S3Bucket=${BUCKET},S3Key=aws-${TAG}.raw}" | jq -r '.ImportTaskId')
|
|
echo ${import_task_id}
|
|
|
|
# Wait for import to complete
|
|
echo "waiting for snapshot import to complete"
|
|
snapshot_status=$(aws ec2 describe-import-snapshot-tasks --region ${REGION} --import-task-ids ${import_task_id} | \
|
|
jq -r --arg image_name "aws-${TAG}.raw" '.ImportSnapshotTasks[] | select(.SnapshotTaskDetail.UserBucket.S3Key == $image_name) | .SnapshotTaskDetail.Status')
|
|
while [ ${snapshot_status} != "completed" ]; do
|
|
sleep 5
|
|
snapshot_status=$(aws ec2 describe-import-snapshot-tasks --region ${REGION} --import-task-ids ${import_task_id} | \
|
|
jq -r --arg image_name "aws-${TAG}.raw" '.ImportSnapshotTasks[] | select(.SnapshotTaskDetail.UserBucket.S3Key == $image_name) | .SnapshotTaskDetail.Status')
|
|
done
|
|
snapshot_id=$(aws ec2 describe-import-snapshot-tasks --region ${REGION} --import-task-ids ${import_task_id} | \
|
|
jq -r --arg image_name "aws-${TAG}.raw" '.ImportSnapshotTasks[] | select(.SnapshotTaskDetail.UserBucket.S3Key == $image_name) | .SnapshotTaskDetail.SnapshotId')
|
|
echo ${snapshot_id}
|
|
|
|
# Create AMI
|
|
image_id=$(aws ec2 describe-images --region ${REGION} --filters="Name=name,Values=talos-e2e-${TAG}" | jq -r '.Images[0].ImageId') || true
|
|
|
|
if [[ ${image_id} != "null" ]]; then
|
|
aws ec2 deregister-image --region ${REGION} --image-id ${image_id}
|
|
fi
|
|
|
|
ami=$(aws ec2 register-image --region ${REGION} \
|
|
--block-device-mappings "DeviceName=/dev/xvda,VirtualName=talostest,Ebs={DeleteOnTermination=true,SnapshotId=${snapshot_id},VolumeSize=20,VolumeType=gp2}" \
|
|
--root-device-name /dev/xvda \
|
|
--virtualization-type hvm \
|
|
--architecture x86_64 \
|
|
--ena-support \
|
|
--name talos-e2e-${TAG} | jq -r '.ImageId')
|
|
|
|
# Setup the cluster YAML.
|
|
sed -e "s#{{REGION}}#${REGION}#g" \
|
|
-e "s/{{TAG}}/${SHA}/" \
|
|
-e "s#{{AMI}}#${ami}#g" ${PWD}/hack/test/capi/cluster-aws.yaml > ${TMP}/cluster.yaml
|
|
}
|
|
|
|
setup
|
|
create_cluster_capi aws
|
|
run_talos_integration_test
|
|
run_kubernetes_integration_test
|