2023-11-30 15:55:51 +00:00
|
|
|
from uuid import uuid4
|
|
|
|
|
2023-06-16 10:42:07 +00:00
|
|
|
import boto3
|
2021-08-04 12:40:10 +00:00
|
|
|
import pytest
|
2023-06-16 10:42:07 +00:00
|
|
|
from botocore.exceptions import ClientError
|
2023-11-30 15:55:51 +00:00
|
|
|
|
|
|
|
from moto import mock_batch, mock_ec2, mock_ecs, mock_iam
|
|
|
|
|
|
|
|
from . import _get_clients, _setup
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_job_queue():
|
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
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
arn = resp["computeEnvironmentArn"]
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
jq_name = str(uuid4())[0:6]
|
2021-08-04 12:40:10 +00:00
|
|
|
resp = batch_client.create_job_queue(
|
2021-10-05 17:11:07 +00:00
|
|
|
jobQueueName=jq_name,
|
2021-08-04 12:40:10 +00:00
|
|
|
state="ENABLED",
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[{"order": 123, "computeEnvironment": arn}],
|
2023-01-26 15:06:50 +00:00
|
|
|
schedulingPolicyArn="policy_arn",
|
2021-08-04 12:40:10 +00:00
|
|
|
)
|
2023-06-16 10:42:07 +00:00
|
|
|
assert "jobQueueArn" in resp
|
|
|
|
assert "jobQueueName" in resp
|
2021-08-04 12:40:10 +00:00
|
|
|
queue_arn = resp["jobQueueArn"]
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_queues = batch_client.describe_job_queues()["jobQueues"]
|
|
|
|
our_queues = [q for q in all_queues if q["jobQueueName"] == jq_name]
|
2023-06-16 10:42:07 +00:00
|
|
|
assert len(our_queues) == 1
|
|
|
|
assert our_queues[0]["jobQueueArn"] == queue_arn
|
|
|
|
assert our_queues[0]["schedulingPolicyArn"] == "policy_arn"
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_batch
|
|
|
|
def test_describe_job_queue_unknown_value():
|
2023-06-16 10:42:07 +00:00
|
|
|
batch_client = boto3.client("batch", "us-east-1")
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
resp = batch_client.describe_job_queues(jobQueues=["test_invalid_queue"])
|
2023-06-16 10:42:07 +00:00
|
|
|
assert len(resp["jobQueues"]) == 0
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_job_queue_twice():
|
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
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
compute_env_arn = resp["computeEnvironmentArn"]
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
jq_name = str(uuid4())[0:6]
|
2021-08-04 12:40:10 +00:00
|
|
|
batch_client.create_job_queue(
|
2021-10-05 17:11:07 +00:00
|
|
|
jobQueueName=jq_name,
|
2021-08-04 12:40:10 +00:00
|
|
|
state="ENABLED",
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[{"order": 123, "computeEnvironment": compute_env_arn}],
|
|
|
|
)
|
|
|
|
with pytest.raises(ClientError) as ex:
|
|
|
|
batch_client.create_job_queue(
|
2021-10-05 17:11:07 +00:00
|
|
|
jobQueueName=jq_name,
|
2021-08-04 12:40:10 +00:00
|
|
|
state="ENABLED",
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[
|
|
|
|
{"order": 123, "computeEnvironment": compute_env_arn}
|
|
|
|
],
|
|
|
|
)
|
|
|
|
|
|
|
|
err = ex.value.response["Error"]
|
2023-06-16 10:42:07 +00:00
|
|
|
assert err["Code"] == "ClientException"
|
|
|
|
assert err["Message"] == f"Job queue {jq_name} already exists"
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_job_queue_incorrect_state():
|
2021-10-18 19:44:29 +00:00
|
|
|
_, _, _, _, batch_client = _get_clients()
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
with pytest.raises(ClientError) as ex:
|
|
|
|
batch_client.create_job_queue(
|
2021-10-05 17:11:07 +00:00
|
|
|
jobQueueName=str(uuid4()),
|
2021-08-04 12:40:10 +00:00
|
|
|
state="JUNK",
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[],
|
|
|
|
)
|
|
|
|
err = ex.value.response["Error"]
|
2023-06-16 10:42:07 +00:00
|
|
|
assert err["Code"] == "ClientException"
|
|
|
|
assert err["Message"] == "state JUNK must be one of ENABLED | DISABLED"
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_create_job_queue_without_compute_environment():
|
2021-10-18 19:44:29 +00:00
|
|
|
_, _, _, _, batch_client = _get_clients()
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
with pytest.raises(ClientError) as ex:
|
|
|
|
batch_client.create_job_queue(
|
2021-10-05 17:11:07 +00:00
|
|
|
jobQueueName=str(uuid4()),
|
2021-08-04 12:40:10 +00:00
|
|
|
state="ENABLED",
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[],
|
|
|
|
)
|
|
|
|
err = ex.value.response["Error"]
|
2023-06-16 10:42:07 +00:00
|
|
|
assert err["Code"] == "ClientException"
|
|
|
|
assert err["Message"] == "At least 1 compute environment must be provided"
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_job_queue_bad_arn():
|
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
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
arn = resp["computeEnvironmentArn"]
|
|
|
|
|
|
|
|
with pytest.raises(ClientError) as ex:
|
|
|
|
batch_client.create_job_queue(
|
2021-10-05 17:11:07 +00:00
|
|
|
jobQueueName=str(uuid4()),
|
2021-08-04 12:40:10 +00:00
|
|
|
state="ENABLED",
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[
|
|
|
|
{"order": 123, "computeEnvironment": arn + "LALALA"}
|
|
|
|
],
|
|
|
|
)
|
|
|
|
err = ex.value.response["Error"]
|
2023-06-16 10:42:07 +00:00
|
|
|
assert err["Code"] == "ClientException"
|
|
|
|
assert err["Message"] == "computeEnvironmentOrder is malformed"
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_update_job_queue():
|
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
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
arn = resp["computeEnvironmentArn"]
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
jq_name = str(uuid4())
|
2021-08-04 12:40:10 +00:00
|
|
|
resp = batch_client.create_job_queue(
|
2021-10-05 17:11:07 +00:00
|
|
|
jobQueueName=jq_name,
|
2021-08-04 12:40:10 +00:00
|
|
|
state="ENABLED",
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[{"order": 123, "computeEnvironment": arn}],
|
|
|
|
)
|
|
|
|
queue_arn = resp["jobQueueArn"]
|
|
|
|
|
|
|
|
batch_client.update_job_queue(jobQueue=queue_arn, priority=5)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_queues = batch_client.describe_job_queues()["jobQueues"]
|
|
|
|
our_queues = [q for q in all_queues if q["jobQueueName"] == jq_name]
|
2023-06-16 10:42:07 +00:00
|
|
|
assert our_queues[0]["priority"] == 5
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
batch_client.update_job_queue(jobQueue=jq_name, priority=15)
|
2021-08-04 12:40:10 +00:00
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_queues = batch_client.describe_job_queues()["jobQueues"]
|
|
|
|
our_queues = [q for q in all_queues if q["jobQueueName"] == jq_name]
|
2023-06-16 10:42:07 +00:00
|
|
|
assert len(our_queues) == 1
|
|
|
|
assert our_queues[0]["priority"] == 15
|
2021-08-04 12:40:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
@mock_ecs
|
|
|
|
@mock_iam
|
|
|
|
@mock_batch
|
|
|
|
def test_delete_job_queue():
|
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
|
|
|
resp = batch_client.create_compute_environment(
|
|
|
|
computeEnvironmentName=compute_name,
|
|
|
|
type="UNMANAGED",
|
|
|
|
state="ENABLED",
|
|
|
|
serviceRole=iam_arn,
|
|
|
|
)
|
|
|
|
arn = resp["computeEnvironmentArn"]
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
jq_name = str(uuid4())
|
2021-08-04 12:40:10 +00:00
|
|
|
resp = batch_client.create_job_queue(
|
2021-10-05 17:11:07 +00:00
|
|
|
jobQueueName=jq_name,
|
2021-08-04 12:40:10 +00:00
|
|
|
state="ENABLED",
|
|
|
|
priority=123,
|
|
|
|
computeEnvironmentOrder=[{"order": 123, "computeEnvironment": arn}],
|
|
|
|
)
|
|
|
|
queue_arn = resp["jobQueueArn"]
|
|
|
|
|
|
|
|
batch_client.delete_job_queue(jobQueue=queue_arn)
|
|
|
|
|
2021-10-05 17:11:07 +00:00
|
|
|
all_queues = batch_client.describe_job_queues()["jobQueues"]
|
2023-06-16 10:42:07 +00:00
|
|
|
assert jq_name not in [q["jobQueueName"] for q in all_queues]
|