From 20a23d15ce8d758fcc00d7db361b2577b2a58add Mon Sep 17 00:00:00 2001 From: Taddes Date: Fri, 18 Oct 2024 15:35:03 -0400 Subject: [PATCH] change firefox version logic to be more robust and return a value of 0 if unparsable, updated related tests --- syncserver/src/server/user_agent.rs | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/syncserver/src/server/user_agent.rs b/syncserver/src/server/user_agent.rs index b63181acc6..cfeb549533 100644 --- a/syncserver/src/server/user_agent.rs +++ b/syncserver/src/server/user_agent.rs @@ -157,8 +157,12 @@ pub fn get_device_info(user_agent: &str) -> DeviceInfo { DeviceFamily::Other => Platform::Other, }; - let firefox_version = - u32::from_str(w_result.version.split('.').collect::>()[0]).unwrap_or_default(); + let firefox_version = w_result + .version + .split('.') + .next() + .and_then(|v| v.parse::().ok()) + .unwrap_or(0); DeviceInfo { platform, @@ -279,6 +283,7 @@ mod tests { assert_eq!(device_info.platform, Platform::FirefoxIOS); assert_eq!(device_info.device_family, DeviceFamily::Mobile); assert_eq!(device_info.os_family, OsFamily::IOS); + assert_eq!(device_info.firefox_version, 0); } #[test] @@ -288,5 +293,6 @@ mod tests { assert_eq!(device_info.platform, Platform::FirefoxIOS); assert_eq!(device_info.device_family, DeviceFamily::Mobile); assert_eq!(device_info.os_family, OsFamily::IOS); + assert_eq!(device_info.firefox_version, 0); } }