2017-09-26 16:37:26 +00:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import boto3
|
2017-10-03 22:21:06 +00:00
|
|
|
from botocore.exceptions import ClientError
|
2017-09-26 16:37:26 +00:00
|
|
|
import sure # noqa
|
2017-09-29 22:29:36 +00:00
|
|
|
from moto import mock_batch, mock_iam, mock_ec2, mock_ecs
|
2017-09-26 16:37:26 +00:00
|
|
|
|
|
|
|
|
2017-09-26 21:22:59 +00:00
|
|
|
DEFAULT_REGION = 'eu-central-1'
|
|
|
|
|
|
|
|
|
|
|
|
def _get_clients():
|
|
|
|
return boto3.client('ec2', region_name=DEFAULT_REGION), \
|
|
|
|
boto3.client('iam', region_name=DEFAULT_REGION), \
|
2017-09-29 22:29:36 +00:00
|
|
|
boto3.client('ecs', region_name=DEFAULT_REGION), \
|
2017-09-26 21:22:59 +00:00
|
|
|
boto3.client('batch', region_name=DEFAULT_REGION)
|
|
|
|
|
|
|
|
|
|
|
|
def _setup(ec2_client, iam_client):
|
|
|
|
"""
|
|
|
|
Do prerequisite setup
|
|
|
|
:return: VPC ID, Subnet ID, Security group ID, IAM Role ARN
|
|
|
|
:rtype: tuple
|
|
|
|
"""
|
|
|
|
resp = ec2_client.create_vpc(CidrBlock='172.30.0.0/24')
|
|
|
|
vpc_id = resp['Vpc']['VpcId']
|
|
|
|
resp = ec2_client.create_subnet(
|
|
|
|
AvailabilityZone='eu-central-1a',
|
|
|
|
CidrBlock='172.30.0.0/25',
|
|
|
|
VpcId=vpc_id
|
|
|
|
)
|
|
|
|
subnet_id = resp['Subnet']['SubnetId']
|
|
|
|
resp = ec2_client.create_security_group(
|
|
|
|
Description='test_sg_desc',
|
|
|
|
GroupName='test_sg',
|
|
|
|
VpcId=vpc_id
|
|
|
|
)
|
|
|
|
sg_id = resp['GroupId']
|
|
|
|
|
|
|
|
resp = iam_client.create_role(
|
|
|
|
RoleName='TestRole',
|
|
|
|
AssumeRolePolicyDocument='some_policy'
|
|
|
|
)
|
|
|
|
iam_arn = resp['Role']['Arn']
|
|
|
|
|
|
|
|
return vpc_id, subnet_id, sg_id, iam_arn
|
|
|
|
|
|
|
|
|
|
|
|
# Yes, yes it talks to all the things
|
|
|
|
@mock_ec2
|
2017-09-29 22:29:36 +00:00
|
|
|
@mock_ecs
|
2017-09-26 21:22:59 +00:00
|
|
|
@mock_iam
|
2017-09-26 16:37:26 +00:00
|
|
|
@mock_batch
|
2017-09-29 22:29:36 +00:00
|
|
|
def test_create_managed_compute_environment():
|
|
|
|
ec2_client, iam_client, ecs_client, batch_client = _get_clients()
|
2017-09-26 21:22:59 +00:00
|
|
|
vpc_id, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = 'test_compute_env'
|
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type='MANAGED',
|
|
|
|
state='ENABLED',
|
|
|
|
computeResources={
|
|
|
|
'type': 'EC2',
|
2017-09-29 22:29:36 +00:00
|
|
|
'minvCpus': 5,
|
|
|
|
'maxvCpus': 10,
|
|
|
|
'desiredvCpus': 5,
|
2017-09-26 21:22:59 +00:00
|
|
|
'instanceTypes': [
|
2017-09-29 22:29:36 +00:00
|
|
|
't2.small',
|
|
|
|
't2.medium'
|
2017-09-26 21:22:59 +00:00
|
|
|
],
|
|
|
|
'imageId': 'some_image_id',
|
|
|
|
'subnets': [
|
|
|
|
subnet_id,
|
|
|
|
],
|
|
|
|
'securityGroupIds': [
|
|
|
|
sg_id,
|
|
|
|
],
|
|
|
|
'ec2KeyPair': 'string',
|
|
|
|
'instanceRole': iam_arn,
|
|
|
|
'tags': {
|
|
|
|
'string': 'string'
|
|
|
|
},
|
|
|
|
'bidPercentage': 123,
|
|
|
|
'spotIamFleetRole': 'string'
|
|
|
|
},
|
|
|
|
serviceRole=iam_arn
|
|
|
|
)
|
|
|
|
resp.should.contain('computeEnvironmentArn')
|
|
|
|
resp['computeEnvironmentName'].should.equal(compute_name)
|
|
|
|
|
2017-09-29 22:29:36 +00:00
|
|
|
# Given a t2.medium is 2 vcpu and t2.small is 1, therefore 2 mediums and 1 small should be created
|
|
|
|
resp = ec2_client.describe_instances()
|
|
|
|
resp.should.contain('Reservations')
|
|
|
|
len(resp['Reservations']).should.equal(3)
|
|
|
|
|
|
|
|
# Should have created 1 ECS cluster
|
|
|
|
resp = ecs_client.list_clusters()
|
|
|
|
resp.should.contain('clusterArns')
|
|
|
|
len(resp['clusterArns']).should.equal(1)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_unmanaged_compute_environment():
|
|
|
|
ec2_client, iam_client, ecs_client, batch_client = _get_clients()
|
|
|
|
vpc_id, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = 'test_compute_env'
|
|
|
|
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)
|
|
|
|
|
|
|
|
# Its unmanaged so no instances should be created
|
|
|
|
resp = ec2_client.describe_instances()
|
|
|
|
resp.should.contain('Reservations')
|
|
|
|
len(resp['Reservations']).should.equal(0)
|
|
|
|
|
|
|
|
# Should have created 1 ECS cluster
|
|
|
|
resp = ecs_client.list_clusters()
|
|
|
|
resp.should.contain('clusterArns')
|
|
|
|
len(resp['clusterArns']).should.equal(1)
|
|
|
|
|
2017-09-26 21:22:59 +00:00
|
|
|
# TODO create 1000s of tests to test complex option combinations of create environment
|
2017-09-29 22:29:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_describe_compute_environment():
|
|
|
|
ec2_client, iam_client, ecs_client, batch_client = _get_clients()
|
|
|
|
vpc_id, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = 'test_compute_env'
|
|
|
|
batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type='UNMANAGED',
|
|
|
|
state='ENABLED',
|
|
|
|
serviceRole=iam_arn
|
|
|
|
)
|
|
|
|
|
|
|
|
resp = batch_client.describe_compute_environments()
|
|
|
|
len(resp['computeEnvironments']).should.equal(1)
|
|
|
|
resp['computeEnvironments'][0]['computeEnvironmentName'].should.equal(compute_name)
|
|
|
|
|
|
|
|
# Test filtering
|
|
|
|
resp = batch_client.describe_compute_environments(
|
|
|
|
computeEnvironments=['test1']
|
|
|
|
)
|
|
|
|
len(resp['computeEnvironments']).should.equal(0)
|
|
|
|
|
2017-10-03 21:35:30 +00:00
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_delete_unmanaged_compute_environment():
|
|
|
|
ec2_client, iam_client, ecs_client, batch_client = _get_clients()
|
|
|
|
vpc_id, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = 'test_compute_env'
|
|
|
|
batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type='UNMANAGED',
|
|
|
|
state='ENABLED',
|
|
|
|
serviceRole=iam_arn
|
|
|
|
)
|
|
|
|
|
|
|
|
batch_client.delete_compute_environment(
|
|
|
|
computeEnvironment=compute_name,
|
|
|
|
)
|
|
|
|
|
|
|
|
resp = batch_client.describe_compute_environments()
|
|
|
|
len(resp['computeEnvironments']).should.equal(0)
|
|
|
|
|
|
|
|
resp = ecs_client.list_clusters()
|
|
|
|
len(resp.get('clusterArns', [])).should.equal(0)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_delete_managed_compute_environment():
|
|
|
|
ec2_client, iam_client, ecs_client, batch_client = _get_clients()
|
|
|
|
vpc_id, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = 'test_compute_env'
|
|
|
|
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,
|
|
|
|
'tags': {
|
|
|
|
'string': 'string'
|
|
|
|
},
|
|
|
|
'bidPercentage': 123,
|
|
|
|
'spotIamFleetRole': 'string'
|
|
|
|
},
|
|
|
|
serviceRole=iam_arn
|
|
|
|
)
|
|
|
|
|
|
|
|
batch_client.delete_compute_environment(
|
|
|
|
computeEnvironment=compute_name,
|
|
|
|
)
|
|
|
|
|
|
|
|
resp = batch_client.describe_compute_environments()
|
|
|
|
len(resp['computeEnvironments']).should.equal(0)
|
|
|
|
|
|
|
|
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')
|
|
|
|
|
|
|
|
resp = ecs_client.list_clusters()
|
|
|
|
len(resp.get('clusterArns', [])).should.equal(0)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_update_unmanaged_compute_environment_state():
|
|
|
|
ec2_client, iam_client, ecs_client, batch_client = _get_clients()
|
|
|
|
vpc_id, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = 'test_compute_env'
|
|
|
|
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'
|
|
|
|
)
|
|
|
|
|
|
|
|
resp = batch_client.describe_compute_environments()
|
|
|
|
len(resp['computeEnvironments']).should.equal(1)
|
|
|
|
resp['computeEnvironments'][0]['state'].should.equal('DISABLED')
|
2017-10-03 22:21:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_job_queue():
|
|
|
|
ec2_client, iam_client, ecs_client, batch_client = _get_clients()
|
|
|
|
vpc_id, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = 'test_compute_env'
|
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type='UNMANAGED',
|
|
|
|
state='ENABLED',
|
|
|
|
serviceRole=iam_arn
|
|
|
|
)
|
|
|
|
arn = resp['computeEnvironmentArn']
|
|
|
|
|
|
|
|
resp = batch_client.create_job_queue(
|
|
|
|
jobQueueName='test_job_queue',
|
|
|
|
state='ENABLED',
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[
|
|
|
|
{
|
|
|
|
'order': 123,
|
|
|
|
'computeEnvironment': arn
|
|
|
|
},
|
|
|
|
]
|
|
|
|
)
|
|
|
|
resp.should.contain('jobQueueArn')
|
|
|
|
resp.should.contain('jobQueueName')
|
|
|
|
queue_arn = resp['jobQueueArn']
|
|
|
|
|
|
|
|
resp = batch_client.describe_job_queues()
|
|
|
|
resp.should.contain('jobQueues')
|
2017-10-03 22:28:10 +00:00
|
|
|
len(resp['jobQueues']).should.equal(1)
|
2017-10-03 22:21:06 +00:00
|
|
|
resp['jobQueues'][0]['jobQueueArn'].should.equal(queue_arn)
|
|
|
|
|
2017-10-03 22:28:10 +00:00
|
|
|
resp = batch_client.describe_job_queues(jobQueues=['test_invalid_queue'])
|
|
|
|
resp.should.contain('jobQueues')
|
|
|
|
len(resp['jobQueues']).should.equal(0)
|
|
|
|
|
2017-10-03 22:21:06 +00:00
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_job_queue_bad_arn():
|
|
|
|
ec2_client, iam_client, ecs_client, batch_client = _get_clients()
|
|
|
|
vpc_id, subnet_id, sg_id, iam_arn = _setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
compute_name = 'test_compute_env'
|
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type='UNMANAGED',
|
|
|
|
state='ENABLED',
|
|
|
|
serviceRole=iam_arn
|
|
|
|
)
|
|
|
|
arn = resp['computeEnvironmentArn']
|
|
|
|
|
|
|
|
try:
|
|
|
|
batch_client.create_job_queue(
|
|
|
|
jobQueueName='test_job_queue',
|
|
|
|
state='ENABLED',
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[
|
|
|
|
{
|
|
|
|
'order': 123,
|
|
|
|
'computeEnvironment': arn + 'LALALA'
|
|
|
|
},
|
|
|
|
]
|
|
|
|
)
|
|
|
|
except ClientError as err:
|
|
|
|
err.response['Error']['Code'].should.equal('ClientException')
|