* git mv src/wasm-lib rust Signed-off-by: Jess Frazelle <github@jessfraz.com> * mv wasm-lib to workspace Signed-off-by: Jess Frazelle <github@jessfraz.com> * mv kcl-lib Signed-off-by: Jess Frazelle <github@jessfraz.com> * mv derive docs Signed-off-by: Jess Frazelle <github@jessfraz.com> * resolve file paths Signed-off-by: Jess Frazelle <github@jessfraz.com> * clippy Signed-off-by: Jess Frazelle <github@jessfraz.com> * move more shit Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix more paths Signed-off-by: Jess Frazelle <github@jessfraz.com> * make yarn build:wasm work Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix scripts Signed-off-by: Jess Frazelle <github@jessfraz.com> * fixups Signed-off-by: Jess Frazelle <github@jessfraz.com> * better references Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix cargo ci Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix reference Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix more ci Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix tests Signed-off-by: Jess Frazelle <github@jessfraz.com> * cargo sort Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix script Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix Signed-off-by: Jess Frazelle <github@jessfraz.com> * fmt Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix a dep Signed-off-by: Jess Frazelle <github@jessfraz.com> * sort Signed-off-by: Jess Frazelle <github@jessfraz.com> * remove unused deps Signed-off-by: Jess Frazelle <github@jessfraz.com> * Revert "remove unused deps" This reverts commit fbabdb062e275fd5cbc1476f8480a1afee15d972. * updates Signed-off-by: Jess Frazelle <github@jessfraz.com> * deps; Signed-off-by: Jess Frazelle <github@jessfraz.com> * fixes Signed-off-by: Jess Frazelle <github@jessfraz.com> * updates Signed-off-by: Jess Frazelle <github@jessfraz.com> --------- Signed-off-by: Jess Frazelle <github@jessfraz.com>
256 lines
7.2 KiB
Rust
256 lines
7.2 KiB
Rust
//! Cache testing framework.
|
|
|
|
use kcl_lib::{bust_cache, ExecError, ExecOutcome};
|
|
|
|
#[derive(Debug)]
|
|
struct Variation<'a> {
|
|
code: &'a str,
|
|
settings: &'a kcl_lib::ExecutorSettings,
|
|
}
|
|
|
|
async fn cache_test(
|
|
test_name: &str,
|
|
variations: Vec<Variation<'_>>,
|
|
) -> Vec<(String, image::DynamicImage, ExecOutcome)> {
|
|
let first = variations
|
|
.first()
|
|
.ok_or_else(|| anyhow::anyhow!("No variations provided for test '{}'", test_name))
|
|
.unwrap();
|
|
|
|
let mut ctx = kcl_lib::ExecutorContext::new_with_client(first.settings.clone(), None, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
bust_cache().await;
|
|
let mut img_results = Vec::new();
|
|
for (index, variation) in variations.iter().enumerate() {
|
|
let program = kcl_lib::Program::parse_no_errs(variation.code).unwrap();
|
|
|
|
// set the new settings.
|
|
ctx.settings = variation.settings.clone();
|
|
|
|
let outcome = ctx.run_with_caching(program).await.unwrap();
|
|
let snapshot_png_bytes = ctx.prepare_snapshot().await.unwrap().contents.0;
|
|
|
|
// Decode the snapshot, return it.
|
|
let img = image::ImageReader::new(std::io::Cursor::new(snapshot_png_bytes))
|
|
.with_guessed_format()
|
|
.map_err(|e| ExecError::BadPng(e.to_string()))
|
|
.and_then(|x| x.decode().map_err(|e| ExecError::BadPng(e.to_string())))
|
|
.unwrap();
|
|
// Save the snapshot.
|
|
let path = crate::assert_out(&format!("cache_{}_{}", test_name, index), &img);
|
|
|
|
img_results.push((path, img, outcome));
|
|
}
|
|
|
|
ctx.close().await;
|
|
|
|
img_results
|
|
}
|
|
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
async fn kcl_test_cache_change_units_changes_output() {
|
|
let code = r#"part001 = startSketchOn('XY')
|
|
|> startProfileAt([5.5229, 5.25217], %)
|
|
|> line(end = [10.50433, -1.19122])
|
|
|> line(end = [8.01362, -5.48731])
|
|
|> line(end = [-1.02877, -6.76825])
|
|
|> line(end = [-11.53311, 2.81559])
|
|
|> close()
|
|
|> extrude(length = 4)
|
|
"#;
|
|
|
|
let result = cache_test(
|
|
"change_units_changes_output",
|
|
vec![
|
|
Variation {
|
|
code,
|
|
settings: &kcl_lib::ExecutorSettings {
|
|
units: kcl_lib::UnitLength::In,
|
|
..Default::default()
|
|
},
|
|
},
|
|
Variation {
|
|
code,
|
|
settings: &kcl_lib::ExecutorSettings {
|
|
units: kcl_lib::UnitLength::Mm,
|
|
..Default::default()
|
|
},
|
|
},
|
|
],
|
|
)
|
|
.await;
|
|
|
|
let first = result.first().unwrap();
|
|
let second = result.last().unwrap();
|
|
|
|
assert!(first.1 != second.1);
|
|
}
|
|
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
async fn kcl_test_cache_change_grid_visualizes_grid_off_to_on() {
|
|
let code = r#"part001 = startSketchOn('XY')
|
|
|> startProfileAt([5.5229, 5.25217], %)
|
|
|> line(end = [10.50433, -1.19122])
|
|
|> line(end = [8.01362, -5.48731])
|
|
|> line(end = [-1.02877, -6.76825])
|
|
|> line(end = [-11.53311, 2.81559])
|
|
|> close()
|
|
|> extrude(length = 4)
|
|
"#;
|
|
|
|
let result = cache_test(
|
|
"change_grid_visualizes_grid_off_to_on",
|
|
vec![
|
|
Variation {
|
|
code,
|
|
settings: &kcl_lib::ExecutorSettings {
|
|
show_grid: false,
|
|
..Default::default()
|
|
},
|
|
},
|
|
Variation {
|
|
code,
|
|
settings: &kcl_lib::ExecutorSettings {
|
|
show_grid: true,
|
|
..Default::default()
|
|
},
|
|
},
|
|
],
|
|
)
|
|
.await;
|
|
|
|
let first = result.first().unwrap();
|
|
let second = result.last().unwrap();
|
|
|
|
assert!(first.1 != second.1);
|
|
}
|
|
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
async fn kcl_test_cache_change_grid_visualizes_grid_on_to_off() {
|
|
let code = r#"part001 = startSketchOn('XY')
|
|
|> startProfileAt([5.5229, 5.25217], %)
|
|
|> line(end = [10.50433, -1.19122])
|
|
|> line(end = [8.01362, -5.48731])
|
|
|> line(end = [-1.02877, -6.76825])
|
|
|> line(end = [-11.53311, 2.81559])
|
|
|> close()
|
|
|> extrude(length = 4)
|
|
"#;
|
|
|
|
let result = cache_test(
|
|
"change_grid_visualizes_grid_on_to_off",
|
|
vec![
|
|
Variation {
|
|
code,
|
|
settings: &kcl_lib::ExecutorSettings {
|
|
show_grid: true,
|
|
..Default::default()
|
|
},
|
|
},
|
|
Variation {
|
|
code,
|
|
settings: &kcl_lib::ExecutorSettings {
|
|
show_grid: false,
|
|
..Default::default()
|
|
},
|
|
},
|
|
],
|
|
)
|
|
.await;
|
|
|
|
let first = result.first().unwrap();
|
|
let second = result.last().unwrap();
|
|
|
|
assert!(first.1 != second.1);
|
|
}
|
|
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
async fn kcl_test_cache_change_highlight_edges_changes_visual() {
|
|
let code = r#"part001 = startSketchOn('XY')
|
|
|> startProfileAt([5.5229, 5.25217], %)
|
|
|> line(end = [10.50433, -1.19122])
|
|
|> line(end = [8.01362, -5.48731])
|
|
|> line(end = [-1.02877, -6.76825])
|
|
|> line(end = [-11.53311, 2.81559])
|
|
|> close()
|
|
|> extrude(length = 4)
|
|
"#;
|
|
|
|
let result = cache_test(
|
|
"change_highlight_edges_changes_visual",
|
|
vec![
|
|
Variation {
|
|
code,
|
|
settings: &kcl_lib::ExecutorSettings {
|
|
highlight_edges: true,
|
|
..Default::default()
|
|
},
|
|
},
|
|
Variation {
|
|
code,
|
|
settings: &kcl_lib::ExecutorSettings {
|
|
highlight_edges: false,
|
|
..Default::default()
|
|
},
|
|
},
|
|
],
|
|
)
|
|
.await;
|
|
|
|
let first = result.first().unwrap();
|
|
let second = result.last().unwrap();
|
|
|
|
assert!(first.1 != second.1);
|
|
}
|
|
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
async fn kcl_test_cache_add_line_preserves_artifact_commands() {
|
|
let code = r#"sketch001 = startSketchOn('XY')
|
|
|> startProfileAt([5.5229, 5.25217], %)
|
|
|> line(end = [10.50433, -1.19122])
|
|
|> line(end = [8.01362, -5.48731])
|
|
|> line(end = [-1.02877, -6.76825])
|
|
|> line(end = [-11.53311, 2.81559])
|
|
|> close()
|
|
"#;
|
|
// Use a new statement; don't extend the prior pipeline. This allows us to
|
|
// detect a prefix.
|
|
let code_with_extrude = code.to_owned()
|
|
+ r#"
|
|
extrude(sketch001, length = 4)
|
|
"#;
|
|
|
|
let result = cache_test(
|
|
"add_line_preserves_artifact_commands",
|
|
vec![
|
|
Variation {
|
|
code,
|
|
settings: &Default::default(),
|
|
},
|
|
Variation {
|
|
code: code_with_extrude.as_str(),
|
|
settings: &Default::default(),
|
|
},
|
|
],
|
|
)
|
|
.await;
|
|
|
|
let first = &result.first().unwrap().2;
|
|
let second = &result.last().unwrap().2;
|
|
|
|
assert!(
|
|
first.artifact_commands.len() < second.artifact_commands.len(),
|
|
"Second should have all the artifact commands of the first, plus more. first={:?}, second={:?}",
|
|
first.artifact_commands.len(),
|
|
second.artifact_commands.len()
|
|
);
|
|
assert!(
|
|
first.artifact_graph.len() < second.artifact_graph.len(),
|
|
"Second should have all the artifacts of the first, plus more. first={:?}, second={:?}",
|
|
first.artifact_graph.len(),
|
|
second.artifact_graph.len()
|
|
);
|
|
}
|