From bafa4592ba625538deab3f195efcb42de5dca1e6 Mon Sep 17 00:00:00 2001 From: AntiTopQuark Date: Wed, 27 Dec 2023 23:38:34 +0800 Subject: [PATCH] refactor(TableRouteValue): add panic notes and type checks --- src/common/meta/src/key/table_route.rs | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/src/common/meta/src/key/table_route.rs b/src/common/meta/src/key/table_route.rs index d767d098a79f..7f6ed8c79680 100644 --- a/src/common/meta/src/key/table_route.rs +++ b/src/common/meta/src/key/table_route.rs @@ -62,7 +62,13 @@ impl TableRouteValue { } /// Returns a new version [TableRouteValue] with `region_routes`. + /// + /// # Panics + /// The route type is not the [TableRouteValue::Physical]. pub fn update(&self, region_routes: Vec) -> Self { + if (!self.is_physical()) { + panic!("Mistakenly been treated as a Physical TableRoute: {self:?}"); + } let version = self.physical_table_route().version; Self::Physical(PhysicalTableRouteValue { region_routes, @@ -73,13 +79,25 @@ impl TableRouteValue { /// Returns the version. /// /// For test purpose. + /// + /// # Panics + /// The route type is not the [TableRouteValue::Physical]. #[cfg(any(test, feature = "testing"))] pub fn version(&self) -> u64 { + if (!self.is_physical()) { + panic!("Mistakenly been treated as a Physical TableRoute: {self:?}"); + } self.physical_table_route().version } /// Returns the corresponding [RegionRoute]. + /// + /// # Panics + /// The route type is not the [TableRouteValue::Physical]. pub fn region_route(&self, region_id: RegionId) -> Option { + if (!self.is_physical()) { + panic!("Mistakenly been treated as a Physical TableRoute: {self:?}"); + } self.physical_table_route() .region_routes .iter() @@ -97,6 +115,9 @@ impl TableRouteValue { /// # Panics /// The route type is not the [TableRouteValue::Physical]. pub fn region_routes(&self) -> &Vec { + if (!self.is_physical()) { + panic!("Mistakenly been treated as a Physical TableRoute: {self:?}"); + } &self.physical_table_route().region_routes }