mirror of
https://github.com/fluencelabs/aquavm
synced 2025-06-26 05:01:32 +00:00
* support call_parameters v2 * remove old comment * use released marine * fix test wasm * update sdk marine use lens * fix test module * WIP fixing the tests to use lens * WIP tetraplet field renaming test fixes * rename more lambda to lens * fix build * Fix gen-bench-data compilation * Update gen-bench-data Cargo.lock * Fix signature tests --------- Co-authored-by: drrtuy <roman@fluence.one> Co-authored-by: Ivan Boldyrev <ivan@fluence.one>
253 lines
8.7 KiB
Rust
253 lines
8.7 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::CatchableError;
|
|
use air_test_framework::AirScriptExecutor;
|
|
use air_test_utils::prelude::*;
|
|
|
|
use pretty_assertions::assert_eq;
|
|
use std::cell::RefCell;
|
|
|
|
#[test]
|
|
fn length_functor_for_array_scalar() {
|
|
let script = r#"
|
|
(seq
|
|
(call %init_peer_id% ("" "") [] variable) ; ok = [1,1,1]
|
|
(call %init_peer_id% ("" "") [variable.length]) ; behaviour = echo
|
|
)
|
|
"#;
|
|
|
|
let init_peer_name = "init_peer_id";
|
|
let executor = AirScriptExecutor::from_annotated(TestRunParameters::from_init_peer_id(init_peer_name), script)
|
|
.expect("invalid test AIR script");
|
|
|
|
let result = executor.execute_one(init_peer_name).unwrap();
|
|
let actual_trace = trace_from_result(&result);
|
|
|
|
let expected_trace = vec![
|
|
scalar!(json!([1, 1, 1]), peer_name = init_peer_name, service = "..0"),
|
|
unused!(3, peer_name = init_peer_name, args = vec![3], service = "..1"),
|
|
];
|
|
assert_eq!(actual_trace, expected_trace);
|
|
}
|
|
|
|
#[test]
|
|
fn length_functor_for_non_array_scalar() {
|
|
let result_jvalue = "string_jvalue";
|
|
let script = format!(
|
|
r#"
|
|
(seq
|
|
(call %init_peer_id% ("" "") [] variable) ; ok = "{result_jvalue}"
|
|
(call %init_peer_id% ("" "") [variable.length]) ; behaviour = echo
|
|
)
|
|
"#
|
|
);
|
|
|
|
let init_peer_name = "init_peer_id";
|
|
let executor = AirScriptExecutor::from_annotated(TestRunParameters::from_init_peer_id(init_peer_name), &script)
|
|
.expect("invalid test AIR script");
|
|
|
|
let result = executor.execute_one(init_peer_name).unwrap();
|
|
check_error(
|
|
&result,
|
|
CatchableError::LengthFunctorAppliedToNotArray(result_jvalue.into()),
|
|
);
|
|
}
|
|
|
|
#[test]
|
|
fn length_functor_for_stream() {
|
|
let script = r#"
|
|
(seq
|
|
(seq
|
|
(ap 1 $stream)
|
|
(ap 1 $stream))
|
|
(seq
|
|
(canon %init_peer_id% $stream #stream)
|
|
(call %init_peer_id% ("" "") [#stream.length]) ; behaviour = echo
|
|
)
|
|
)
|
|
"#;
|
|
|
|
let init_peer_name = "init_peer_id";
|
|
let executor = AirScriptExecutor::from_annotated(TestRunParameters::from_init_peer_id(init_peer_name), script)
|
|
.expect("invalid test AIR script");
|
|
|
|
let result = executor.execute_one(init_peer_name).unwrap();
|
|
let actual_trace = trace_from_result(&result);
|
|
|
|
let init_peer_id = executor.resolve_name(init_peer_name).to_string();
|
|
|
|
let expected_trace = vec![
|
|
executed_state::ap(0),
|
|
executed_state::ap(0),
|
|
executed_state::canon(json!({
|
|
"tetraplet": {"function_name": "", "lens": "", "peer_pk": init_peer_id, "service_id": ""},
|
|
"values": [
|
|
{
|
|
"result": 1,
|
|
"tetraplet": {"function_name": "", "lens": "", "peer_pk": init_peer_id, "service_id": ""},
|
|
"trace_pos": 0,
|
|
},
|
|
{
|
|
"result": 1,
|
|
"tetraplet": {"function_name": "", "lens": "", "peer_pk": init_peer_id, "service_id": ""},
|
|
"trace_pos": 1,
|
|
},
|
|
]
|
|
})),
|
|
unused!(2, peer = init_peer_id, service = "..0", args = vec![2]),
|
|
];
|
|
assert_eq!(actual_trace, expected_trace);
|
|
}
|
|
|
|
#[test]
|
|
fn length_functor_for_empty_stream() {
|
|
let script = r#"
|
|
(new $stream
|
|
(seq
|
|
(canon %init_peer_id% $stream #canon_stream)
|
|
(call %init_peer_id% ("" "") [#canon_stream.length]) ; behaviour = echo
|
|
)
|
|
)
|
|
"#;
|
|
|
|
let init_peer_name = "init_peer_id";
|
|
let executor = AirScriptExecutor::from_annotated(TestRunParameters::from_init_peer_id(init_peer_name), script)
|
|
.expect("invalid test AIR script");
|
|
|
|
let result = executor.execute_one(init_peer_name).unwrap();
|
|
let actual_trace = trace_from_result(&result);
|
|
|
|
let init_peer_id = executor.resolve_name(init_peer_name).to_string();
|
|
|
|
let expected_trace = vec![
|
|
executed_state::canon(
|
|
json!({"tetraplet": {"function_name": "", "lens": "", "peer_pk": init_peer_id, "service_id": ""},
|
|
"values": []} ),
|
|
),
|
|
unused!(0, peer = init_peer_id, service = "..0", args = vec![0]),
|
|
];
|
|
assert_eq!(actual_trace, expected_trace);
|
|
}
|
|
|
|
#[test]
|
|
fn length_functor_for_canon_stream() {
|
|
let script = r#"
|
|
(seq
|
|
(seq
|
|
(ap 1 $stream)
|
|
(ap 1 $stream))
|
|
(seq
|
|
(canon %init_peer_id% $stream #canon_stream)
|
|
(call %init_peer_id% ("" "") [#canon_stream.length]) ; behaviour = echo
|
|
)
|
|
)
|
|
"#;
|
|
|
|
let init_peer_name = "init_peer_id";
|
|
let executor = AirScriptExecutor::from_annotated(TestRunParameters::from_init_peer_id(init_peer_name), script)
|
|
.expect("invalid test AIR script");
|
|
|
|
let result = executor.execute_one(init_peer_name).unwrap();
|
|
let actual_trace = trace_from_result(&result);
|
|
|
|
let init_peer_id = executor.resolve_name(init_peer_name).to_string();
|
|
|
|
let expected_trace = vec![
|
|
executed_state::ap(0),
|
|
executed_state::ap(0),
|
|
executed_state::canon(
|
|
json!({"tetraplet": {"function_name": "", "lens": "", "peer_pk": init_peer_id, "service_id": ""},
|
|
"values": [{"result": 1, "tetraplet": {"function_name": "", "lens": "", "peer_pk": init_peer_id, "service_id": ""}, "trace_pos": 0},
|
|
{"result": 1, "tetraplet": {"function_name": "", "lens": "", "peer_pk": init_peer_id, "service_id": ""}, "trace_pos": 1}
|
|
]} ),
|
|
),
|
|
unused!(2, peer = init_peer_id, service = "..0", args = vec![2]),
|
|
];
|
|
assert_eq!(actual_trace, expected_trace);
|
|
}
|
|
|
|
#[test]
|
|
fn length_functor_for_empty_canon_stream() {
|
|
let script = r#"
|
|
(new $stream
|
|
(seq
|
|
(canon %init_peer_id% $stream #canon_stream)
|
|
(call %init_peer_id% ("" "") [#canon_stream.length]) ; behaviour = echo
|
|
)
|
|
)
|
|
"#;
|
|
|
|
let init_peer_name = "init_peer_id";
|
|
let executor = AirScriptExecutor::from_annotated(TestRunParameters::from_init_peer_id(init_peer_name), script)
|
|
.expect("invalid test AIR script");
|
|
|
|
let result = executor.execute_one(init_peer_name).unwrap();
|
|
let actual_trace = trace_from_result(&result);
|
|
|
|
let init_peer_id = executor.resolve_name(init_peer_name).to_string();
|
|
|
|
let expected_trace = vec![
|
|
executed_state::canon(
|
|
json!({"tetraplet": {"function_name": "", "lens": "", "peer_pk": init_peer_id, "service_id": ""}, "values": []} ),
|
|
),
|
|
unused!(0, peer = init_peer_id, service = "..0", args = vec![0]),
|
|
];
|
|
assert_eq!(actual_trace, expected_trace);
|
|
}
|
|
|
|
#[test]
|
|
fn functor_dont_influence_tetraplet() {
|
|
let set_variable_peer_id = "set_variable_peer_id";
|
|
let set_variable_peer_result = json!({"field": [1,2,3]});
|
|
let mut set_variable_vm = create_avm(
|
|
set_variable_call_service(set_variable_peer_result.clone()),
|
|
set_variable_peer_id,
|
|
);
|
|
|
|
let tetraplet_catcher_peer_id = "tetraplet_catcher_peer_id";
|
|
let (call_service, actual_tetraplet) = tetraplet_host_function(echo_call_service());
|
|
let mut tetraplet_catcher_vm = create_avm(call_service, tetraplet_catcher_peer_id);
|
|
|
|
let script = format!(
|
|
r#"
|
|
(seq
|
|
(call "{set_variable_peer_id}" ("" "") [] scalar)
|
|
(seq
|
|
(ap scalar.$.field field)
|
|
(seq
|
|
(ap field.length length)
|
|
(call "{tetraplet_catcher_peer_id}" ("" "") [length])
|
|
)
|
|
)
|
|
)
|
|
"#
|
|
);
|
|
|
|
let result = checked_call_vm!(set_variable_vm, <_>::default(), &script, "", "");
|
|
let result = checked_call_vm!(tetraplet_catcher_vm, <_>::default(), &script, "", result.data);
|
|
let actual_trace = trace_from_result(&result);
|
|
|
|
let expected_tetraplet = RefCell::new(vec![vec![SecurityTetraplet::new("", "", "", ".length")]]);
|
|
assert_eq!(actual_tetraplet.as_ref(), &expected_tetraplet);
|
|
|
|
let expected_trace = vec![
|
|
scalar!(set_variable_peer_result, peer = set_variable_peer_id),
|
|
unused!(3, peer = tetraplet_catcher_peer_id, args = vec![3]),
|
|
];
|
|
assert_eq!(actual_trace, expected_trace);
|
|
}
|