diff --git a/kstreams/backends/kafka.py b/kstreams/backends/kafka.py index 19271d0b..f2fd69ab 100644 --- a/kstreams/backends/kafka.py +++ b/kstreams/backends/kafka.py @@ -63,6 +63,7 @@ class Kafka(BaseModel): class Config: arbitrary_types_allowed = True + use_enum_values = True @root_validator def protocols_validation(cls, values): diff --git a/tests/test_backend_kafka.py b/tests/test_backend_kafka.py index faf715c8..3eb1c1ac 100644 --- a/tests/test_backend_kafka.py +++ b/tests/test_backend_kafka.py @@ -99,3 +99,21 @@ def test_sasl_ssl_fail_missing_ssl_context(): sasl_plain_password=password, ) assert "ssl_context" in str(e.value.args[0]) + + +def test_backend_to_dict(): + kafka_backend = Kafka( + security_protocol=SecurityProtocol.SASL_PLAINTEXT, + sasl_plain_username="username", + sasl_plain_password="pwd", + ) + assert kafka_backend.security_protocol == SecurityProtocol.SASL_PLAINTEXT + assert kafka_backend.dict() == { + "bootstrap_servers": ["localhost:9092"], + "security_protocol": "SASL_PLAINTEXT", + "ssl_context": None, + "sasl_mechanism": "PLAIN", + "sasl_plain_username": "username", + "sasl_plain_password": "pwd", + "sasl_oauth_token_provider": None, + }