2022-01-26 19:41:04 +00:00
|
|
|
import boto3
|
|
|
|
|
|
|
|
from moto import mock_kinesis
|
2023-02-01 16:16:25 +00:00
|
|
|
from tests import DEFAULT_ACCOUNT_ID
|
2023-11-30 15:55:51 +00:00
|
|
|
|
2023-02-01 16:16:25 +00:00
|
|
|
from .test_kinesis import get_stream_arn
|
2022-01-26 19:41:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_kinesis
|
|
|
|
def test_enable_enhanced_monitoring_all():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
stream_name = "my_stream_summary"
|
|
|
|
client.create_stream(StreamName=stream_name, ShardCount=4)
|
|
|
|
|
|
|
|
resp = client.enable_enhanced_monitoring(
|
|
|
|
StreamName=stream_name, ShardLevelMetrics=["ALL"]
|
|
|
|
)
|
|
|
|
|
2023-08-01 09:47:40 +00:00
|
|
|
assert resp["StreamName"] == stream_name
|
|
|
|
assert resp["CurrentShardLevelMetrics"] == []
|
|
|
|
assert resp["DesiredShardLevelMetrics"] == ["ALL"]
|
|
|
|
assert (
|
|
|
|
resp["StreamARN"]
|
|
|
|
== f"arn:aws:kinesis:us-east-1:{DEFAULT_ACCOUNT_ID}:stream/{stream_name}"
|
2023-02-01 16:16:25 +00:00
|
|
|
)
|
2022-01-26 19:41:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_kinesis
|
|
|
|
def test_enable_enhanced_monitoring_is_persisted():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
stream_name = "my_stream_summary"
|
|
|
|
client.create_stream(StreamName=stream_name, ShardCount=4)
|
|
|
|
|
|
|
|
client.enable_enhanced_monitoring(
|
|
|
|
StreamName=stream_name, ShardLevelMetrics=["IncomingBytes", "OutgoingBytes"]
|
|
|
|
)
|
|
|
|
|
|
|
|
stream = client.describe_stream(StreamName=stream_name)["StreamDescription"]
|
|
|
|
metrics = stream["EnhancedMonitoring"][0]["ShardLevelMetrics"]
|
2023-08-01 09:47:40 +00:00
|
|
|
assert set(metrics) == {"IncomingBytes", "OutgoingBytes"}
|
2022-01-26 19:41:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_kinesis
|
|
|
|
def test_enable_enhanced_monitoring_in_steps():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
stream_name = "my_stream_summary"
|
|
|
|
client.create_stream(StreamName=stream_name, ShardCount=4)
|
|
|
|
|
|
|
|
client.enable_enhanced_monitoring(
|
|
|
|
StreamName=stream_name, ShardLevelMetrics=["IncomingBytes", "OutgoingBytes"]
|
|
|
|
)
|
|
|
|
|
|
|
|
resp = client.enable_enhanced_monitoring(
|
|
|
|
StreamName=stream_name, ShardLevelMetrics=["WriteProvisionedThroughputExceeded"]
|
|
|
|
)
|
|
|
|
|
2023-08-01 09:47:40 +00:00
|
|
|
assert len(resp["CurrentShardLevelMetrics"]) == 2
|
|
|
|
assert "IncomingBytes" in resp["CurrentShardLevelMetrics"]
|
|
|
|
assert "OutgoingBytes" in resp["CurrentShardLevelMetrics"]
|
|
|
|
assert len(resp["DesiredShardLevelMetrics"]) == 3
|
|
|
|
assert "IncomingBytes" in resp["DesiredShardLevelMetrics"]
|
|
|
|
assert "OutgoingBytes" in resp["DesiredShardLevelMetrics"]
|
|
|
|
assert "WriteProvisionedThroughputExceeded" in resp["DesiredShardLevelMetrics"]
|
2022-01-26 19:41:04 +00:00
|
|
|
|
|
|
|
stream = client.describe_stream(StreamName=stream_name)["StreamDescription"]
|
|
|
|
metrics = stream["EnhancedMonitoring"][0]["ShardLevelMetrics"]
|
2023-08-01 09:47:40 +00:00
|
|
|
assert len(metrics) == 3
|
|
|
|
assert "IncomingBytes" in metrics
|
|
|
|
assert "OutgoingBytes" in metrics
|
|
|
|
assert "WriteProvisionedThroughputExceeded" in metrics
|
2022-01-26 19:41:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_kinesis
|
|
|
|
def test_disable_enhanced_monitoring():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
stream_name = "my_stream_summary"
|
|
|
|
client.create_stream(StreamName=stream_name, ShardCount=4)
|
2023-02-01 16:16:25 +00:00
|
|
|
stream_arn = get_stream_arn(client, stream_name)
|
2022-01-26 19:41:04 +00:00
|
|
|
|
|
|
|
client.enable_enhanced_monitoring(
|
2023-02-01 16:16:25 +00:00
|
|
|
StreamARN=stream_arn,
|
2022-01-26 19:41:04 +00:00
|
|
|
ShardLevelMetrics=[
|
|
|
|
"IncomingBytes",
|
|
|
|
"OutgoingBytes",
|
|
|
|
"WriteProvisionedThroughputExceeded",
|
|
|
|
],
|
|
|
|
)
|
|
|
|
|
|
|
|
resp = client.disable_enhanced_monitoring(
|
|
|
|
StreamName=stream_name, ShardLevelMetrics=["OutgoingBytes"]
|
|
|
|
)
|
|
|
|
|
2023-08-01 09:47:40 +00:00
|
|
|
assert resp["StreamName"] == stream_name
|
|
|
|
assert (
|
|
|
|
resp["StreamARN"]
|
|
|
|
== f"arn:aws:kinesis:us-east-1:{DEFAULT_ACCOUNT_ID}:stream/{stream_name}"
|
2023-02-01 16:16:25 +00:00
|
|
|
)
|
|
|
|
|
2023-08-01 09:47:40 +00:00
|
|
|
assert len(resp["CurrentShardLevelMetrics"]) == 3
|
|
|
|
assert "IncomingBytes" in resp["CurrentShardLevelMetrics"]
|
|
|
|
assert "OutgoingBytes" in resp["CurrentShardLevelMetrics"]
|
|
|
|
assert "WriteProvisionedThroughputExceeded" in resp["CurrentShardLevelMetrics"]
|
|
|
|
assert len(resp["DesiredShardLevelMetrics"]) == 2
|
|
|
|
assert "IncomingBytes" in resp["DesiredShardLevelMetrics"]
|
|
|
|
assert "WriteProvisionedThroughputExceeded" in resp["DesiredShardLevelMetrics"]
|
2022-01-26 19:41:04 +00:00
|
|
|
|
|
|
|
stream = client.describe_stream(StreamName=stream_name)["StreamDescription"]
|
|
|
|
metrics = stream["EnhancedMonitoring"][0]["ShardLevelMetrics"]
|
2023-08-01 09:47:40 +00:00
|
|
|
assert len(metrics) == 2
|
|
|
|
assert "IncomingBytes" in metrics
|
|
|
|
assert "WriteProvisionedThroughputExceeded" in metrics
|
2022-01-26 19:41:04 +00:00
|
|
|
|
2023-02-01 16:16:25 +00:00
|
|
|
resp = client.disable_enhanced_monitoring(
|
|
|
|
StreamARN=stream_arn, ShardLevelMetrics=["IncomingBytes"]
|
|
|
|
)
|
|
|
|
|
2023-08-01 09:47:40 +00:00
|
|
|
assert len(resp["CurrentShardLevelMetrics"]) == 2
|
|
|
|
assert len(resp["DesiredShardLevelMetrics"]) == 1
|
2023-02-01 16:16:25 +00:00
|
|
|
|
2022-01-26 19:41:04 +00:00
|
|
|
|
|
|
|
@mock_kinesis
|
|
|
|
def test_disable_enhanced_monitoring_all():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
stream_name = "my_stream_summary"
|
|
|
|
client.create_stream(StreamName=stream_name, ShardCount=4)
|
|
|
|
|
|
|
|
client.enable_enhanced_monitoring(
|
|
|
|
StreamName=stream_name,
|
|
|
|
ShardLevelMetrics=[
|
|
|
|
"IncomingBytes",
|
|
|
|
"OutgoingBytes",
|
|
|
|
"WriteProvisionedThroughputExceeded",
|
|
|
|
],
|
|
|
|
)
|
|
|
|
|
|
|
|
client.disable_enhanced_monitoring(
|
|
|
|
StreamName=stream_name, ShardLevelMetrics=["ALL"]
|
|
|
|
)
|
|
|
|
|
|
|
|
stream = client.describe_stream(StreamName=stream_name)["StreamDescription"]
|
|
|
|
metrics = stream["EnhancedMonitoring"][0]["ShardLevelMetrics"]
|
2023-08-01 09:47:40 +00:00
|
|
|
assert metrics == []
|