2022-04-20 23:05:37 +03:00

342 lines
14 KiB
Rust

/*
* Copyright 2022 Fluence Labs Limited
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
use air_test_utils::prelude::*;
#[test]
fn join_chat_1() {
use std::collections::HashSet;
let relay_1_peer_id = "relay_1_peer_id";
let mut relay_1 = create_avm(unit_call_service(), relay_1_peer_id);
let relay_2_peer_id = "relay_2_peer_id";
let mut relay_2 = create_avm(unit_call_service(), relay_2_peer_id);
let client_1_peer_id = "client_1_peer_id";
let mut client_1 = create_avm(unit_call_service(), client_1_peer_id);
let client_2_peer_id = "client_2_peer_id";
let mut client_2 = create_avm(unit_call_service(), client_2_peer_id);
let remote_peer_id = "remote_peer_id";
let members = json!([[client_1_peer_id, relay_1_peer_id], [client_2_peer_id, relay_2_peer_id]]);
let members_call_service: CallServiceClosure =
Box::new(move |_| -> CallServiceResult { CallServiceResult::ok(members.clone()) });
let mut remote = create_avm(members_call_service, remote_peer_id);
let script = f!(r#"
(seq
(call "{relay_1_peer_id}" ("identity" "") [] $void1)
(seq
(call "{remote_peer_id}" ("552196ea-b9b2-4761-98d4-8e7dba77fac4" "add") [] $void2)
(seq
(call "{remote_peer_id}" ("920e3ba3-cbdf-4ae3-8972-0fa2f31fffd9" "get_users") [] members)
(fold members m
(par
(seq
(call m.$.[1]! ("identity" "") [] $void)
(call m.$.[0]! ("fgemb3" "add") [] $void3)
)
(next m)
)
)
)
)
)
"#);
let client_1_result = checked_call_vm!(client_1, <_>::default(), &script, "", "");
let client_1_actual_trace = trace_from_result(&client_1_result);
let client_1_expected_trace = vec![executed_state::request_sent_by(client_1_peer_id)];
assert_eq!(client_1_actual_trace, client_1_expected_trace);
assert_eq!(client_1_result.next_peer_pks, vec![String::from(relay_1_peer_id)]);
let relay_1_result = checked_call_vm!(relay_1, <_>::default(), &script, client_1_result.data, "");
let relay_1_actual_trace = trace_from_result(&relay_1_result);
let relay_1_expected_trace = vec![
executed_state::stream_string("result from unit_call_service", 0),
executed_state::request_sent_by(relay_1_peer_id),
];
assert_eq!(relay_1_actual_trace, relay_1_expected_trace);
assert_eq!(relay_1_result.next_peer_pks, vec![String::from(remote_peer_id)]);
let remote_result = checked_call_vm!(remote, <_>::default(), &script, relay_1_result.data, "");
let remote_actual_trace = trace_from_result(&remote_result);
let remote_expected_trace = vec![
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream(
json!([[client_1_peer_id, relay_1_peer_id], [client_2_peer_id, relay_2_peer_id]]),
0,
),
executed_state::scalar(json!([
[client_1_peer_id, relay_1_peer_id],
[client_2_peer_id, relay_2_peer_id]
])),
executed_state::par(1, 2),
executed_state::request_sent_by(remote_peer_id),
executed_state::par(1, 0),
executed_state::request_sent_by(remote_peer_id),
];
let actual_remote_next_peer_pks: HashSet<_> = remote_result.next_peer_pks.iter().map(|s| s.as_str()).collect();
let expected_next_peer_pks = maplit::hashset! {
relay_1_peer_id,
relay_2_peer_id,
};
assert_eq!(remote_actual_trace, remote_expected_trace);
assert_eq!(actual_remote_next_peer_pks, expected_next_peer_pks);
let relay_1_result = checked_call_vm!(relay_1, <_>::default(), &script, remote_result.data.clone(), "");
let relay_1_actual_trace = trace_from_result(&relay_1_result);
let relay_1_expected_trace = vec![
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream(
json!([[client_1_peer_id, relay_1_peer_id], [client_2_peer_id, relay_2_peer_id]]),
0,
),
executed_state::scalar(json!([
[client_1_peer_id, relay_1_peer_id],
[client_2_peer_id, relay_2_peer_id]
])),
executed_state::par(2, 2),
executed_state::stream_string("result from unit_call_service", 0),
executed_state::request_sent_by(relay_1_peer_id),
executed_state::par(1, 0),
executed_state::request_sent_by(remote_peer_id),
];
assert_eq!(relay_1_actual_trace, relay_1_expected_trace);
assert_eq!(relay_1_result.next_peer_pks, vec![String::from(client_1_peer_id)]);
let client_1_result = checked_call_vm!(client_1, <_>::default(), &script, relay_1_result.data, "");
let client_1_actual_trace = trace_from_result(&client_1_result);
let client_1_expected_trace = vec![
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream(
json!([[client_1_peer_id, relay_1_peer_id], [client_2_peer_id, relay_2_peer_id]]),
0,
),
executed_state::scalar(json!([
[client_1_peer_id, relay_1_peer_id],
[client_2_peer_id, relay_2_peer_id]
])),
executed_state::par(2, 2),
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream_string("result from unit_call_service", 0),
executed_state::par(1, 0),
executed_state::request_sent_by(remote_peer_id),
];
assert_eq!(client_1_actual_trace, client_1_expected_trace);
assert!(client_1_result.next_peer_pks.is_empty());
let relay_2_result = checked_call_vm!(relay_2, <_>::default(), &script, remote_result.data, "");
let relay_2_actual_trace = trace_from_result(&relay_2_result);
let relay_2_expected_trace = vec![
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream(
json!([[client_1_peer_id, relay_1_peer_id], [client_2_peer_id, relay_2_peer_id]]),
0,
),
executed_state::scalar(json!([
[client_1_peer_id, relay_1_peer_id],
[client_2_peer_id, relay_2_peer_id]
])),
executed_state::par(1, 3),
executed_state::request_sent_by(remote_peer_id),
executed_state::par(2, 0),
executed_state::stream_string("result from unit_call_service", 0),
executed_state::request_sent_by(relay_2_peer_id),
];
assert_eq!(relay_2_actual_trace, relay_2_expected_trace);
assert_eq!(relay_2_result.next_peer_pks, vec![String::from(client_2_peer_id)]);
let client_2_result = checked_call_vm!(client_2, <_>::default(), script, relay_2_result.data, "");
let client_2_actual_trace = trace_from_result(&client_2_result);
let client_2_expected_trace = vec![
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream(
json!([[client_1_peer_id, relay_1_peer_id], [client_2_peer_id, relay_2_peer_id]]),
0,
),
executed_state::scalar(json!([
[client_1_peer_id, relay_1_peer_id],
[client_2_peer_id, relay_2_peer_id]
])),
executed_state::par(1, 3),
executed_state::request_sent_by(remote_peer_id),
executed_state::par(2, 0),
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream_string("result from unit_call_service", 0),
];
assert_eq!(client_2_actual_trace, client_2_expected_trace);
assert!(client_2_result.next_peer_pks.is_empty());
}
#[test]
fn join_chat_2() {
let members_call_service1: CallServiceClosure =
Box::new(|_| -> CallServiceResult { CallServiceResult::ok(json!([["A"], ["B"]])) });
let relay_1_peer_id = "relay_1_peer_id";
let mut relay_1 = create_avm(unit_call_service(), relay_1_peer_id);
let remote_peer_id = "remove_peer_id";
let mut remote = create_avm(members_call_service1, remote_peer_id);
let client_peer_id = "client_peer_id";
let mut client_1 = create_avm(unit_call_service(), client_peer_id);
let script = f!(r#"
(seq
(call "{relay_1_peer_id}" ("identity" "") [] $void1)
(seq
(call "{remote_peer_id}" ("920e3ba3-cbdf-4ae3-8972-0fa2f31fffd9" "get_users") [] members)
(fold members m
(par
(seq
(call "{relay_1_peer_id}" ("identity" "") [] $void)
(call "{client_peer_id}" ("fgemb3" "add") [m] $void3)
)
(next m)
)
)
)
)
"#);
let client_1_result = checked_call_vm!(client_1, <_>::default(), &script, "", "");
let relay_1_result = checked_call_vm!(relay_1, <_>::default(), &script, client_1_result.data, "");
let remote_result = checked_call_vm!(remote, <_>::default(), &script, relay_1_result.data, "");
let relay_1_result = checked_call_vm!(relay_1, <_>::default(), &script, remote_result.data, "");
let client_1_result = checked_call_vm!(client_1, <_>::default(), script, relay_1_result.data, "");
let client_1_actual_trace = trace_from_result(&client_1_result);
let client_1_expected_trace = vec![
executed_state::stream_string("result from unit_call_service", 0),
executed_state::scalar(json!([["A"], ["B"]])),
executed_state::par(2, 3),
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream_string("result from unit_call_service", 0),
executed_state::par(2, 0),
executed_state::stream_string("result from unit_call_service", 0),
executed_state::stream_string("result from unit_call_service", 0),
];
assert_eq!(client_1_actual_trace, client_1_expected_trace);
assert!(client_1_result.next_peer_pks.is_empty());
}
#[test]
fn init_peer_id() {
let relay_1_peer_id = "relay_1_peer_id";
let mut relay_1 = create_avm(unit_call_service(), relay_1_peer_id);
let client_1_peer_id = "client_1_peer_id";
let mut client_1 = create_avm(unit_call_service(), client_1_peer_id);
let initiator_peer_id = "initiator_peer_id";
let mut initiator = create_avm(unit_call_service(), initiator_peer_id);
let remote_peer_id = "remote_peer_id";
let members = json!([[client_1_peer_id], ["B"]]);
let members_call_service: CallServiceClosure =
Box::new(move |_| -> CallServiceResult { CallServiceResult::ok(members.clone()) });
let mut remote = create_avm(members_call_service, remote_peer_id);
let script = f!(r#"(seq
(seq
(call "{relay_1_peer_id}" ("identity" "") [])
(seq
(call "{remote_peer_id}" ("920e3ba3-cbdf-4ae3-8972-0fa2f31fffd9" "get_users") [] members)
(fold members m
(par
(seq
(call "{relay_1_peer_id}" ("identity" "") [])
(call "{client_1_peer_id}" ("fgemb3" "add") [m])
)
(next m)
)
)
)
)
(call %init_peer_id% ("identity" "") [])
)
"#);
let test_params = TestRunParameters::from_init_peer_id(initiator_peer_id);
let initiator_1_result = checked_call_vm!(initiator, test_params.clone(), &script, "", "");
let client_1_result = checked_call_vm!(client_1, test_params.clone(), &script, initiator_1_result.data, "");
let relay_1_result = checked_call_vm!(relay_1, test_params.clone(), &script, client_1_result.data, "");
let remote_result = checked_call_vm!(remote, test_params.clone(), &script, relay_1_result.data, "");
let relay_1_result = checked_call_vm!(relay_1, test_params.clone(), &script, remote_result.data, "");
let client_1_result = checked_call_vm!(client_1, test_params.clone(), &script, relay_1_result.data, "");
let client_1_actual_trace = trace_from_result(&client_1_result);
let client_1_expected_trace = vec![
executed_state::scalar_string("result from unit_call_service"),
executed_state::scalar(json!([[client_1_peer_id], ["B"]])),
executed_state::par(2, 3),
executed_state::scalar_string("result from unit_call_service"),
executed_state::scalar_string("result from unit_call_service"),
executed_state::par(2, 0),
executed_state::scalar_string("result from unit_call_service"),
executed_state::scalar_string("result from unit_call_service"),
executed_state::request_sent_by(client_1_peer_id),
];
assert_eq!(client_1_actual_trace, client_1_expected_trace);
assert_eq!(client_1_result.next_peer_pks, vec![initiator_peer_id.to_string()]);
let initiator_1_result = checked_call_vm!(initiator, test_params.clone(), script, client_1_result.data, "");
let initiator_1_actual_trace = trace_from_result(&initiator_1_result);
let initiator_1_expected_trace = vec![
executed_state::scalar_string("result from unit_call_service"),
executed_state::scalar(json!([[client_1_peer_id], ["B"]])),
executed_state::par(2, 3),
executed_state::scalar_string("result from unit_call_service"),
executed_state::scalar_string("result from unit_call_service"),
executed_state::par(2, 0),
executed_state::scalar_string("result from unit_call_service"),
executed_state::scalar_string("result from unit_call_service"),
executed_state::scalar_string("result from unit_call_service"),
];
assert_eq!(initiator_1_actual_trace, initiator_1_expected_trace);
assert!(initiator_1_result.next_peer_pks.is_empty());
}