From 33ccf5ea09232a139b5428c583211de44cf63e93 Mon Sep 17 00:00:00 2001 From: Jesse Bakker Date: Thu, 12 Oct 2023 12:41:04 +0200 Subject: [PATCH] Fix dozer.lock stability --- dozer-cli/src/simple/build/contract/mod.rs | 35 ++++++++++++++++++++-- 1 file changed, 33 insertions(+), 2 deletions(-) diff --git a/dozer-cli/src/simple/build/contract/mod.rs b/dozer-cli/src/simple/build/contract/mod.rs index 93934c60ec..0f043b40c6 100644 --- a/dozer-cli/src/simple/build/contract/mod.rs +++ b/dozer-cli/src/simple/build/contract/mod.rs @@ -229,11 +229,42 @@ where impl PartialEq for PipelineContract { fn eq(&self, other: &PipelineContract) -> bool { + dbg!(self, other); is_isomorphic_matching( self.0.graph(), other.0.graph(), - PartialEq::eq, - PartialEq::eq, + |left, right| { + left.handle == right.handle + && match (&left.kind, &right.kind) { + ( + NodeKind::Source { + typ: left_typ, + port_names: left_portnames, + }, + NodeKind::Source { + typ: right_typ, + port_names: right_portnames, + }, + ) => { + if left_typ != right_typ { + false + } else { + let mut left: Vec<_> = left_portnames.values().collect(); + left.sort(); + let mut right: Vec<_> = right_portnames.values().collect(); + right.sort(); + left == right + } + } + ( + NodeKind::Processor { typ: left_typ }, + NodeKind::Processor { typ: right_typ }, + ) => left_typ == right_typ, + (NodeKind::Sink, NodeKind::Sink) => true, + _ => false, + } + }, + |left, right| left.schema == right.schema, ) } }