From 97ca6c161129495f6e053c2634f7984cd6f4bd5e Mon Sep 17 00:00:00 2001 From: Allan Clements Date: Wed, 13 Nov 2024 12:14:08 -0600 Subject: [PATCH] Added serial annotation for test_partial_content to prevent test state intermingling and retry loops for merge tests that observe state between transactions to prevent flakey failures --- .../tests/integration_client_async.rs | 3 + gremlin-client/tests/integration_traversal.rs | 63 ++++++++++++------- 2 files changed, 45 insertions(+), 21 deletions(-) diff --git a/gremlin-client/tests/integration_client_async.rs b/gremlin-client/tests/integration_client_async.rs index 2a2e794..4f74263 100644 --- a/gremlin-client/tests/integration_client_async.rs +++ b/gremlin-client/tests/integration_client_async.rs @@ -9,6 +9,7 @@ mod aio { use rstest::*; use rstest_reuse::{self, *}; + use serial_test::serial; use crate::common; @@ -63,6 +64,7 @@ mod aio { } #[apply(common::serializers)] + #[serial(test_session_empty_query)] #[cfg(feature = "async-std-runtime")] #[cfg_attr(feature = "async-std-runtime", async_std::test)] async fn test_session_empty_query(protocol: IoProtocol) { @@ -118,6 +120,7 @@ mod aio { } #[apply(common::serializers)] + #[serial(test_partial_content)] #[cfg(feature = "async-std-runtime")] #[cfg_attr(feature = "async-std-runtime", async_std::test)] async fn test_partial_content(protocol: IoProtocol) { diff --git a/gremlin-client/tests/integration_traversal.rs b/gremlin-client/tests/integration_traversal.rs index 54ff255..4ab4cfd 100644 --- a/gremlin-client/tests/integration_traversal.rs +++ b/gremlin-client/tests/integration_traversal.rs @@ -373,19 +373,30 @@ mod merge_tests { injection_map.insert("match_params".into(), on_match_map.into()); let do_merge_edge = |g: GraphTraversalSource| -> Map { - g.inject(vec![injection_map.clone().into()]) - .unfold() - .as_("payload") - .merge_e(__.select("payload").select("merge_params")) - .option(( - Merge::OnCreate, - __.select("payload").select("create_params"), - )) - .option((Merge::OnMatch, __.select("payload").select("match_params"))) - .element_map(()) - .next() - .expect("Should get a response") - .expect("Should return a edge properties") + let mut attempt = 0; + loop { + attempt += 1; + let response = g + .inject(vec![injection_map.clone().into()]) + .unfold() + .as_("payload") + .merge_e(__.select("payload").select("merge_params")) + .option(( + Merge::OnCreate, + __.select("payload").select("create_params"), + )) + .option((Merge::OnMatch, __.select("payload").select("match_params"))) + .element_map(()) + .next(); + if response.is_ok() { + break response; + } else if attempt > 10 { + std::panic!("mergeE vertices not observed before attempt exhaustion") + } + std::thread::sleep(std::time::Duration::from_millis(10)); + } + .expect("Should get a response") + .expect("Should return a edge properties") }; let on_create_edge_properties = do_merge_edge(g.clone()); @@ -436,14 +447,24 @@ mod merge_tests { assignment_map.insert(Direction::Out.into(), vertex_b.id().into()); assignment_map.insert(T::Label.into(), expected_edge_label.into()); - let anonymous_merge_e_properties = g - .inject(1) - .unfold() - .coalesce::([__.merge_e(assignment_map)]) - .element_map(()) - .next() - .expect("Should get a response") - .expect("Should return a edge properties"); + let mut attempt = 0; + let anonymous_merge_e_properties = loop { + attempt += 1; + let response = g + .inject(1) + .unfold() + .coalesce::([__.merge_e(assignment_map.clone())]) + .element_map(()) + .next(); + if response.is_ok() { + break response; + } else if attempt > 10 { + std::panic!("mergeE vertices not observed before attempt exhaustion") + } + std::thread::sleep(std::time::Duration::from_millis(10)); + } + .expect("Should get a response") + .expect("Should return a edge properties"); let incoming_vertex: &Map = anonymous_merge_e_properties .get(Direction::In)