pub struct DescribeTopicPartitionsService;Expand description
A Service using Storage as Context taking DescribeTopicPartitionsRequest returning DescribeTopicPartitionsResponse.
use rama::{Context, Layer as _, Service, layer::MapStateLayer};
use tansu_sans_io::{
DescribeTopicPartitionsRequest, ErrorCode,
describe_topic_partitions_request::TopicRequest,
};
use tansu_storage::{DescribeTopicPartitionsService, 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(DescribeTopicPartitionsService);
let topic = "abcba";
let response = service
.serve(
Context::default(),
DescribeTopicPartitionsRequest::default()
.topics(Some([TopicRequest::default().name(topic.into())].into())),
)
.await?;
let topics = response.topics.unwrap_or_default();
assert_eq!(1, topics.len());
assert_eq!(
ErrorCode::UnknownTopicOrPartition,
ErrorCode::try_from(topics[0].error_code)?
);
assert_eq!(Some(topic), topics[0].name.as_deref());Trait Implementations§
Source§impl Clone for DescribeTopicPartitionsService
impl Clone for DescribeTopicPartitionsService
Source§fn clone(&self) -> DescribeTopicPartitionsService
fn clone(&self) -> DescribeTopicPartitionsService
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 Default for DescribeTopicPartitionsService
impl Default for DescribeTopicPartitionsService
Source§fn default() -> DescribeTopicPartitionsService
fn default() -> DescribeTopicPartitionsService
Returns the “default value” for a type. Read more
Source§impl Ord for DescribeTopicPartitionsService
impl Ord for DescribeTopicPartitionsService
Source§fn cmp(&self, other: &DescribeTopicPartitionsService) -> Ordering
fn cmp(&self, other: &DescribeTopicPartitionsService) -> 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 DescribeTopicPartitionsService
impl PartialEq for DescribeTopicPartitionsService
Source§fn eq(&self, other: &DescribeTopicPartitionsService) -> bool
fn eq(&self, other: &DescribeTopicPartitionsService) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl PartialOrd for DescribeTopicPartitionsService
impl PartialOrd for DescribeTopicPartitionsService
Source§impl<G> Service<G, DescribeTopicPartitionsRequest> for DescribeTopicPartitionsServicewhere
G: Storage,
impl<G> Service<G, DescribeTopicPartitionsRequest> for DescribeTopicPartitionsServicewhere
G: Storage,
impl Copy for DescribeTopicPartitionsService
impl Eq for DescribeTopicPartitionsService
impl StructuralPartialEq for DescribeTopicPartitionsService
Auto Trait Implementations§
impl Freeze for DescribeTopicPartitionsService
impl RefUnwindSafe for DescribeTopicPartitionsService
impl Send for DescribeTopicPartitionsService
impl Sync for DescribeTopicPartitionsService
impl Unpin for DescribeTopicPartitionsService
impl UnsafeUnpin for DescribeTopicPartitionsService
impl UnwindSafe for DescribeTopicPartitionsService
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