-
Notifications
You must be signed in to change notification settings - Fork 599
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
rptest
: add delete_retention_ms_test.py
- Loading branch information
1 parent
3cedc2b
commit f737a4d
Showing
1 changed file
with
222 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,222 @@ | ||
from collections import namedtuple | ||
from ducktape.mark import matrix, defaults | ||
from ducktape.utils.util import wait_until | ||
from rptest.clients.rpk import RpkTool, RpkException | ||
from rptest.clients.types import TopicSpec | ||
from rptest.services.cluster import cluster | ||
from rptest.tests.redpanda_test import RedpandaTest | ||
from rptest.util import expect_exception | ||
|
||
|
||
class DeleteRetentionMsTest(RedpandaTest): | ||
def __init__(self, ctx): | ||
self.ctx = ctx | ||
super().__init__(ctx) | ||
|
||
self.rpk = RpkTool(self.redpanda) | ||
|
||
@cluster(num_nodes=1) | ||
def test_get_cluster_config(self): | ||
# Default value | ||
cluster_default = self.rpk.cluster_config_get('tombstone_retention_ms') | ||
assert cluster_default == 'null' | ||
|
||
@cluster(num_nodes=1) | ||
def test_set_cluster_config(self): | ||
self.rpk.cluster_config_set('tombstone_retention_ms', 1234567890) | ||
cluster_prop = self.rpk.cluster_config_get('tombstone_retention_ms') | ||
assert cluster_prop == "1234567890" | ||
|
||
topic_name = "tapioca" | ||
topic = TopicSpec(name=topic_name) | ||
self.rpk.create_topic(topic_name, partitions=1) | ||
topic_desc = self.rpk.describe_topic_configs(topic_name) | ||
assert topic_desc['delete.retention.ms'][0] == '1234567890' | ||
|
||
@cluster(num_nodes=1) | ||
def test_alter_topic_config(self): | ||
topic_name = "tapioca" | ||
topic = TopicSpec(name=topic_name) | ||
self.rpk.create_topic(topic_name, partitions=1) | ||
topic_desc = self.rpk.describe_topic_configs(topic_name) | ||
|
||
# Upon topic construction, this property is actually "disabled" by default. | ||
assert topic_desc['delete.retention.ms'][0] == '-1' | ||
assert topic_desc['delete.retention.ms'][1] == 'DEFAULT_CONFIG' | ||
|
||
# Set value | ||
self.rpk.alter_topic_config(topic_name, 'delete.retention.ms', | ||
1234567890) | ||
|
||
topic_desc = self.rpk.describe_topic_configs(topic_name) | ||
assert topic_desc['delete.retention.ms'][0] == '1234567890' | ||
assert topic_desc['delete.retention.ms'][1] == 'DYNAMIC_TOPIC_CONFIG' | ||
|
||
# Set cluster value and delete topic config | ||
self.rpk.cluster_config_set('tombstone_retention_ms', 100) | ||
self.rpk.delete_topic_config(topic_name, 'delete.retention.ms') | ||
|
||
topic_desc = self.rpk.describe_topic_configs(topic_name) | ||
assert topic_desc['delete.retention.ms'][0] == '100' | ||
assert topic_desc['delete.retention.ms'][1] == 'DEFAULT_CONFIG' | ||
|
||
# Disable topic value | ||
self.rpk.alter_topic_config(topic_name, 'delete.retention.ms', -1) | ||
topic_desc = self.rpk.describe_topic_configs(topic_name) | ||
assert topic_desc['delete.retention.ms'][0] == '-1' | ||
assert topic_desc['delete.retention.ms'][1] == 'DYNAMIC_TOPIC_CONFIG' | ||
|
||
@cluster(num_nodes=1) | ||
def test_create_topic_configurations_cluster_defaults(self): | ||
topic_name = "tapioca" | ||
TopicAndClusterConf = namedtuple('TopicAndClusterConf', [ | ||
'delete_retention_ms', 'cloud_storage_remote_read', | ||
'cloud_storage_remote_write', 'valid' | ||
]) | ||
#We cannot enable delete.retention.ms if any cloud storage properties are also enabled. | ||
test_cases = [ | ||
TopicAndClusterConf(delete_retention_ms=None, | ||
cloud_storage_remote_read='false', | ||
cloud_storage_remote_write='false', | ||
valid=True), | ||
TopicAndClusterConf(delete_retention_ms=None, | ||
cloud_storage_remote_read='true', | ||
cloud_storage_remote_write='false', | ||
valid=True), | ||
TopicAndClusterConf(delete_retention_ms=None, | ||
cloud_storage_remote_read='false', | ||
cloud_storage_remote_write='true', | ||
valid=True), | ||
TopicAndClusterConf(delete_retention_ms=None, | ||
cloud_storage_remote_read='true', | ||
cloud_storage_remote_write='true', | ||
valid=True), | ||
TopicAndClusterConf(delete_retention_ms=1000, | ||
cloud_storage_remote_read='false', | ||
cloud_storage_remote_write='false', | ||
valid=True), | ||
TopicAndClusterConf(delete_retention_ms=1000, | ||
cloud_storage_remote_read='true', | ||
cloud_storage_remote_write='false', | ||
valid=False), | ||
TopicAndClusterConf(delete_retention_ms=1000, | ||
cloud_storage_remote_read='false', | ||
cloud_storage_remote_write='true', | ||
valid=False), | ||
TopicAndClusterConf(delete_retention_ms=1000, | ||
cloud_storage_remote_read='true', | ||
cloud_storage_remote_write='true', | ||
valid=False), | ||
] | ||
for test_case in test_cases: | ||
self.rpk.cluster_config_set('cloud_storage_enable_remote_read', | ||
test_case.cloud_storage_remote_read) | ||
self.rpk.cluster_config_set('cloud_storage_enable_remote_write', | ||
test_case.cloud_storage_remote_write) | ||
|
||
# Sanity check cluster defaults after setting them. | ||
assert self.rpk.cluster_config_get( | ||
'cloud_storage_enable_remote_read' | ||
) == test_case.cloud_storage_remote_read | ||
|
||
assert self.rpk.cluster_config_get( | ||
'cloud_storage_enable_remote_write' | ||
) == test_case.cloud_storage_remote_write | ||
|
||
config = {} | ||
if test_case.delete_retention_ms is not None: | ||
config = {'delete.retention.ms': test_case.delete_retention_ms} | ||
expected_delete_retention_ms = str( | ||
test_case.delete_retention_ms) | ||
else: | ||
expected_delete_retention_ms = '-1' | ||
|
||
if test_case.valid: | ||
# Expect a successful topic creation. | ||
self.rpk.create_topic(topic_name, partitions=1, config=config) | ||
topic_desc = self.rpk.describe_topic_configs(topic_name) | ||
assert topic_desc['delete.retention.ms'][ | ||
0] == expected_delete_retention_ms | ||
# Delete the topic so that we can try again with the next test case. | ||
self.rpk.delete_topic(topic_name) | ||
else: | ||
# Expect a failure due to misconfiguration. | ||
with expect_exception( | ||
RpkException, lambda e: | ||
'Unsupported delete.retention.ms configuration, cannot be enabled at the same time as redpanda.remote.read or redpanda.remote.write.' | ||
in str(e)): | ||
self.rpk.create_topic(topic_name, | ||
partitions=1, | ||
config=config) | ||
|
||
@cluster(num_nodes=1) | ||
def test_create_topic_configurations(self): | ||
topic_name = "tapioca" | ||
TopicConf = namedtuple( | ||
'TopicConf', | ||
['delete_retention_ms', 'remote_read', 'remote_write', 'valid']) | ||
#We cannot enable delete.retention.ms if any cloud storage properties are also enabled. | ||
test_cases = [ | ||
TopicConf(delete_retention_ms=None, | ||
remote_read='false', | ||
remote_write='false', | ||
valid=True), | ||
TopicConf(delete_retention_ms=None, | ||
remote_read='true', | ||
remote_write='false', | ||
valid=True), | ||
TopicConf(delete_retention_ms=None, | ||
remote_read='false', | ||
remote_write='true', | ||
valid=True), | ||
TopicConf(delete_retention_ms=None, | ||
remote_read='true', | ||
remote_write='true', | ||
valid=True), | ||
TopicConf(delete_retention_ms=1000, | ||
remote_read='false', | ||
remote_write='false', | ||
valid=True), | ||
TopicConf(delete_retention_ms=1000, | ||
remote_read='true', | ||
remote_write='false', | ||
valid=False), | ||
TopicConf(delete_retention_ms=1000, | ||
remote_read='false', | ||
remote_write='true', | ||
valid=False), | ||
TopicConf(delete_retention_ms=1000, | ||
remote_read='true', | ||
remote_write='true', | ||
valid=False), | ||
] | ||
for test_case in test_cases: | ||
config = { | ||
'redpanda.remote.read': test_case.remote_read, | ||
'redpanda.remote.write': test_case.remote_write | ||
} | ||
|
||
if test_case.delete_retention_ms is not None: | ||
config['delete.retention.ms'] = test_case.delete_retention_ms | ||
expected_delete_retention_ms = str( | ||
test_case.delete_retention_ms) | ||
else: | ||
expected_delete_retention_ms = '-1' | ||
|
||
if test_case.valid: | ||
# Expect a successful topic creation. | ||
self.rpk.create_topic(topic_name, partitions=1, config=config) | ||
topic_desc = self.rpk.describe_topic_configs(topic_name) | ||
assert topic_desc['delete.retention.ms'][ | ||
0] == expected_delete_retention_ms | ||
# Delete the topic so that we can try again with the next test case. | ||
self.rpk.delete_topic(topic_name) | ||
else: | ||
# Expect a failure due to misconfiguration. | ||
with expect_exception( | ||
RpkException, lambda e: | ||
'Unsupported delete.retention.ms configuration, cannot be enabled at the same time as redpanda.remote.read or redpanda.remote.write.' | ||
in str(e)): | ||
self.rpk.create_topic(topic_name, | ||
partitions=1, | ||
config=config) |