mirror of
https://github.com/fluencelabs/aquavm
synced 2025-04-24 23:02:16 +00:00
This PR intended to reduce stream usage scope in order to make AquaVM truly deterministic. Refs: #297. Co-authored-by: Ivan Boldyrev <ivan@fluence.one> Co-authored-by: Anatoly Laskaris <github_me@nahsi.dev>
130 lines
4.7 KiB
Rust
130 lines
4.7 KiB
Rust
/*
|
|
* Copyright 2021 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]
|
|
// test for github.com/fluencelabs/aquavm/issues/211
|
|
// On the versions < 0.20.1 it just crashes
|
|
fn issue_211() {
|
|
let peer_1_id = "peer_1_id";
|
|
|
|
let script = f!(r#"
|
|
(xor
|
|
(seq
|
|
(seq
|
|
(seq
|
|
(seq
|
|
(null)
|
|
(call %init_peer_id% ("getdatasrv" "idx") [] idx) ; ok=2
|
|
)
|
|
(call %init_peer_id% ("getdatasrv" "nodes") [] nodes) ; ok = [1,2,3]
|
|
)
|
|
(new $nodes2
|
|
(seq
|
|
(seq
|
|
(par
|
|
(fold nodes node
|
|
(par
|
|
(ap node $nodes2)
|
|
(next node)
|
|
)
|
|
)
|
|
(null)
|
|
)
|
|
(seq
|
|
(canon %init_peer_id% $nodes2 #nodes2_0)
|
|
(call %init_peer_id% ("op" "noop") [#nodes2_0.$.[idx]! nodes]) ; ok="expected result"
|
|
)
|
|
)
|
|
(seq
|
|
(canon %init_peer_id% $nodes2 #nodes2_1)
|
|
(call %init_peer_id% ("op" "identity") [#nodes2_1] nodes2-fix) ; ok="expected result"
|
|
)
|
|
)
|
|
)
|
|
)
|
|
(null)
|
|
)
|
|
(call %init_peer_id% ("errorhandlingsrv" "error") [%last_error% 2]) ; ok="error"
|
|
)
|
|
"#);
|
|
|
|
let run_params = TestRunParameters::from_init_peer_id(peer_1_id);
|
|
|
|
let engine =
|
|
air_test_framework::AirScriptExecutor::simple(run_params, &script).expect("invalid test executor config");
|
|
|
|
let result = engine.execute_one(peer_1_id).unwrap();
|
|
|
|
let expected_trace = vec![
|
|
executed_state::scalar_number(2),
|
|
executed_state::scalar(json!([1, 2, 3])),
|
|
executed_state::par(6, 0),
|
|
executed_state::par(1, 4),
|
|
executed_state::ap(0),
|
|
executed_state::par(1, 2),
|
|
executed_state::ap(0),
|
|
executed_state::par(1, 0),
|
|
executed_state::ap(0),
|
|
executed_state::canon(json!({
|
|
"tetraplet": {"function_name": "", "json_path": "", "peer_pk": "peer_1_id", "service_id": ""},
|
|
"values": [
|
|
{
|
|
"result": 1,
|
|
"tetraplet": {"function_name": "nodes", "json_path": "", "peer_pk": "peer_1_id", "service_id": "getdatasrv..1"},
|
|
"trace_pos": 4
|
|
},
|
|
{
|
|
"result": 2,
|
|
"tetraplet": {"function_name": "nodes", "json_path": "", "peer_pk": "peer_1_id", "service_id": "getdatasrv..1"},
|
|
"trace_pos": 6
|
|
},
|
|
{
|
|
"result": 3,
|
|
"tetraplet": {"function_name": "nodes", "json_path": "", "peer_pk": "peer_1_id", "service_id": "getdatasrv..1"},
|
|
"trace_pos": 8
|
|
},
|
|
]
|
|
})),
|
|
executed_state::scalar_string("expected result"),
|
|
executed_state::canon(json!({
|
|
"tetraplet": {"function_name": "", "json_path": "", "peer_pk": "peer_1_id", "service_id": ""},
|
|
"values": [
|
|
{
|
|
"result": 1,
|
|
"tetraplet": {"function_name": "nodes", "json_path": "", "peer_pk": "peer_1_id", "service_id": "getdatasrv..1"},
|
|
"trace_pos": 4
|
|
},
|
|
{
|
|
"result": 2,
|
|
"tetraplet": {"function_name": "nodes", "json_path": "", "peer_pk": "peer_1_id", "service_id": "getdatasrv..1"},
|
|
"trace_pos": 6
|
|
},
|
|
{
|
|
"result": 3,
|
|
"tetraplet": {"function_name": "nodes", "json_path": "", "peer_pk": "peer_1_id", "service_id": "getdatasrv..1"},
|
|
"trace_pos": 8
|
|
},
|
|
]
|
|
})),
|
|
executed_state::scalar_string("expected result"),
|
|
];
|
|
|
|
let actual_trace = trace_from_result(&result);
|
|
assert_eq!(actual_trace, expected_trace);
|
|
}
|