feat(tvix/glue): use TvixStoreIO as derivation builtin state
We propagate a `TvixStoreIO` as the `state` of our derivation-specific builtins in the glue crate. The evaluators `io_handle` itself is using a Rc<dyn EvalIO>. An earlier version of TvixStoreIO was also introducing generics over the different internal services themselves, but we opted for instead hardcoding this to Arc<dyn …> for the sake of less macro voodoo. Change-Id: I535c476f06b840858fa3070c4a237ece47f7a15b Reviewed-on: https://cl.tvl.fyi/c/depot/+/10636 Reviewed-by: raitobezarius <tvl@lahfa.xyz> Autosubmit: raitobezarius <tvl@lahfa.xyz> Tested-by: BuildkiteCI Reviewed-by: flokli <flokli@flokli.de>
This commit is contained in:
parent
43b9e25025
commit
12ae96cff2
7 changed files with 124 additions and 102 deletions
|
@ -1,12 +1,13 @@
|
|||
use criterion::{black_box, criterion_group, criterion_main, Criterion};
|
||||
use lazy_static::lazy_static;
|
||||
use std::{cell::RefCell, env, rc::Rc, sync::Arc, time::Duration};
|
||||
use std::{env, rc::Rc, sync::Arc, time::Duration};
|
||||
use tvix_castore::{
|
||||
blobservice::{BlobService, MemoryBlobService},
|
||||
directoryservice::{DirectoryService, MemoryDirectoryService},
|
||||
};
|
||||
use tvix_eval::EvalIO;
|
||||
use tvix_glue::{
|
||||
builtins::add_derivation_builtins, configure_nix_path, known_paths::KnownPaths,
|
||||
builtins::add_derivation_builtins, configure_nix_path, tvix_io::TvixIO,
|
||||
tvix_store_io::TvixStoreIO,
|
||||
};
|
||||
use tvix_store::pathinfoservice::{MemoryPathInfoService, PathInfoService};
|
||||
|
@ -26,10 +27,21 @@ fn interpret(code: &str) {
|
|||
// TODO: this is a bit annoying.
|
||||
// It'd be nice if we could set this up once and then run evaluate() with a
|
||||
// piece of code. b/262
|
||||
let mut eval = tvix_eval::Evaluation::new_impure();
|
||||
|
||||
let known_paths: Rc<RefCell<KnownPaths>> = Default::default();
|
||||
add_derivation_builtins(&mut eval, known_paths);
|
||||
// We assemble a complete store in memory.
|
||||
let tvix_store_io = Rc::new(TvixStoreIO::new(
|
||||
BLOB_SERVICE.clone(),
|
||||
DIRECTORY_SERVICE.clone(),
|
||||
PATH_INFO_SERVICE.clone(),
|
||||
TOKIO_RUNTIME.handle().clone(),
|
||||
));
|
||||
|
||||
let mut eval = tvix_eval::Evaluation::new(
|
||||
Box::new(TvixIO::new(tvix_store_io.clone() as Rc<dyn EvalIO>)) as Box<dyn EvalIO>,
|
||||
true,
|
||||
);
|
||||
|
||||
add_derivation_builtins(&mut eval, tvix_store_io);
|
||||
configure_nix_path(
|
||||
&mut eval,
|
||||
// The benchmark requires TVIX_BENCH_NIX_PATH to be set, so barf out
|
||||
|
@ -37,13 +49,6 @@ fn interpret(code: &str) {
|
|||
&Some(env::var("TVIX_BENCH_NIX_PATH").expect("TVIX_BENCH_NIX_PATH must be set")),
|
||||
);
|
||||
|
||||
eval.io_handle = Box::new(tvix_glue::tvix_io::TvixIO::new(TvixStoreIO::new(
|
||||
BLOB_SERVICE.clone(),
|
||||
DIRECTORY_SERVICE.clone(),
|
||||
PATH_INFO_SERVICE.clone(),
|
||||
TOKIO_RUNTIME.handle().clone(),
|
||||
)));
|
||||
|
||||
let result = eval.evaluate(code, None);
|
||||
|
||||
assert!(result.errors.is_empty());
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue