rocketmq_remoting/protocol/body/
consumer_offset_serialize_wrapper.rs1use std::collections::HashMap;
18
19use cheetah_string::CheetahString;
20use serde::Deserialize;
21use serde::Serialize;
22
23use crate::protocol::DataVersion;
24
25#[derive(Serialize, Deserialize, Debug, Default)]
26#[serde(rename_all = "camelCase")]
27pub struct ConsumerOffsetSerializeWrapper {
28 data_version: DataVersion,
29 offset_table: HashMap<CheetahString , HashMap<i32 , i64>>,
31}
32
33impl ConsumerOffsetSerializeWrapper {
34 pub fn data_version(&self) -> &DataVersion {
36 &self.data_version
37 }
38 pub fn set_data_version(&mut self, data_version: DataVersion) {
40 self.data_version = data_version;
41 }
42 pub fn offset_table_ref(&self) -> &HashMap<CheetahString, HashMap<i32, i64>> {
44 &self.offset_table
45 }
46 pub fn offset_table(self) -> HashMap<CheetahString, HashMap<i32, i64>> {
47 self.offset_table
48 }
49 pub fn offset_table_mut(&mut self) -> &mut HashMap<CheetahString, HashMap<i32, i64>> {
51 &mut self.offset_table
52 }
53 pub fn set_offset_table(&mut self, offset_table: HashMap<CheetahString, HashMap<i32, i64>>) {
55 self.offset_table = offset_table;
56 }
57}
58
59#[cfg(test)]
60mod tests {
61 use std::collections::HashMap;
62
63 use super::*;
64
65 #[test]
66 fn test_consumer_offset_serialize_wrapper_insert_and_retrieve() {
67 let mut wrapper = ConsumerOffsetSerializeWrapper::default();
68
69 let topic_group = CheetahString::from("test_topic@test_group");
70 let mut queue_offsets = HashMap::new();
71 queue_offsets.insert(0, 100i64);
72 queue_offsets.insert(1, 200i64);
73
74 wrapper
75 .offset_table
76 .insert(topic_group.clone(), queue_offsets);
77
78 assert_eq!(wrapper.offset_table.len(), 1);
79 assert!(wrapper.offset_table.contains_key(&topic_group));
80
81 let retrieved_offsets = wrapper.offset_table.get(&topic_group).unwrap();
82 assert_eq!(retrieved_offsets.get(&0), Some(&100i64));
83 assert_eq!(retrieved_offsets.get(&1), Some(&200i64));
84 }
85}