1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
use nature_common::{Executor, is_default};

use crate::FlowSelector;
use crate::relation_target::RelationTarget;

#[derive(Debug, Clone, Serialize, Deserialize, Default, PartialEq, Eq)]
pub struct RelationSettings {
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub selector: Option<FlowSelector>,
    /// array executor will share the convert task
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub executor: Option<Executor>,
    /// filter will execute before executor,
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub filter_before: Vec<Executor>,
    /// filter will execute after executor,
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub filter_after: Vec<Executor>,
    /// if the downstream is state meta, when `is_main` is set to true, the upstream's id will be used as downstream's id
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub use_upstream_id: bool,
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub target: RelationTarget,
    /// delay seconds to execute the converter
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub delay: i32,
    /// delay seconds to execute the converter based on `Instance.para`
    /// - first value : how long to delay
    /// - second value : time part based on of the `Instance.para`
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub delay_on_para: (i32, u8),
    /// if this relation's next target will use the upstream's id please set this property to `true`
    #[serde(skip_serializing_if = "is_default")]
    #[serde(default)]
    pub id_bridge: bool,
}

#[cfg(test)]
mod test {
    use std::collections::HashSet;

    use nature_common::{Protocol, TargetState};

    use super::*;

    #[test]
    fn default_test() {
        let settings = RelationSettings::default();
        let result = serde_json::to_string(&settings).unwrap();
        assert_eq!(result, "{}");
    }

    #[test]
    fn delay_on_para() {
        let mut settings = RelationSettings::default();
        settings.delay_on_para = (100, 20);
        let result = serde_json::to_string(&settings).unwrap();
        assert_eq!(result, r#"{"delay_on_para":[100,20]}"#);
        let rtn = serde_json::from_str::<RelationSettings>(&result).unwrap();
        assert_eq!(rtn, settings);
    }

    #[test]
    fn selector_test() {
        let mut set = HashSet::<String>::new();
        set.insert("one".to_string());
        let mut fs = FlowSelector::default();
        fs.state_all = set;

        let mut setting = RelationSettings::default();
        setting.selector = Some(fs);

        let result = serde_json::to_string(&setting).unwrap();
        let res_str = r#"{"selector":{"state_all":["one"]}}"#;
        assert_eq!(result, res_str);
        let res_obj: RelationSettings = serde_json::from_str(res_str).unwrap();
        assert_eq!(res_obj, setting);
    }

    #[test]
    fn empty_executor_test() {
        let setting = RelationSettings::default();
        let result = serde_json::to_string(&setting).unwrap();
        let res_str = r#"{}"#;
        assert_eq!(result, res_str);
        let res_obj: RelationSettings = serde_json::from_str(res_str).unwrap();
        assert_eq!(res_obj, setting);
    }

    #[test]
    fn executor_test() {
        let executor = Executor {
            protocol: Protocol::LocalRust,
            url: "nature_demo:order_new".to_string(),
            settings: "".to_string(),
        };
        let mut setting = RelationSettings::default();
        setting.executor = Some(executor);
        let result = serde_json::to_string(&setting).unwrap();
        let res_str = r#"{"executor":{"protocol":"localRust","url":"nature_demo:order_new"}}"#;
        assert_eq!(result, res_str);
        let res_obj: RelationSettings = serde_json::from_str(res_str).unwrap();
        assert_eq!(res_obj, setting);
    }

    #[test]
    fn use_upstream_id() {
        let mut setting = RelationSettings::default();
        setting.use_upstream_id = true;
        let result = serde_json::to_string(&setting).unwrap();
        let res_str = r#"{"use_upstream_id":true}"#;
        assert_eq!(result, res_str);
        let res_obj: RelationSettings = serde_json::from_str(res_str).unwrap();
        assert_eq!(res_obj, setting);
    }

    #[test]
    fn target_state() {
        let state = TargetState { add: Some(vec!["new".to_string()]), remove: None, need_all: Default::default(), need_any: Default::default(), need_none: Default::default() };
        let mut setting = RelationSettings::default();
        setting.target.states = Some(state);
        let result = serde_json::to_string(&setting).unwrap();
        let res_str = r#"{"target":{"states":{"add":["new"]}}}"#;
        assert_eq!(result, res_str);
        let res_obj: RelationSettings = serde_json::from_str(res_str).unwrap();
        assert_eq!(res_obj, setting);
    }
}