From eab58b9bada9930c0b35463f70c88dcaab0616a3 Mon Sep 17 00:00:00 2001 From: Alex Snaps Date: Sat, 2 Nov 2024 12:03:06 -0400 Subject: [PATCH] Assert on the path requested when accessing well known attr Signed-off-by: Alex Snaps --- src/data/cel.rs | 55 ++++++++++++++++++++++++++++++++++---------- src/data/property.rs | 10 ++++++-- 2 files changed, 51 insertions(+), 14 deletions(-) diff --git a/src/data/cel.rs b/src/data/cel.rs index c2c4d67..1e65797 100644 --- a/src/data/cel.rs +++ b/src/data/cel.rs @@ -449,12 +449,14 @@ pub mod data { #[cfg(test)] mod tests { use crate::data::cel::{known_attribute_for, Expression, Predicate}; + use crate::data::property; use cel_interpreter::objects::ValueType; #[test] fn predicates() { let predicate = Predicate::new("source.port == 65432").expect("This is valid CEL!"); - super::super::property::test::TEST_PROPERTY_VALUE.set(Some(65432_i64.to_le_bytes().into())); + property::test::TEST_PROPERTY_VALUE + .set(Some(("source.port".into(), 65432_i64.to_le_bytes().into()))); assert!(predicate.test()); } @@ -470,36 +472,65 @@ mod tests { #[test] fn expressions_to_json_resolve() { - super::super::property::test::TEST_PROPERTY_VALUE.set(Some("true".bytes().collect())); + property::test::TEST_PROPERTY_VALUE.set(Some(( + property::Path::new(vec![ + "filter_state", + "wasm.kuadrant.auth.identity.anonymous", + ]), + "true".bytes().collect(), + ))); let value = Expression::new("auth.identity.anonymous").unwrap().eval(); assert_eq!(value, true.into()); - super::super::property::test::TEST_PROPERTY_VALUE.set(Some("42".bytes().collect())); + + property::test::TEST_PROPERTY_VALUE.set(Some(( + property::Path::new(vec!["filter_state", "wasm.kuadrant.auth.identity.age"]), + "42".bytes().collect(), + ))); let value = Expression::new("auth.identity.age").unwrap().eval(); assert_eq!(value, 42.into()); - super::super::property::test::TEST_PROPERTY_VALUE.set(Some("42.3".bytes().collect())); + + property::test::TEST_PROPERTY_VALUE.set(Some(( + property::Path::new(vec!["filter_state", "wasm.kuadrant.auth.identity.age"]), + "42.3".bytes().collect(), + ))); let value = Expression::new("auth.identity.age").unwrap().eval(); assert_eq!(value, 42.3.into()); - super::super::property::test::TEST_PROPERTY_VALUE.set(Some("\"John\"".bytes().collect())); - let value = Expression::new("auth.identity.name").unwrap().eval(); - assert_eq!(value, "John".into()); - super::super::property::test::TEST_PROPERTY_VALUE.set(Some("-42".bytes().collect())); + + property::test::TEST_PROPERTY_VALUE.set(Some(( + property::Path::new(vec!["filter_state", "wasm.kuadrant.auth.identity.age"]), + "\"John\"".bytes().collect(), + ))); let value = Expression::new("auth.identity.age").unwrap().eval(); + assert_eq!(value, "John".into()); + + property::test::TEST_PROPERTY_VALUE.set(Some(( + property::Path::new(vec!["filter_state", "wasm.kuadrant.auth.identity.name"]), + "-42".bytes().collect(), + ))); + let value = Expression::new("auth.identity.name").unwrap().eval(); assert_eq!(value, (-42).into()); + // let's fall back to strings, as that's what we read and set in store_metadata - super::super::property::test::TEST_PROPERTY_VALUE - .set(Some("some random crap".bytes().collect())); + property::test::TEST_PROPERTY_VALUE.set(Some(( + property::Path::new(vec!["filter_state", "wasm.kuadrant.auth.identity.age"]), + "some random crap".bytes().collect(), + ))); let value = Expression::new("auth.identity.age").unwrap().eval(); assert_eq!(value, "some random crap".into()); } #[test] fn attribute_resolve() { - super::super::property::test::TEST_PROPERTY_VALUE.set(Some(80_i64.to_le_bytes().into())); + property::test::TEST_PROPERTY_VALUE.set(Some(( + "destination.port".into(), + 80_i64.to_le_bytes().into(), + ))); let value = known_attribute_for(&"destination.port".into()) .unwrap() .get(); assert_eq!(value, 80.into()); - super::super::property::test::TEST_PROPERTY_VALUE.set(Some("GET".bytes().collect())); + property::test::TEST_PROPERTY_VALUE + .set(Some(("request.method".into(), "GET".bytes().collect()))); let value = known_attribute_for(&"request.method".into()).unwrap().get(); assert_eq!(value, "GET".into()); } diff --git a/src/data/property.rs b/src/data/property.rs index 973e709..9b20fe0 100644 --- a/src/data/property.rs +++ b/src/data/property.rs @@ -35,7 +35,13 @@ fn wasm_prop(tokens: &[&str]) -> Path { #[cfg(test)] fn host_get_property(path: &Path) -> Result>, Status> { debug!("get_property: {:?}", path); - Ok(test::TEST_PROPERTY_VALUE.take()) + match test::TEST_PROPERTY_VALUE.take() { + None => Err(Status::NotFound), + Some((expected_path, data)) => { + assert_eq!(&expected_path, path); + Ok(Some(data)) + } + } } #[cfg(test)] @@ -146,7 +152,7 @@ pub mod test { use std::cell::Cell; thread_local!( - pub static TEST_PROPERTY_VALUE: Cell>> = const { Cell::new(None) }; + pub static TEST_PROPERTY_VALUE: Cell)>> = const { Cell::new(None) }; ); #[test]