aquavm/crates/air-lib/test-utils/src/executed_state.rs

224 lines
6.7 KiB
Rust
Raw Normal View History

2021-05-16 22:52:22 +03:00
/*
* Copyright 2020 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.
*/
2021-08-24 16:14:15 +03:00
use super::ApResult;
use super::CallResult;
2022-08-26 00:43:43 +03:00
use super::CanonResult;
2021-08-24 16:14:15 +03:00
use super::ExecutedState;
2021-05-16 22:52:22 +03:00
use super::JValue;
2021-08-24 16:14:15 +03:00
use super::ParResult;
use super::Sender;
use super::TracePos;
use super::ValueRef;
2021-08-24 16:14:15 +03:00
use crate::FoldLore;
use crate::FoldResult;
use crate::FoldSubTraceLore;
use crate::SubTraceDesc;
2021-05-16 22:52:22 +03:00
use air_interpreter_cid::value_to_json_cid;
use air_interpreter_data::CanonCidAggregate;
use air_interpreter_data::CidTracker;
use avm_server::SecurityTetraplet;
use serde::Deserialize;
use serde::Serialize;
2021-05-16 22:52:22 +03:00
use std::rc::Rc;
2021-08-24 16:14:15 +03:00
pub fn scalar(result: JValue) -> ExecutedState {
let cid = value_to_json_cid(&result)
.unwrap_or_else(|e| panic!("{:?}: failed to compute CID of {:?}", e, result));
let value = ValueRef::Scalar(Rc::new(cid));
ExecutedState::Call(CallResult::Executed(value))
}
pub fn scalar_tracked(result: impl Into<JValue>, tracker: &mut CidTracker) -> ExecutedState {
let cid = tracker.record_value(Rc::new(result.into())).unwrap();
let value = ValueRef::Scalar(cid);
2021-08-24 16:14:15 +03:00
ExecutedState::Call(CallResult::Executed(value))
2021-05-16 22:52:22 +03:00
}
pub fn scalar_number(result: impl Into<serde_json::Number>) -> ExecutedState {
let result = JValue::Number(result.into());
scalar(result)
}
pub fn stream_call_result(result: JValue, generation: u32) -> CallResult {
let cid = value_to_json_cid(&result)
.unwrap_or_else(|e| panic!("{:?}: failed to compute CID of {:?}", e, result));
CallResult::executed_stream(Rc::new(cid), generation)
}
pub fn stream(result: JValue, generation: u32) -> ExecutedState {
ExecutedState::Call(stream_call_result(result, generation))
}
pub fn stream_tracked(
value: impl Into<JValue>,
generation: u32,
tracker: &mut CidTracker,
) -> ExecutedState {
let cid = tracker.record_value(Rc::new(value.into())).unwrap();
ExecutedState::Call(CallResult::executed_stream(cid, generation))
2021-05-16 22:52:22 +03:00
}
pub fn scalar_string(result: impl Into<String>) -> ExecutedState {
2021-08-24 16:14:15 +03:00
let result = JValue::String(result.into());
scalar(result)
2021-05-16 22:52:22 +03:00
}
pub fn scalar_string_array(result: Vec<impl Into<String>>) -> ExecutedState {
let result = result
.into_iter()
.map(|s| JValue::String(s.into()))
.collect::<Vec<_>>();
let value = JValue::Array(result);
2021-05-16 22:52:22 +03:00
scalar(value)
2021-05-16 22:52:22 +03:00
}
2021-08-24 16:14:15 +03:00
pub fn stream_string(result: impl Into<String>, generation: u32) -> ExecutedState {
let result = JValue::String(result.into());
stream(result, generation)
2021-05-16 22:52:22 +03:00
}
2021-08-24 16:14:15 +03:00
pub fn stream_number(result: impl Into<serde_json::Number>, generation: u32) -> ExecutedState {
let result = JValue::Number(result.into());
stream(result, generation)
2021-05-16 22:52:22 +03:00
}
2021-08-24 16:14:15 +03:00
pub fn stream_string_array(result: Vec<impl Into<String>>, generation: u32) -> ExecutedState {
2021-05-16 22:52:22 +03:00
let result = result
.into_iter()
.map(|s| JValue::String(s.into()))
.collect::<Vec<_>>();
let value = JValue::Array(result);
2021-05-16 22:52:22 +03:00
stream(value, generation)
2021-05-16 22:52:22 +03:00
}
pub fn request_sent_by(sender: impl Into<String>) -> ExecutedState {
ExecutedState::Call(CallResult::RequestSentBy(Sender::PeerId(Rc::new(
sender.into(),
))))
2021-05-16 22:52:22 +03:00
}
pub fn par(left: usize, right: usize) -> ExecutedState {
2021-08-24 16:14:15 +03:00
let par_result = ParResult {
left_size: left as _,
right_size: right as _,
};
ExecutedState::Par(par_result)
2021-05-16 22:52:22 +03:00
}
2021-11-24 18:47:49 +03:00
pub fn service_failed(ret_code: i32, error_message: &str) -> ExecutedState {
2021-05-16 22:52:22 +03:00
ExecutedState::Call(CallResult::CallServiceFailed(
ret_code,
Rc::new(format!(r#""{error_message}""#)),
2021-05-16 22:52:22 +03:00
))
}
2021-08-24 16:14:15 +03:00
pub fn fold(lore: FoldLore) -> ExecutedState {
let result = FoldResult { lore };
ExecutedState::Fold(result)
}
pub fn subtrace_lore(
value_pos: usize,
2021-08-24 16:14:15 +03:00
before: SubTraceDesc,
after: SubTraceDesc,
) -> FoldSubTraceLore {
FoldSubTraceLore {
value_pos: value_pos.into(),
2021-08-24 16:14:15 +03:00
subtraces_desc: vec![before, after],
}
}
pub fn subtrace_desc(begin_pos: impl Into<TracePos>, subtrace_len: u32) -> SubTraceDesc {
SubTraceDesc {
begin_pos: begin_pos.into(),
subtrace_len,
}
}
pub fn ap(generation: u32) -> ExecutedState {
let ap_result = ApResult::new(generation);
2021-08-24 16:14:15 +03:00
ExecutedState::Ap(ap_result)
}
#[derive(Debug, Serialize, Deserialize)]
pub struct ValueAggregateAlike {
pub result: Rc<JValue>,
pub tetraplet: Rc<SecurityTetraplet>,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct CanonResultAlike {
pub tetraplet: Rc<SecurityTetraplet>,
pub values: Vec<ValueAggregateAlike>,
}
/// This function takes a JSON DSL-like struct for compatibility and test writer
/// convenience.
pub fn canon(canonicalized_element: JValue) -> ExecutedState {
let mut value_tracker = CidTracker::<JValue>::new();
let mut tetraplet_tracker = CidTracker::<SecurityTetraplet>::new();
let mut canon_tracker = CidTracker::<CanonCidAggregate>::new();
canon_tracked(
canonicalized_element,
&mut value_tracker,
&mut tetraplet_tracker,
&mut canon_tracker,
)
}
pub fn canon_tracked(
canonicalized_element: JValue,
value_tracker: &mut CidTracker<JValue>,
tetraplet_tracker: &mut CidTracker<SecurityTetraplet>,
canon_tracker: &mut CidTracker<CanonCidAggregate>,
) -> ExecutedState {
let canon_input = serde_json::from_value::<CanonResultAlike>(canonicalized_element)
.expect("Malformed canon input");
let tetraplet_cid = tetraplet_tracker
.record_value(canon_input.tetraplet.clone())
.unwrap_or_else(|e| {
panic!(
"{:?}: failed to compute CID of {:?}",
e, canon_input.tetraplet
)
});
let value_cids = canon_input
.values
.iter()
.map(|value| {
let value_cid = value_tracker.record_value(value.result.clone())?;
let tetraplet_cid = tetraplet_tracker.record_value(value.tetraplet.clone())?;
canon_tracker.record_value(CanonCidAggregate {
value: value_cid,
tetraplet: tetraplet_cid,
})
})
.collect::<Result<Vec<_>, _>>()
.unwrap_or_else(|e| panic!("{:?}: failed to compute CID of {:?}", e, canon_input.values));
let canon_result = CanonResult::new(tetraplet_cid, value_cids);
2022-08-26 00:43:43 +03:00
ExecutedState::Canon(canon_result)
}