/* * AquaVM Workflow Engine * * Copyright (C) 2024 Fluence DAO * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation version 3 of the * License. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ use air_test_utils::prelude::*; use pretty_assertions::assert_eq; use std::ops::Deref; #[tokio::test] // test for github.com/fluencelabs/aquavm/issues/302 async fn issue_302() { let peer_id_1 = "peer_id_1"; let mut peer_vm_1 = create_avm(echo_call_service(), peer_id_1).await; let peer_id_2 = "peer_id_2"; let mut peer_vm_2 = create_avm(echo_call_service(), peer_id_2).await; let peer_id_3 = "peer_id_3"; let mut peer_vm_3 = create_avm(echo_call_service(), peer_id_3).await; let script = format!( r#" (new $stream (par (call "{peer_id_1}" ("" "") [2] $stream) (seq (call "{peer_id_2}" ("" "") [1] $stream) (seq (call "{peer_id_3}" ("" "") [0] $stream) (seq (canon "{peer_id_2}" $stream #stream) (call "{peer_id_2}" ("" "") [#stream]) ) ) ) ) ) "# ); let result_1 = checked_call_vm!(peer_vm_2, <_>::default(), &script, "", ""); let result_2 = checked_call_vm!(peer_vm_1, <_>::default(), &script, "", result_1.data.clone()); let result_3 = checked_call_vm!(peer_vm_3, <_>::default(), &script, "", result_2.data); let result_4 = checked_call_vm!(peer_vm_2, <_>::default(), &script, result_1.data, result_3.data); let actual_trace = trace_from_result(&result_4); let val_2 = stream!(2, 1, peer = peer_id_1, args = vec![2]); let val_1 = stream!(1, 0, peer = peer_id_2, args = vec![1]); let val_0 = stream!(0, 2, peer = peer_id_3, args = vec![0]); let cid_2 = extract_service_result_cid(&val_2); let cid_1 = extract_service_result_cid(&val_1); let cid_0 = extract_service_result_cid(&val_0); let expected_trace = vec![ executed_state::par(1, 4), val_2, val_1, val_0, executed_state::canon(json!({ "tetraplet": {"function_name": "", "lens": "", "peer_pk": "peer_id_2", "service_id": ""}, "values": [{ "result": 1, "tetraplet": {"function_name": "", "lens": "", "peer_pk": "peer_id_2", "service_id": ""}, "provenance": Provenance::service_result(cid_1), }, { "result": 2, "tetraplet": {"function_name": "", "lens": "", "peer_pk": "peer_id_1", "service_id": ""}, "provenance": Provenance::service_result(cid_2), }, { "result": 0, "tetraplet": {"function_name": "", "lens": "", "peer_pk": "peer_id_3", "service_id": ""}, "provenance": Provenance::service_result(cid_0), }], })), unused!(json!([1, 2, 0]), peer = peer_id_2, args = vec![vec![1, 2, 0]]), ]; assert_eq!(actual_trace.deref(), expected_trace); }