use hyperlight_common::flatbuffer_wrappers::function_types::{ParameterValue, ReturnType};
use tracing::{span, Level};
extern crate hyperlight_host;
use std::sync::{Arc, Mutex};
use std::thread::{spawn, JoinHandle};
use hyperlight_host::sandbox::uninitialized::UninitializedSandbox;
use hyperlight_host::sandbox_state::sandbox::EvolvableSandbox;
use hyperlight_host::sandbox_state::transition::Noop;
use hyperlight_host::{GuestBinary, MultiUseSandbox, Result};
use hyperlight_testing::simple_guest_as_string;
use tracing_forest::ForestLayer;
use tracing_subscriber::layer::SubscriberExt;
use tracing_subscriber::util::SubscriberInitExt;
use tracing_subscriber::{EnvFilter, Layer, Registry};
use uuid::Uuid;
fn fn_writer(_msg: String) -> Result<i32> {
Ok(0)
}
fn main() -> Result<()> {
let layer = ForestLayer::default().with_filter(EnvFilter::from_default_env());
Registry::default().with(layer).init();
run_example()
}
fn run_example() -> Result<()> {
let hyperlight_guest_path =
simple_guest_as_string().expect("Cannot find the guest binary at the expected location.");
let mut join_handles: Vec<JoinHandle<Result<()>>> = vec![];
let span = span!(Level::INFO, "hyperlight tracing example",);
let _entered = span.enter();
for i in 0..10 {
let path = hyperlight_guest_path.clone();
let writer_func = Arc::new(Mutex::new(fn_writer));
let handle = spawn(move || -> Result<()> {
let id = Uuid::new_v4();
let span = span!(
Level::INFO,
"hyperlight tracing example thread",
context = format!("Thread number {}", i),
uuid = %id,
);
let _entered = span.enter();
let usandbox = UninitializedSandbox::new(
GuestBinary::FilePath(path),
None,
None,
Some(&writer_func),
)?;
let no_op = Noop::<UninitializedSandbox, MultiUseSandbox>::default();
let mut multiuse_sandbox = usandbox.evolve(no_op)?;
for _ in 0..5 {
let result = multiuse_sandbox.call_guest_function_by_name(
"Echo",
ReturnType::String,
Some(vec![ParameterValue::String("a".to_string())]),
);
assert!(result.is_ok());
}
let msg = "Hello, World!!\n".to_string();
for _ in 0..5 {
let result = multiuse_sandbox.call_guest_function_by_name(
"PrintOutput",
ReturnType::Int,
Some(vec![ParameterValue::String(msg.clone())]),
);
assert!(result.is_ok());
}
Ok(())
});
join_handles.push(handle);
}
let usandbox = UninitializedSandbox::new(
GuestBinary::FilePath(hyperlight_guest_path.clone()),
None,
None,
None,
)?;
let no_op = Noop::<UninitializedSandbox, MultiUseSandbox>::default();
let mut multiuse_sandbox = usandbox.evolve(no_op)?;
for i in 0..5 {
let id = Uuid::new_v4();
let span = span!(
Level::INFO,
"hyperlight tracing call cancellation example thread",
context = format!("Thread number {}", i),
uuid = %id,
);
let _entered = span.enter();
let mut ctx = multiuse_sandbox.new_call_context();
let result = ctx.call("Spin", ReturnType::Void, None);
assert!(result.is_err());
let result = ctx.finish();
assert!(result.is_ok());
multiuse_sandbox = result.unwrap();
}
for join_handle in join_handles {
let result = join_handle.join();
assert!(result.is_ok());
}
Ok(())
}