2021-08-04 12:40:10 +00:00
|
|
|
from . import _get_clients, _setup
|
|
|
|
import random
|
2021-11-01 10:31:22 +00:00
|
|
|
import pytest
|
2021-10-18 19:44:29 +00:00
|
|
|
import sure # noqa # pylint: disable=unused-import
|
2021-08-04 12:40:10 +00:00
|
|
|
from moto import mock_batch, mock_iam, mock_ec2, mock_ecs
|
2021-10-05 17:11:07 +00:00
|
|
|
from uuid import uuid4
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
2021-11-01 10:31:22 +00:00
|
|
|
@pytest.mark.parametrize("use_resource_reqs", [True, False])
|
|
|
|
def test_register_task_definition(use_resource_reqs):
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
2021-08-04 12:40:10 +00:00
|
|
|
_setup(ec2_client, iam_client)
|
|
|
|
|
2021-11-01 10:31:22 +00:00
|
|
|
resp = register_job_def(batch_client, use_resource_reqs=use_resource_reqs)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
resp.should.contain("jobDefinitionArn")
|
|
|
|
resp.should.contain("jobDefinitionName")
|
|
|
|
resp.should.contain("revision")
|
|
|
|
|
|
|
|
assert resp["jobDefinitionArn"].endswith(
|
|
|
|
"{0}:{1}".format(resp["jobDefinitionName"], resp["revision"])
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2021-09-21 16:12:18 +00:00
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_register_task_definition_with_tags():
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
2021-09-21 16:12:18 +00:00
|
|
|
_setup(ec2_client, iam_client)
|
|
|
|
|
|
|
|
resp = register_job_def_with_tags(batch_client)
|
|
|
|
|
|
|
|
resp.should.contain("jobDefinitionArn")
|
|
|
|
resp.should.contain("jobDefinitionName")
|
|
|
|
resp.should.contain("revision")
|
|
|
|
|
|
|
|
assert resp["jobDefinitionArn"].endswith(
|
|
|
|
"{0}:{1}".format(resp["jobDefinitionName"], resp["revision"])
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2021-08-04 12:40:10 +00:00
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
2021-11-01 10:31:22 +00:00
|
|
|
@pytest.mark.parametrize("use_resource_reqs", [True, False])
|
|
|
|
def test_reregister_task_definition(use_resource_reqs):
|
2021-08-04 12:40:10 +00:00
|
|
|
# Reregistering task with the same name bumps the revision number
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
2021-08-04 12:40:10 +00:00
|
|
|
_setup(ec2_client, iam_client)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
job_def_name = str(uuid4())[0:6]
|
2021-11-01 10:31:22 +00:00
|
|
|
resp1 = register_job_def(
|
|
|
|
batch_client, definition_name=job_def_name, use_resource_reqs=use_resource_reqs
|
|
|
|
)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
resp1.should.contain("jobDefinitionArn")
|
2021-10-05 17:11:07 +00:00
|
|
|
resp1.should.have.key("jobDefinitionName").equals(job_def_name)
|
2021-08-04 12:40:10 +00:00
|
|
|
resp1.should.contain("revision")
|
|
|
|
|
|
|
|
assert resp1["jobDefinitionArn"].endswith(
|
|
|
|
"{0}:{1}".format(resp1["jobDefinitionName"], resp1["revision"])
|
|
|
|
)
|
|
|
|
resp1["revision"].should.equal(1)
|
|
|
|
|
2021-11-01 10:31:22 +00:00
|
|
|
resp2 = register_job_def(
|
|
|
|
batch_client, definition_name=job_def_name, use_resource_reqs=use_resource_reqs
|
|
|
|
)
|
2021-08-04 12:40:10 +00:00
|
|
|
resp2["revision"].should.equal(2)
|
|
|
|
|
|
|
|
resp2["jobDefinitionArn"].should_not.equal(resp1["jobDefinitionArn"])
|
|
|
|
|
2021-11-01 10:31:22 +00:00
|
|
|
resp3 = register_job_def(
|
|
|
|
batch_client, definition_name=job_def_name, use_resource_reqs=use_resource_reqs
|
|
|
|
)
|
2021-08-04 12:40:10 +00:00
|
|
|
resp3["revision"].should.equal(3)
|
|
|
|
|
|
|
|
resp3["jobDefinitionArn"].should_not.equal(resp1["jobDefinitionArn"])
|
|
|
|
resp3["jobDefinitionArn"].should_not.equal(resp2["jobDefinitionArn"])
|
|
|
|
|
2021-11-01 10:31:22 +00:00
|
|
|
resp4 = register_job_def(
|
|
|
|
batch_client, definition_name=job_def_name, use_resource_reqs=use_resource_reqs
|
|
|
|
)
|
2021-08-04 12:40:10 +00:00
|
|
|
resp4["revision"].should.equal(4)
|
|
|
|
|
|
|
|
resp4["jobDefinitionArn"].should_not.equal(resp1["jobDefinitionArn"])
|
|
|
|
resp4["jobDefinitionArn"].should_not.equal(resp2["jobDefinitionArn"])
|
|
|
|
resp4["jobDefinitionArn"].should_not.equal(resp3["jobDefinitionArn"])
|
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
2021-11-01 10:31:22 +00:00
|
|
|
@pytest.mark.parametrize("use_resource_reqs", [True, False])
|
|
|
|
def test_delete_task_definition(use_resource_reqs):
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
2021-08-04 12:40:10 +00:00
|
|
|
_setup(ec2_client, iam_client)
|
|
|
|
|
2021-11-01 10:31:22 +00:00
|
|
|
resp = register_job_def(
|
|
|
|
batch_client, definition_name=str(uuid4()), use_resource_reqs=use_resource_reqs
|
|
|
|
)
|
2021-10-05 17:11:07 +00:00
|
|
|
name = resp["jobDefinitionName"]
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
batch_client.deregister_job_definition(jobDefinition=resp["jobDefinitionArn"])
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_defs = batch_client.describe_job_definitions()["jobDefinitions"]
|
|
|
|
[jobdef["jobDefinitionName"] for jobdef in all_defs].shouldnt.contain(name)
|
2021-09-27 17:19:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
2021-11-01 10:31:22 +00:00
|
|
|
@pytest.mark.parametrize("use_resource_reqs", [True, False])
|
|
|
|
def test_delete_task_definition_by_name(use_resource_reqs):
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
2021-09-27 17:19:44 +00:00
|
|
|
_setup(ec2_client, iam_client)
|
|
|
|
|
2021-11-01 10:31:22 +00:00
|
|
|
resp = register_job_def(
|
|
|
|
batch_client, definition_name=str(uuid4()), use_resource_reqs=use_resource_reqs
|
|
|
|
)
|
2021-10-05 17:11:07 +00:00
|
|
|
name = resp["jobDefinitionName"]
|
2021-09-27 17:19:44 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
batch_client.deregister_job_definition(jobDefinition=f"{name}:{resp['revision']}")
|
2021-09-27 17:19:44 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_defs = batch_client.describe_job_definitions()["jobDefinitions"]
|
|
|
|
[jobdef["jobDefinitionName"] for jobdef in all_defs].shouldnt.contain(name)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
2021-11-01 10:31:22 +00:00
|
|
|
@pytest.mark.parametrize("use_resource_reqs", [True, False])
|
|
|
|
def test_describe_task_definition(use_resource_reqs):
|
2021-10-18 19:44:29 +00:00
|
|
|
ec2_client, iam_client, _, _, batch_client = _get_clients()
|
2021-08-04 12:40:10 +00:00
|
|
|
_setup(ec2_client, iam_client)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
sleep_def_name = f"sleep10_{str(uuid4())[0:6]}"
|
|
|
|
other_name = str(uuid4())[0:6]
|
|
|
|
tagged_name = str(uuid4())[0:6]
|
2021-11-01 10:31:22 +00:00
|
|
|
register_job_def(
|
|
|
|
batch_client,
|
|
|
|
definition_name=sleep_def_name,
|
|
|
|
use_resource_reqs=use_resource_reqs,
|
|
|
|
)
|
|
|
|
register_job_def(
|
|
|
|
batch_client,
|
|
|
|
definition_name=sleep_def_name,
|
|
|
|
use_resource_reqs=use_resource_reqs,
|
|
|
|
)
|
|
|
|
register_job_def(
|
|
|
|
batch_client, definition_name=other_name, use_resource_reqs=use_resource_reqs
|
|
|
|
)
|
2021-10-05 17:11:07 +00:00
|
|
|
register_job_def_with_tags(batch_client, definition_name=tagged_name)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
resp = batch_client.describe_job_definitions(jobDefinitionName=sleep_def_name)
|
2021-08-04 12:40:10 +00:00
|
|
|
len(resp["jobDefinitions"]).should.equal(2)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
job_defs = batch_client.describe_job_definitions()["jobDefinitions"]
|
|
|
|
all_names = [jd["jobDefinitionName"] for jd in job_defs]
|
|
|
|
all_names.should.contain(sleep_def_name)
|
|
|
|
all_names.should.contain(other_name)
|
|
|
|
all_names.should.contain(tagged_name)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
resp = batch_client.describe_job_definitions(
|
|
|
|
jobDefinitions=[sleep_def_name, other_name]
|
|
|
|
)
|
2021-08-04 12:40:10 +00:00
|
|
|
len(resp["jobDefinitions"]).should.equal(3)
|
2021-09-21 16:12:18 +00:00
|
|
|
resp["jobDefinitions"][0]["tags"].should.equal({})
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
resp = batch_client.describe_job_definitions(jobDefinitionName=tagged_name)
|
2021-09-21 16:12:18 +00:00
|
|
|
resp["jobDefinitions"][0]["tags"].should.equal(
|
|
|
|
{"foo": "123", "bar": "456",}
|
|
|
|
)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
for job_definition in resp["jobDefinitions"]:
|
|
|
|
job_definition["status"].should.equal("ACTIVE")
|
|
|
|
|
|
|
|
|
2021-11-01 10:31:22 +00:00
|
|
|
def register_job_def(batch_client, definition_name="sleep10", use_resource_reqs=True):
|
|
|
|
container_properties = {
|
|
|
|
"image": "busybox",
|
|
|
|
"command": ["sleep", "10"],
|
|
|
|
}
|
|
|
|
|
|
|
|
if use_resource_reqs:
|
|
|
|
container_properties.update(
|
|
|
|
{
|
|
|
|
"resourceRequirements": [
|
2022-01-29 12:07:10 +00:00
|
|
|
{"value": "0.25", "type": "VCPU"},
|
|
|
|
{"value": "512", "type": "MEMORY"},
|
2021-11-01 10:31:22 +00:00
|
|
|
]
|
|
|
|
}
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
container_properties.update(
|
2022-01-29 12:07:10 +00:00
|
|
|
{"memory": 128, "vcpus": 1,}
|
2021-11-01 10:31:22 +00:00
|
|
|
)
|
|
|
|
|
2021-08-04 12:40:10 +00:00
|
|
|
return batch_client.register_job_definition(
|
|
|
|
jobDefinitionName=definition_name,
|
|
|
|
type="container",
|
2022-01-29 12:07:10 +00:00
|
|
|
containerProperties=container_properties,
|
2021-08-04 12:40:10 +00:00
|
|
|
)
|
2021-09-21 16:12:18 +00:00
|
|
|
|
|
|
|
|
|
|
|
def register_job_def_with_tags(batch_client, definition_name="sleep10"):
|
|
|
|
return batch_client.register_job_definition(
|
|
|
|
jobDefinitionName=definition_name,
|
|
|
|
type="container",
|
|
|
|
containerProperties={
|
|
|
|
"image": "busybox",
|
|
|
|
"vcpus": 1,
|
|
|
|
"memory": random.randint(4, 128),
|
|
|
|
"command": ["sleep", "10"],
|
|
|
|
},
|
|
|
|
tags={"foo": "123", "bar": "456",},
|
|
|
|
)
|