2022-09-08 21:51:55 +00:00
|
|
|
import boto3
|
|
|
|
import pytest
|
|
|
|
from botocore.exceptions import ClientError
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
from moto import mock_aws
|
2022-09-08 21:51:55 +00:00
|
|
|
|
2023-04-24 19:11:36 +00:00
|
|
|
ONE_MB = 2**20
|
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2022-09-08 21:51:55 +00:00
|
|
|
def test_record_data_exceeds_1mb():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
client.create_stream(StreamName="my_stream", ShardCount=1)
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
client.put_records(
|
2023-04-24 19:11:36 +00:00
|
|
|
Records=[{"Data": b"a" * (ONE_MB + 1), "PartitionKey": "key"}],
|
|
|
|
StreamName="my_stream",
|
|
|
|
)
|
|
|
|
err = exc.value.response["Error"]
|
2023-08-01 09:47:40 +00:00
|
|
|
assert err["Code"] == "ValidationException"
|
|
|
|
assert (
|
|
|
|
err["Message"]
|
|
|
|
== "1 validation error detected: Value at 'records.1.member.data' failed to satisfy constraint: Member must have length less than or equal to 1048576"
|
2023-04-24 19:11:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2023-04-24 19:11:36 +00:00
|
|
|
def test_record_data_and_partition_key_exceeds_1mb():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
client.create_stream(StreamName="my_stream", ShardCount=1)
|
|
|
|
|
|
|
|
key = "key"
|
|
|
|
key_size = len(key)
|
|
|
|
data_size = ONE_MB - key_size + 1
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
client.put_records(
|
|
|
|
Records=[{"Data": b"a" * data_size, "PartitionKey": key}],
|
2022-09-08 21:51:55 +00:00
|
|
|
StreamName="my_stream",
|
|
|
|
)
|
|
|
|
err = exc.value.response["Error"]
|
2023-08-01 09:47:40 +00:00
|
|
|
assert err["Code"] == "ValidationException"
|
|
|
|
assert (
|
|
|
|
err["Message"]
|
|
|
|
== "1 validation error detected: Value at 'records.1.member.data' failed to satisfy constraint: Member must have length less than or equal to 1048576"
|
2022-09-08 21:51:55 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2023-04-24 19:11:36 +00:00
|
|
|
def test_record_data_and_partition_key_exactly_1mb():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
client.create_stream(StreamName="my_stream", ShardCount=1)
|
|
|
|
|
|
|
|
key = "key"
|
|
|
|
key_size = len(key)
|
|
|
|
data_size = ONE_MB - key_size
|
|
|
|
|
|
|
|
client.put_records(
|
|
|
|
Records=[{"Data": b"a" * data_size, "PartitionKey": key}],
|
|
|
|
StreamName="my_stream",
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2023-04-24 19:11:36 +00:00
|
|
|
def test_record_data_and_partition_key_smaller_than_1mb():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
client.create_stream(StreamName="my_stream", ShardCount=1)
|
|
|
|
|
|
|
|
key = "key"
|
|
|
|
key_size = len(key)
|
|
|
|
data_size = ONE_MB - key_size - 1
|
|
|
|
client.put_records(
|
|
|
|
Records=[{"Data": b"a" * data_size, "PartitionKey": key}],
|
|
|
|
StreamName="my_stream",
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2022-09-08 21:51:55 +00:00
|
|
|
def test_total_record_data_exceeds_5mb():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
client.create_stream(StreamName="my_stream", ShardCount=1)
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
client.put_records(
|
|
|
|
Records=[{"Data": b"a" * 2**20, "PartitionKey": "key"}] * 5,
|
|
|
|
StreamName="my_stream",
|
|
|
|
)
|
|
|
|
err = exc.value.response["Error"]
|
2023-08-01 09:47:40 +00:00
|
|
|
assert err["Code"] == "InvalidArgumentException"
|
|
|
|
assert err["Message"] == "Records size exceeds 5 MB limit"
|
2022-09-08 21:51:55 +00:00
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2023-04-24 19:11:36 +00:00
|
|
|
def test_total_record_data_exact_5mb():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
client.create_stream(StreamName="my_stream", ShardCount=1)
|
|
|
|
key = "key"
|
|
|
|
key_size = len(key)
|
|
|
|
data_size = ONE_MB - key_size
|
|
|
|
client.put_records(
|
|
|
|
Records=[{"Data": b"a" * (data_size), "PartitionKey": key}] * 5,
|
|
|
|
StreamName="my_stream",
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2022-09-08 21:51:55 +00:00
|
|
|
def test_too_many_records():
|
|
|
|
client = boto3.client("kinesis", region_name="us-east-1")
|
|
|
|
client.create_stream(StreamName="my_stream", ShardCount=1)
|
2023-04-24 19:11:36 +00:00
|
|
|
|
2022-09-08 21:51:55 +00:00
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
client.put_records(
|
|
|
|
Records=[{"Data": b"a", "PartitionKey": "key"}] * 501,
|
|
|
|
StreamName="my_stream",
|
|
|
|
)
|
|
|
|
err = exc.value.response["Error"]
|
2023-08-01 09:47:40 +00:00
|
|
|
assert err["Code"] == "ValidationException"
|
|
|
|
assert (
|
|
|
|
err["Message"]
|
|
|
|
== "1 validation error detected: Value at 'records' failed to satisfy constraint: Member must have length less than or equal to 500"
|
2022-09-08 21:51:55 +00:00
|
|
|
)
|