// Copyright © SixtyFPS GmbH // SPDX-License-Identifier: GPL-3.0-only OR LicenseRef-Slint-commercial use itertools::Itertools; use slint_interpreter::{DiagnosticLevel, Value, ValueType}; use std::error::Error; pub fn test(testcase: &test_driver_lib::TestCase) -> Result<(), Box> { i_slint_backend_testing::init(); let source = std::fs::read_to_string(&testcase.absolute_path)?; let include_paths = test_driver_lib::extract_include_paths(&source) .map(std::path::PathBuf::from) .collect::>(); let mut compiler = slint_interpreter::ComponentCompiler::default(); compiler.set_include_paths(include_paths); compiler.set_style(String::from("fluent")); // force to fluent style as Qt does not like multi-threaded test execution let component = spin_on::spin_on(compiler.build_from_source(source, testcase.absolute_path.clone())); let component = match component { None => { slint_interpreter::print_diagnostics(compiler.diagnostics()); match std::env::var("SLINT_INTERPRETER_ERROR_WHITELIST") { Ok(wl) if !wl.is_empty() => { let errors = compiler .diagnostics() .iter() .filter(|d| d.level() == DiagnosticLevel::Error) .collect::>(); if !errors.is_empty() && errors.iter().all(|d| wl.split(';').any(|w| d.message().contains(w))) { eprintln!( "{}: Ignoring Error because of the error whitelist!", testcase.relative_path.display() ); return Ok(()); } } _ => {} } return Err(compiler.diagnostics().iter().map(|d| d.to_string()).join("\n").into()); } Some(c) => c, }; let instance = component.create().unwrap(); if let Some((_, ty)) = component.properties().find(|x| x.0 == "test") { if ty == ValueType::Bool { let result = instance.get_property("test")?; if result != Value::Bool(true) { eprintln!("FAIL: {}: test returned {:?}", testcase.relative_path.display(), result); eprintln!("Property list:"); for (p, _) in component.properties() { eprintln!(" {}: {:?}", p, instance.get_property(&p)); } panic!("Test Failed: {:?}", result); } } } Ok(()) }