meerkat-mob 0.5.2

Multi-agent orchestration runtime for Meerkat
Documentation
use crate::MeerkatId;

#[derive(Debug, Clone, PartialEq, Eq)]
pub(super) enum MobRuntimeBridgeEffect {
    DeliverLifecycleNotice {
        peer_id: MeerkatId,
        intent: &'static str,
    },
}

pub(super) struct MobRuntimeBridgeAuthority;

impl MobRuntimeBridgeAuthority {
    pub(super) fn plan_lifecycle_notice(
        sender_ready: bool,
        wired_peers: &[MeerkatId],
        intent: &'static str,
    ) -> Vec<MobRuntimeBridgeEffect> {
        if !sender_ready {
            return Vec::new();
        }
        wired_peers
            .iter()
            .cloned()
            .map(|peer_id| MobRuntimeBridgeEffect::DeliverLifecycleNotice { peer_id, intent })
            .collect()
    }
}

#[cfg(test)]
mod tests {
    use super::*;

    #[test]
    fn missing_sender_skips_notice_delivery() {
        let effects = MobRuntimeBridgeAuthority::plan_lifecycle_notice(
            false,
            &[MeerkatId::from("a")],
            "mob.kickoff_failed",
        );
        assert!(effects.is_empty());
    }

    #[test]
    fn wired_peers_receive_bridge_notice_plan() {
        let effects = MobRuntimeBridgeAuthority::plan_lifecycle_notice(
            true,
            &[MeerkatId::from("a"), MeerkatId::from("b")],
            "mob.kickoff_failed",
        );
        assert_eq!(effects.len(), 2);
    }
}