pub struct ProduceService;Expand description
A Service using Storage as Context taking ProduceRequest returning ProduceResponse.
use bytes::Bytes;
use rama::{Context, Layer as _, Service as _, layer::MapStateLayer};
use tansu_sans_io::{
CreateTopicsRequest, ErrorCode, ProduceRequest,
create_topics_request::CreatableTopic,
produce_request::{PartitionProduceData, TopicProduceData},
record::{Record, deflated::Frame, inflated},
};
use tansu_storage::{CreateTopicsService, Error, ProduceService, StorageContainer};
use url::Url;
const CLUSTER_ID: &str = "tansu";
const NODE_ID: i32 = 111;
const HOST: &str = "localhost";
const PORT: i32 = 9092;
let storage = StorageContainer::builder()
.cluster_id(CLUSTER_ID)
.node_id(NODE_ID)
.advertised_listener(Url::parse(&format!("tcp://{HOST}:{PORT}"))?)
.storage(Url::parse("memory://tansu/")?)
.build()
.await?;
let create_topic = {
let storage = storage.clone();
MapStateLayer::new(|_| storage).into_layer(CreateTopicsService)
};
let name = "abcba";
let response = create_topic
.serve(
Context::default(),
CreateTopicsRequest::default()
.topics(Some(vec![
CreatableTopic::default()
.name(name.into())
.num_partitions(5)
.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!(ErrorCode::None, ErrorCode::try_from(topics[0].error_code)?);
let produce = {
let storage = storage.clone();
MapStateLayer::new(|_| storage).into_layer(ProduceService)
};
let partition = 0;
let response = produce
.serve(
Context::default(),
ProduceRequest::default().topic_data(Some(
[TopicProduceData::default()
.name(name.into())
.partition_data(Some(
[PartitionProduceData::default()
.index(partition)
.records(Some(Frame {
batches: vec![
inflated::Batch::builder()
.record(
Record::builder().value(
Bytes::from_static(
b"Lorem ipsum dolor sit amet",
)
.into(),
),
)
.build()
.and_then(TryInto::try_into)?,
],
}))]
.into(),
))]
.into(),
)),
)
.await?;
let topics = response.responses.as_deref().unwrap_or_default();
assert_eq!(1, topics.len());
let partitions = topics[0].partition_responses.as_deref().unwrap_or_default();
assert_eq!(1, partitions.len());
assert_eq!(
ErrorCode::None,
ErrorCode::try_from(partitions[0].error_code)?
);Trait Implementations§
Source§impl Clone for ProduceService
impl Clone for ProduceService
Source§fn clone(&self) -> ProduceService
fn clone(&self) -> ProduceService
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 ProduceService
impl Debug for ProduceService
Source§impl Default for ProduceService
impl Default for ProduceService
Source§fn default() -> ProduceService
fn default() -> ProduceService
Returns the “default value” for a type. Read more
Source§impl Hash for ProduceService
impl Hash for ProduceService
Source§impl Ord for ProduceService
impl Ord for ProduceService
Source§fn cmp(&self, other: &ProduceService) -> Ordering
fn cmp(&self, other: &ProduceService) -> 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 ProduceService
impl PartialEq for ProduceService
Source§impl PartialOrd for ProduceService
impl PartialOrd for ProduceService
Source§impl<G> Service<G, ProduceRequest> for ProduceServicewhere
G: Storage,
impl<G> Service<G, ProduceRequest> for ProduceServicewhere
G: Storage,
impl Copy for ProduceService
impl Eq for ProduceService
impl StructuralPartialEq for ProduceService
Auto Trait Implementations§
impl Freeze for ProduceService
impl RefUnwindSafe for ProduceService
impl Send for ProduceService
impl Sync for ProduceService
impl Unpin for ProduceService
impl UnsafeUnpin for ProduceService
impl UnwindSafe for ProduceService
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