From 2b223d45ea4e93123d9c6f1cdfff2d715cd26bb0 Mon Sep 17 00:00:00 2001 From: LivingLimes <141739703+LivingLimes@users.noreply.github.com> Date: Tue, 28 May 2024 20:05:48 +1000 Subject: [PATCH] 4065: Use url crate port_or_known_default to allow parsing default ports (#4087) --- core/src/fnc/parse.rs | 31 ++++++++++++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) diff --git a/core/src/fnc/parse.rs b/core/src/fnc/parse.rs index d416c4d2..7d780970 100644 --- a/core/src/fnc/parse.rs +++ b/core/src/fnc/parse.rs @@ -92,7 +92,7 @@ pub mod url { pub fn port((string,): (String,)) -> Result { // Parse the URL match Url::parse(&string) { - Ok(v) => match v.port() { + Ok(v) => match v.port_or_known_default() { Some(v) => Ok(v.into()), None => Ok(Value::None), }, @@ -118,4 +118,33 @@ pub mod url { Err(_) => Ok(Value::None), } } + + #[cfg(test)] + mod tests { + use crate::sql::value::Value; + + #[test] + fn port_default_port_specified() { + let value = super::port(("http://www.google.com:80".to_string(),)).unwrap(); + assert_eq!(value, 80.into()); + } + + #[test] + fn port_nondefault_port_specified() { + let value = super::port(("http://www.google.com:8080".to_string(),)).unwrap(); + assert_eq!(value, 8080.into()); + } + + #[test] + fn port_no_port_specified() { + let value = super::port(("http://www.google.com".to_string(),)).unwrap(); + assert_eq!(value, 80.into()); + } + + #[test] + fn port_no_scheme_no_port_specified() { + let value = super::port(("www.google.com".to_string(),)).unwrap(); + assert_eq!(value, Value::None); + } + } }