2021-08-04 12:40:10 +00:00
|
|
|
from . import _get_clients, _setup
|
2021-10-26 12:27:24 +00:00
|
|
|
import pytest
|
2021-10-18 19:44:29 +00:00
|
|
|
import sure # noqa # pylint: disable=unused-import
|
2022-02-20 14:01:29 +00:00
|
|
|
from botocore.exceptions import ClientError
|
2021-10-05 17:11:07 +00:00
|
|
|
from moto import mock_batch, mock_iam, mock_ec2, mock_ecs, settings
|
|
|
|
from uuid import uuid4
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
# Yes, yes it talks to all the things
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_managed_compute_environment():
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, ecs_client, _, batch_client = _get_clients()
|
|
|
|
_, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
compute_name = str(uuid4())
|
2021-08-04 12:40:10 +00:00
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="MANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
computeResources={
|
|
|
|
"type": "EC2",
|
|
|
|
"minvCpus": 5,
|
|
|
|
"maxvCpus": 10,
|
|
|
|
"desiredvCpus": 5,
|
|
|
|
"instanceTypes": ["t2.small", "t2.medium"],
|
|
|
|
"imageId": "some_image_id",
|
|
|
|
"subnets": [subnet_id],
|
|
|
|
"securityGroupIds": [sg_id],
|
|
|
|
"ec2KeyPair": "string",
|
|
|
|
"instanceRole": iam_arn.replace("role", "instance-profile"),
|
|
|
|
"tags": {"string": "string"},
|
|
|
|
"bidPercentage": 123,
|
|
|
|
"spotIamFleetRole": "string",
|
|
|
|
},
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
resp.should.contain("computeEnvironmentArn")
|
|
|
|
resp["computeEnvironmentName"].should.equal(compute_name)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
our_env = batch_client.describe_compute_environments(
|
|
|
|
computeEnvironments=[compute_name]
|
|
|
|
)["computeEnvironments"][0]
|
|
|
|
|
2021-08-04 12:40:10 +00:00
|
|
|
# Given a t2.medium is 2 vcpu and t2.small is 1, therefore 2 mediums and 1 small should be created
|
2021-10-05 17:11:07 +00:00
|
|
|
if not settings.TEST_SERVER_MODE:
|
|
|
|
# Can't verify this in ServerMode, as other tests may have created instances
|
|
|
|
resp = ec2_client.describe_instances()
|
|
|
|
resp.should.contain("Reservations")
|
|
|
|
len(resp["Reservations"]).should.equal(3)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
# Should have created 1 ECS cluster
|
2021-10-05 17:11:07 +00:00
|
|
|
all_clusters = ecs_client.list_clusters()["clusterArns"]
|
|
|
|
all_clusters.should.contain(our_env["ecsClusterArn"])
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
2022-02-20 14:01:29 +00:00
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_managed_compute_environment_with_instance_family():
|
|
|
|
"""
|
|
|
|
The InstanceType parameter can have multiple values:
|
|
|
|
instance_type t2.small
|
|
|
|
instance_family t2 <-- What we're testing here
|
|
|
|
'optimal'
|
|
|
|
unknown value
|
|
|
|
"""
|
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
|
|
|
_, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = str(uuid4())
|
|
|
|
batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="MANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
computeResources={
|
|
|
|
"type": "EC2",
|
|
|
|
"minvCpus": 5,
|
|
|
|
"maxvCpus": 10,
|
|
|
|
"desiredvCpus": 5,
|
|
|
|
"instanceTypes": ["t2"],
|
|
|
|
"imageId": "some_image_id",
|
|
|
|
"subnets": [subnet_id],
|
|
|
|
"securityGroupIds": [sg_id],
|
|
|
|
"ec2KeyPair": "string",
|
|
|
|
"instanceRole": iam_arn.replace("role", "instance-profile"),
|
|
|
|
"tags": {"string": "string"},
|
|
|
|
"bidPercentage": 123,
|
|
|
|
"spotIamFleetRole": "string",
|
|
|
|
},
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
|
|
|
|
our_env = batch_client.describe_compute_environments(
|
|
|
|
computeEnvironments=[compute_name]
|
|
|
|
)["computeEnvironments"][0]
|
|
|
|
our_env["computeResources"]["instanceTypes"].should.equal(["t2"])
|
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_managed_compute_environment_with_unknown_instance_type():
|
|
|
|
"""
|
|
|
|
The InstanceType parameter can have multiple values:
|
|
|
|
instance_type t2.small
|
|
|
|
instance_family t2
|
|
|
|
'optimal'
|
|
|
|
unknown value <-- What we're testing here
|
|
|
|
"""
|
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
|
|
|
_, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = str(uuid4())
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="MANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
computeResources={
|
|
|
|
"type": "EC2",
|
|
|
|
"minvCpus": 5,
|
|
|
|
"maxvCpus": 10,
|
|
|
|
"desiredvCpus": 5,
|
|
|
|
"instanceTypes": ["unknown"],
|
|
|
|
"imageId": "some_image_id",
|
|
|
|
"subnets": [subnet_id],
|
|
|
|
"securityGroupIds": [sg_id],
|
|
|
|
"ec2KeyPair": "string",
|
|
|
|
"instanceRole": iam_arn.replace("role", "instance-profile"),
|
|
|
|
"tags": {"string": "string"},
|
|
|
|
"bidPercentage": 123,
|
|
|
|
"spotIamFleetRole": "string",
|
|
|
|
},
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
err = exc.value.response["Error"]
|
|
|
|
err["Code"].should.equal("InvalidParameterValue")
|
|
|
|
err["Message"].should.equal("Instance type unknown does not exist")
|
|
|
|
|
|
|
|
|
2021-08-04 12:40:10 +00:00
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_unmanaged_compute_environment():
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, ecs_client, _, batch_client = _get_clients()
|
|
|
|
_, _, _, iam_arn = _setup(ec2_client, iam_client)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
compute_name = str(uuid4())
|
2021-08-04 12:40:10 +00:00
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
resp.should.contain("computeEnvironmentArn")
|
|
|
|
resp["computeEnvironmentName"].should.equal(compute_name)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
our_env = batch_client.describe_compute_environments(
|
|
|
|
computeEnvironments=[compute_name]
|
|
|
|
)["computeEnvironments"][0]
|
|
|
|
our_env.should.have.key("ecsClusterArn")
|
|
|
|
|
2021-08-04 12:40:10 +00:00
|
|
|
# Its unmanaged so no instances should be created
|
2021-10-05 17:11:07 +00:00
|
|
|
if not settings.TEST_SERVER_MODE:
|
|
|
|
# Can't verify this in ServerMode, as other tests may have created instances
|
|
|
|
resp = ec2_client.describe_instances()
|
|
|
|
resp.should.contain("Reservations")
|
|
|
|
len(resp["Reservations"]).should.equal(0)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
# Should have created 1 ECS cluster
|
2021-10-05 17:11:07 +00:00
|
|
|
all_clusters = ecs_client.list_clusters()["clusterArns"]
|
|
|
|
all_clusters.should.contain(our_env["ecsClusterArn"])
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
# TODO create 1000s of tests to test complex option combinations of create environment
|
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_describe_compute_environment():
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
|
|
|
_, _, _, iam_arn = _setup(ec2_client, iam_client)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
compute_name = str(uuid4())
|
|
|
|
compute_arn = (
|
|
|
|
f"arn:aws:batch:eu-central-1:123456789012:compute-environment/{compute_name}"
|
|
|
|
)
|
2021-08-04 12:40:10 +00:00
|
|
|
batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_envs = batch_client.describe_compute_environments()["computeEnvironments"]
|
|
|
|
our_envs = [e for e in all_envs if e["computeEnvironmentName"] == compute_name]
|
|
|
|
our_envs.should.have.length_of(1)
|
|
|
|
our_envs[0]["computeEnvironmentName"].should.equal(compute_name)
|
|
|
|
our_envs[0]["computeEnvironmentArn"].should.equal(compute_arn)
|
|
|
|
our_envs[0].should.have.key("ecsClusterArn")
|
|
|
|
our_envs[0].should.have.key("state").equal("ENABLED")
|
|
|
|
our_envs[0].should.have.key("status").equal("VALID")
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
# Test filtering
|
|
|
|
resp = batch_client.describe_compute_environments(computeEnvironments=["test1"])
|
|
|
|
len(resp["computeEnvironments"]).should.equal(0)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_delete_unmanaged_compute_environment():
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, ecs_client, _, batch_client = _get_clients()
|
|
|
|
_, _, _, iam_arn = _setup(ec2_client, iam_client)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
compute_name = str(uuid4())
|
2021-08-04 12:40:10 +00:00
|
|
|
batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
our_env = batch_client.describe_compute_environments(
|
|
|
|
computeEnvironments=[compute_name]
|
|
|
|
)["computeEnvironments"][0]
|
|
|
|
|
2021-08-04 12:40:10 +00:00
|
|
|
batch_client.delete_compute_environment(computeEnvironment=compute_name)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_envs = batch_client.describe_compute_environments()["computeEnvironments"]
|
|
|
|
all_names = [e["computeEnvironmentName"] for e in all_envs]
|
|
|
|
all_names.shouldnt.contain(compute_name)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_clusters = ecs_client.list_clusters()["clusterArns"]
|
|
|
|
all_clusters.shouldnt.contain(our_env["ecsClusterArn"])
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_delete_managed_compute_environment():
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, ecs_client, _, batch_client = _get_clients()
|
|
|
|
_, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
compute_name = str(uuid4())
|
2021-08-04 12:40:10 +00:00
|
|
|
batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="MANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
computeResources={
|
|
|
|
"type": "EC2",
|
|
|
|
"minvCpus": 5,
|
|
|
|
"maxvCpus": 10,
|
|
|
|
"desiredvCpus": 5,
|
|
|
|
"instanceTypes": ["t2.small", "t2.medium"],
|
|
|
|
"imageId": "some_image_id",
|
|
|
|
"subnets": [subnet_id],
|
|
|
|
"securityGroupIds": [sg_id],
|
|
|
|
"ec2KeyPair": "string",
|
|
|
|
"instanceRole": iam_arn.replace("role", "instance-profile"),
|
|
|
|
"tags": {"string": "string"},
|
|
|
|
"bidPercentage": 123,
|
|
|
|
"spotIamFleetRole": "string",
|
|
|
|
},
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
our_env = batch_client.describe_compute_environments(
|
|
|
|
computeEnvironments=[compute_name]
|
|
|
|
)["computeEnvironments"][0]
|
|
|
|
|
2021-08-04 12:40:10 +00:00
|
|
|
batch_client.delete_compute_environment(computeEnvironment=compute_name)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_envs = batch_client.describe_compute_environments()["computeEnvironments"]
|
|
|
|
all_names = [e["computeEnvironmentName"] for e in all_envs]
|
|
|
|
all_names.shouldnt.contain(compute_name)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
if not settings.TEST_SERVER_MODE:
|
|
|
|
# Too many instances to know which one is ours in ServerMode
|
|
|
|
resp = ec2_client.describe_instances()
|
|
|
|
resp.should.contain("Reservations")
|
|
|
|
len(resp["Reservations"]).should.equal(3)
|
|
|
|
for reservation in resp["Reservations"]:
|
|
|
|
reservation["Instances"][0]["State"]["Name"].should.equal("terminated")
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_clusters = ecs_client.list_clusters()["clusterArns"]
|
|
|
|
all_clusters.shouldnt.contain(our_env["ecsClusterArn"])
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_update_unmanaged_compute_environment_state():
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
|
|
|
_, _, _, iam_arn = _setup(ec2_client, iam_client)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
compute_name = str(uuid4())
|
2021-08-04 12:40:10 +00:00
|
|
|
batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
|
|
|
|
batch_client.update_compute_environment(
|
|
|
|
computeEnvironment=compute_name, state="DISABLED"
|
|
|
|
)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_envs = batch_client.describe_compute_environments()["computeEnvironments"]
|
|
|
|
our_envs = [e for e in all_envs if e["computeEnvironmentName"] == compute_name]
|
|
|
|
our_envs.should.have.length_of(1)
|
|
|
|
our_envs[0]["state"].should.equal("DISABLED")
|
2021-10-26 12:27:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize("compute_env_type", ["FARGATE", "FARGATE_SPOT"])
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_fargate_managed_compute_environment(compute_env_type):
|
|
|
|
ec2_client, iam_client, ecs_client, _, batch_client = _get_clients()
|
|
|
|
_, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = str(uuid4())
|
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="MANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
computeResources={
|
|
|
|
"type": compute_env_type,
|
|
|
|
"maxvCpus": 10,
|
|
|
|
"subnets": [subnet_id],
|
|
|
|
"securityGroupIds": [sg_id],
|
|
|
|
},
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
resp.should.contain("computeEnvironmentArn")
|
|
|
|
resp["computeEnvironmentName"].should.equal(compute_name)
|
|
|
|
|
|
|
|
our_env = batch_client.describe_compute_environments(
|
|
|
|
computeEnvironments=[compute_name]
|
|
|
|
)["computeEnvironments"][0]
|
|
|
|
|
|
|
|
our_env["computeResources"]["type"].should.equal(compute_env_type)
|
|
|
|
# Should have created 1 ECS cluster
|
|
|
|
all_clusters = ecs_client.list_clusters()["clusterArns"]
|
|
|
|
all_clusters.should.contain(our_env["ecsClusterArn"])
|