Bugfix/mediaconnect create flow include source ingest ip (#5093)

This commit is contained in:
nickphbrown 2022-05-04 11:51:12 +01:00 committed by GitHub
parent eb49891118
commit 600ac8efa5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 68 additions and 19 deletions

View File

@ -78,6 +78,29 @@ class MediaConnectBackend(BaseBackend):
self._flows = OrderedDict()
self._resources = OrderedDict()
def _add_source_details(self, source, flow_id, ingest_ip="127.0.0.1"):
if source:
source["sourceArn"] = (
f"arn:aws:mediaconnect:{self.region_name}:{ACCOUNT_ID}:source"
f":{flow_id}:{source['name']}"
)
if not source.get("entitlementArn"):
source["ingestIp"] = ingest_ip
def _create_flow_add_details(self, flow):
flow_id = uuid4().hex
flow.description = "A Moto test flow"
flow.egress_ip = "127.0.0.1"
flow.flow_arn = f"arn:aws:mediaconnect:{self.region_name}:{ACCOUNT_ID}:flow:{flow_id}:{flow.name}"
for index, _source in enumerate(flow.sources):
self._add_source_details(_source, flow_id, f"127.0.0.{index}")
for index, output in enumerate(flow.outputs):
if output.get("protocol") in ["srt-listener", "zixi-pull"]:
output["listenerAddress"] = f"{index}.0.0.0"
def reset(self):
region_name = self.region_name
self.__dict__ = {}
@ -94,12 +117,6 @@ class MediaConnectBackend(BaseBackend):
sources,
vpc_interfaces,
):
flow_id = uuid4().hex
source_name = source.get("name")
if isinstance(source, dict) and source_name:
source[
"sourceArn"
] = f"arn:aws:mediaconnect:{self.region_name}:{ACCOUNT_ID}:source:{flow_id}:{source_name}"
flow = Flow(
availability_zone=availability_zone,
entitlements=entitlements,
@ -110,9 +127,7 @@ class MediaConnectBackend(BaseBackend):
sources=sources,
vpc_interfaces=vpc_interfaces,
)
flow.description = "A Moto test flow"
flow.egress_ip = "127.0.0.1"
flow.flow_arn = f"arn:aws:mediaconnect:{self.region_name}:{ACCOUNT_ID}:flow:{flow_id}:{name}"
self._create_flow_add_details(flow)
self._flows[flow.flow_arn] = flow
return flow

View File

@ -18,9 +18,6 @@ class MediaConnectResponse(BaseResponse):
entitlements = self._get_param("entitlements")
name = self._get_param("name")
outputs = self._get_param("outputs")
for index, output in enumerate(outputs):
if output.get("protocol") in ["srt-listener", "zixi-pull"]:
output["listenerAddress"] = f"{index}.0.0.0"
source = self._get_param("source")
source_failover_config = self._get_param("sourceFailoverConfig")
sources = self._get_param("sources")

View File

@ -11,6 +11,14 @@ from moto.core import ACCOUNT_ID
region = "eu-west-1"
def _source(name="Source-A"):
return {
"Decryption": {"Algorithm": "aes256", "RoleArn": "some:role"},
"Description": "A source",
"Name": name,
}
def _create_flow_config(name, **kwargs):
availability_zone = kwargs.get("availability_zone", "AZ1")
entitlements = kwargs.get(
@ -36,25 +44,24 @@ def _create_flow_config(name, **kwargs):
)
source = kwargs.get(
"source",
{
"Decryption": {"Algorithm": "aes256", "RoleArn": "some:role"},
"Description": "A source",
"Name": "Source-A",
},
_source(),
)
source_failover_config = kwargs.get("source_failover_config", {})
sources = kwargs.get("sources", [])
vpc_interfaces = kwargs.get("vpc_interfaces", [])
flow_config = dict(
flow_config = dict(Name=name)
optional_flow_config = dict(
AvailabilityZone=availability_zone,
Entitlements=entitlements,
Name=name,
Outputs=outputs,
Source=source,
SourceFailoverConfig=source_failover_config,
Sources=sources,
VpcInterfaces=vpc_interfaces,
)
for key, value in optional_flow_config.items():
if value:
flow_config[key] = value
return flow_config
@ -83,6 +90,36 @@ def test_create_flow_succeeds():
response["Flow"]["Outputs"][0].should.equal({"Name": "Output-1"})
response["Flow"]["Outputs"][1]["ListenerAddress"].should.equal("1.0.0.0")
response["Flow"]["Outputs"][2]["ListenerAddress"].should.equal("2.0.0.0")
response["Flow"]["Source"]["IngestIp"].should.equal("127.0.0.0")
_check_mediaconnect_arn(
type_="source", arn=response["Flow"]["Sources"][0]["SourceArn"], name="Source-A"
)
@mock_mediaconnect
def test_create_flow_alternative_succeeds():
client = boto3.client("mediaconnect", region_name=region)
channel_config = _create_flow_config(
"test-Flow-1",
source=None,
sources=[_source(), _source("Source-B")],
source_failover_config={
"FailoverMode": "FAILOVER",
"SourcePriority": {"PrimarySource": "Source-B"},
"State": "ENABLED",
},
)
response = client.create_flow(**channel_config)
response["ResponseMetadata"]["HTTPStatusCode"].should.equal(200)
_check_mediaconnect_arn(
type_="flow", arn=response["Flow"]["FlowArn"], name="test-Flow-1"
)
response["Flow"]["Name"].should.equal("test-Flow-1")
response["Flow"]["Status"].should.equal("STANDBY")
response["Flow"]["Sources"][0]["IngestIp"].should.equal("127.0.0.0")
response["Flow"]["Sources"][1]["IngestIp"].should.equal("127.0.0.1")
_check_mediaconnect_arn(
type_="source", arn=response["Flow"]["Sources"][0]["SourceArn"], name="Source-A"
)