Always use the latest AMI image

This commit is contained in:
butomo1989 2018-08-20 11:46:09 +02:00
parent ac9371a2ed
commit a5d0e6eba2
2 changed files with 33 additions and 15 deletions

View file

@ -1,12 +1,12 @@
[
{
"region": "eu-west-1",
"ami": "ami-861125ff",
"android_version": "6.0",
"instance": "t2.small"
},
{
"region": "eu-west-1",
"ami": "ami-861125ff",
"android_version": "8.0",
"instance": "t2.small"
}
]

View file

@ -45,12 +45,12 @@ function prepare_geny_aws() {
}
region=$(get_value '.region')
ami=$(get_value '.ami')
android_version=$(get_value '.android_version')
instance=$(get_value '.instance')
echo $region
echo $ami
echo $android_version
echo $instance
aws_tf_content=$(cat <<_EOF
@ -59,9 +59,9 @@ variable "aws_region_$index" {
default = "$region"
}
variable "ami_id_$index" {
variable "android_version_$index" {
type = "string"
default = "$ami"
default = "$android_version"
}
variable "instance_type_$index" {
@ -84,21 +84,39 @@ resource "aws_security_group" "geny_sg_$index" {
protocol = "tcp"
cidr_blocks = ["0.0.0.0/0"]
}
egress {
from_port = 0
to_port = 65535
protocol = "udp"
cidr_blocks = ["0.0.0.0/0"]
}
}
data "aws_ami" "geny_aws_$index" {
provider = "aws.provider_$index"
most_recent = true
filter {
name = "name"
values = ["genymotion-ami-\${var.android_version_$index}-*"]
}
}
resource "aws_instance" "geny_aws_$index" {
provider = "aws.provider_$index"
ami = "\${var.ami_id_$index}"
ami = "\${data.aws_ami.geny_aws_$index.id}"
instance_type = "\${var.instance_type_$index}"
vpc_security_group_ids = ["\${aws_security_group.geny_sg_$index.name}"]
tags {
Name = "EK-\${var.ami_id_$index}"
Name = "EK-\${data.aws_ami.geny_aws_$index.id}"
}
count = 1
}
output "image_id_$index" {
value = "\${data.aws_ami.geny_aws_$index.id}"
}
output "instance_id_$index" {
value = "\${aws_instance.geny_aws_$index.*.id}"
}