pub struct CreateTopicsService;Expand description
A Service using Storage as Context taking CreateTopicsRequest returning CreateTopicsResponse.
use rama::{Context, Layer, Service as _, layer::MapStateLayer};
use tansu_sans_io::{NULL_TOPIC_ID, CreateTopicsRequest,
create_topics_request::CreatableTopic, ErrorCode};
use tansu_storage::{CreateTopicsService, Error, StorageContainer};
use url::Url;
let storage = StorageContainer::builder()
.cluster_id("tansu")
.node_id(111)
.advertised_listener(Url::parse("tcp://localhost:9092")?)
.storage(Url::parse("memory://tansu/")?)
.build()
.await?;
let service = MapStateLayer::new(|_| storage).into_layer(CreateTopicsService);
let name = "abcba";
let response = service
.serve(
Context::default(),
CreateTopicsRequest::default()
.topics(Some(vec![
CreatableTopic::default()
.name(name.into())
.num_partitions(1)
.replication_factor(3)
.assignments(Some([].into()))
.configs(Some([].into())),
]))
.validate_only(Some(false)),
)
.await?;
let topics = response.topics.unwrap_or_default();
assert_eq!(1, topics.len());
assert_eq!(name, topics[0].name.as_str());
assert_ne!(Some(NULL_TOPIC_ID), topics[0].topic_id);
assert_eq!(Some(1), topics[0].num_partitions);
assert_eq!(Some(3), topics[0].replication_factor);
assert_eq!(ErrorCode::None, ErrorCode::try_from(topics[0].error_code)?);Trait Implementations§
Source§impl Clone for CreateTopicsService
impl Clone for CreateTopicsService
Source§fn clone(&self) -> CreateTopicsService
fn clone(&self) -> CreateTopicsService
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for CreateTopicsService
impl Debug for CreateTopicsService
Source§impl Default for CreateTopicsService
impl Default for CreateTopicsService
Source§fn default() -> CreateTopicsService
fn default() -> CreateTopicsService
Returns the “default value” for a type. Read more
Source§impl Hash for CreateTopicsService
impl Hash for CreateTopicsService
Source§impl Ord for CreateTopicsService
impl Ord for CreateTopicsService
Source§fn cmp(&self, other: &CreateTopicsService) -> Ordering
fn cmp(&self, other: &CreateTopicsService) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Compares and returns the maximum of two values. Read more
Source§impl PartialEq for CreateTopicsService
impl PartialEq for CreateTopicsService
Source§impl PartialOrd for CreateTopicsService
impl PartialOrd for CreateTopicsService
Source§impl<G> Service<G, CreateTopicsRequest> for CreateTopicsServicewhere
G: Storage,
impl<G> Service<G, CreateTopicsRequest> for CreateTopicsServicewhere
G: Storage,
impl Copy for CreateTopicsService
impl Eq for CreateTopicsService
impl StructuralPartialEq for CreateTopicsService
Auto Trait Implementations§
impl Freeze for CreateTopicsService
impl RefUnwindSafe for CreateTopicsService
impl Send for CreateTopicsService
impl Sync for CreateTopicsService
impl Unpin for CreateTopicsService
impl UnsafeUnpin for CreateTopicsService
impl UnwindSafe for CreateTopicsService
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more