From fba8b29cdde17aa733bfef6bb75dfb3f0611f943 Mon Sep 17 00:00:00 2001 From: muzarski Date: Wed, 24 Apr 2024 17:39:52 +0200 Subject: [PATCH] cqlvalue: make chrono conversions test utility Made `CqlValue`-to-chrono types conversion methods a private utility methods used only for tests. --- scylla-cql/src/frame/response/result.rs | 35 ++++++++++++++----------- 1 file changed, 19 insertions(+), 16 deletions(-) diff --git a/scylla-cql/src/frame/response/result.rs b/scylla-cql/src/frame/response/result.rs index 75680a91dc..219e97336d 100644 --- a/scylla-cql/src/frame/response/result.rs +++ b/scylla-cql/src/frame/response/result.rs @@ -153,8 +153,9 @@ impl CqlValue { } } + #[cfg(test)] #[cfg(feature = "chrono-04")] - pub fn as_naive_date(&self) -> Option { + fn as_naive_date_04(&self) -> Option { self.as_cql_date().and_then(|date| date.try_into().ok()) } @@ -170,8 +171,9 @@ impl CqlValue { } } + #[cfg(test)] #[cfg(feature = "chrono-04")] - pub fn as_datetime(&self) -> Option> { + fn as_datetime_04(&self) -> Option> { self.as_cql_timestamp().and_then(|ts| ts.try_into().ok()) } @@ -187,8 +189,9 @@ impl CqlValue { } } + #[cfg(test)] #[cfg(feature = "chrono-04")] - pub fn as_naive_time(&self) -> Option { + fn as_naive_time_04(&self) -> Option { self.as_cql_time().and_then(|ts| ts.try_into().ok()) } @@ -1370,7 +1373,7 @@ mod tests { super::deser_cql_value(&ColumnType::Date, &mut (1u32 << 31).to_be_bytes().as_ref()) .unwrap(); - assert_eq!(date.as_naive_date(), Some(unix_epoch)); + assert_eq!(date.as_naive_date_04(), Some(unix_epoch)); // 2^31 - 30 when converted to NaiveDate is 1969-12-02 let before_epoch = NaiveDate::from_ymd_opt(1969, 12, 2).unwrap(); @@ -1380,7 +1383,7 @@ mod tests { ) .unwrap(); - assert_eq!(date.as_naive_date(), Some(before_epoch)); + assert_eq!(date.as_naive_date_04(), Some(before_epoch)); // 2^31 + 30 when converted to NaiveDate is 1970-01-31 let after_epoch = NaiveDate::from_ymd_opt(1970, 1, 31).unwrap(); @@ -1390,20 +1393,20 @@ mod tests { ) .unwrap(); - assert_eq!(date.as_naive_date(), Some(after_epoch)); + assert_eq!(date.as_naive_date_04(), Some(after_epoch)); // 0 and u32::MAX are out of NaiveDate range, fails with an error, not panics assert_eq!( super::deser_cql_value(&ColumnType::Date, &mut 0_u32.to_be_bytes().as_ref()) .unwrap() - .as_naive_date(), + .as_naive_date_04(), None ); assert_eq!( super::deser_cql_value(&ColumnType::Date, &mut u32::MAX.to_be_bytes().as_ref()) .unwrap() - .as_naive_date(), + .as_naive_date_04(), None ); } @@ -1492,7 +1495,7 @@ mod tests { let time = super::deser_cql_value(&ColumnType::Time, &mut (0i64).to_be_bytes().as_ref()).unwrap(); - assert_eq!(time.as_naive_time(), Some(midnight)); + assert_eq!(time.as_naive_time_04(), Some(midnight)); // 10:10:30.500,000,001 let (h, m, s, n) = (10, 10, 30, 500_000_001); @@ -1505,7 +1508,7 @@ mod tests { ) .unwrap(); - assert_eq!(time.as_naive_time(), Some(midnight)); + assert_eq!(time.as_naive_time_04(), Some(midnight)); // 23:59:59.999,999,999 let (h, m, s, n) = (23, 59, 59, 999_999_999); @@ -1518,7 +1521,7 @@ mod tests { ) .unwrap(); - assert_eq!(time.as_naive_time(), Some(midnight)); + assert_eq!(time.as_naive_time_04(), Some(midnight)); } #[cfg(feature = "time-03")] @@ -1584,7 +1587,7 @@ mod tests { let date = super::deser_cql_value(&ColumnType::Timestamp, &mut 0i64.to_be_bytes().as_ref()) .unwrap(); - assert_eq!(date.as_datetime(), Some(unix_epoch)); + assert_eq!(date.as_datetime_04(), Some(unix_epoch)); // When converted to NaiveDateTime, this is 1969-12-01 11:29:29.5 let timestamp: i64 = -((((30 * 24 + 12) * 60 + 30) * 60 + 30) * 1000 + 500); @@ -1599,7 +1602,7 @@ mod tests { ) .unwrap(); - assert_eq!(date.as_datetime(), Some(before_epoch)); + assert_eq!(date.as_datetime_04(), Some(before_epoch)); // when converted to NaiveDateTime, this is is 1970-01-31 12:30:30.5 let timestamp: i64 = (((30 * 24 + 12) * 60 + 30) * 60 + 30) * 1000 + 500; @@ -1614,20 +1617,20 @@ mod tests { ) .unwrap(); - assert_eq!(date.as_datetime(), Some(after_epoch)); + assert_eq!(date.as_datetime_04(), Some(after_epoch)); // 0 and u32::MAX are out of NaiveDate range, fails with an error, not panics assert_eq!( super::deser_cql_value(&ColumnType::Timestamp, &mut i64::MIN.to_be_bytes().as_ref()) .unwrap() - .as_datetime(), + .as_datetime_04(), None ); assert_eq!( super::deser_cql_value(&ColumnType::Timestamp, &mut i64::MAX.to_be_bytes().as_ref()) .unwrap() - .as_datetime(), + .as_datetime_04(), None ); }