feat(tvix/eval): allow to disable warnings
The nix_tests test suite produces lots of warnings. We can't fix these, since they are kept in sync with upstream, so there's little point in cluttering up the console with them every time the tests are run. Let's add a clap flag "warnings" and TVIX_WARNINGS environment variable. The default is "true". The test runner overrides this default and mutes the warnings. Signed-off-by: Adam Joseph <adam@westernsemico.com> Change-Id: I4b065f96fe15838afcca6970491a54e248ae4df7 Reviewed-on: https://cl.tvl.fyi/c/depot/+/6985 Reviewed-by: tazjin <tazjin@tvl.su> Reviewed-by: grfn <grfn@gws.fyi> Tested-by: BuildkiteCI
This commit is contained in:
parent
7c99e9e8e3
commit
e83609a061
2 changed files with 28 additions and 7 deletions
|
@ -25,11 +25,28 @@ pub struct Options {
|
|||
#[cfg_attr(feature = "repl", clap(long, env = "TVIX_TRACE_RUNTIME"))]
|
||||
trace_runtime: bool,
|
||||
|
||||
/// Print warnings
|
||||
#[cfg_attr(
|
||||
feature = "repl",
|
||||
clap(long, env = "TVIX_WARNINGS", default_value = "true")
|
||||
)]
|
||||
warnings: bool,
|
||||
|
||||
/// A colon-separated list of directories to use to resolve `<...>`-style paths
|
||||
#[cfg_attr(feature = "repl", clap(long, short = 'I', env = "NIX_PATH"))]
|
||||
nix_search_path: Option<NixSearchPath>,
|
||||
}
|
||||
|
||||
impl Options {
|
||||
#[cfg(test)]
|
||||
pub(crate) fn test_options() -> Options {
|
||||
Options {
|
||||
warnings: false,
|
||||
..Options::default()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn interpret(code: &str, location: Option<PathBuf>, options: Options) -> EvalResult<Value> {
|
||||
let source = SourceCode::new();
|
||||
let file = source.add_file(
|
||||
|
@ -97,8 +114,10 @@ pub fn interpret(code: &str, location: Option<PathBuf>, options: Options) -> Eva
|
|||
)
|
||||
}?;
|
||||
|
||||
for warning in result.warnings {
|
||||
warning.fancy_format_stderr(&source);
|
||||
if options.warnings {
|
||||
for warning in result.warnings {
|
||||
warning.fancy_format_stderr(&source);
|
||||
}
|
||||
}
|
||||
|
||||
for error in &result.errors {
|
||||
|
@ -128,10 +147,11 @@ pub fn interpret(code: &str, location: Option<PathBuf>, options: Options) -> Eva
|
|||
}
|
||||
|
||||
result.map(|r| {
|
||||
for warning in r.warnings {
|
||||
warning.fancy_format_stderr(&source);
|
||||
if options.warnings {
|
||||
for warning in r.warnings {
|
||||
warning.fancy_format_stderr(&source);
|
||||
}
|
||||
}
|
||||
|
||||
r.value
|
||||
})
|
||||
}
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
use crate::eval::interpret;
|
||||
use crate::eval::Options;
|
||||
use pretty_assertions::assert_eq;
|
||||
|
||||
use test_generator::test_resources;
|
||||
|
@ -12,7 +13,7 @@ fn eval_okay_test(code_path: &str) {
|
|||
let code = std::fs::read_to_string(code_path).expect("should be able to read test code");
|
||||
let exp = std::fs::read_to_string(exp_path).expect("should be able to read test expectation");
|
||||
|
||||
let result = interpret(&code, Some(code_path.into()), Default::default())
|
||||
let result = interpret(&code, Some(code_path.into()), Options::test_options())
|
||||
.expect("evaluation of eval-okay test should succeed");
|
||||
let result_str = format!("{}", result);
|
||||
|
||||
|
@ -29,7 +30,7 @@ fn eval_okay_test(code_path: &str) {
|
|||
fn identity(code_path: &str) {
|
||||
let code = std::fs::read_to_string(code_path).expect("should be able to read test code");
|
||||
|
||||
let result = interpret(&code, None, Default::default())
|
||||
let result = interpret(&code, None, Options::test_options())
|
||||
.expect("evaluation of identity test should succeed");
|
||||
let result_str = format!("{}", result);
|
||||
|
||||
|
|
Loading…
Reference in a new issue