fortrangoingonforty/armfortas / 212c858

Browse files

Test trip-16 loop runs correctly under partial unroll at O2

Authored by mfwolffe <wolffemf@dukes.jmu.edu>
SHA
212c85808703f013997a80ae8bca01d5664f895b
Parents
44ff934
Tree
199da21

1 changed file

StatusFile+-
A tests/loop_partial_unroll.rs 39 0
tests/loop_partial_unroll.rsadded
@@ -0,0 +1,39 @@
1
+use std::collections::BTreeSet;
2
+use std::path::PathBuf;
3
+
4
+use armfortas::driver::OptLevel;
5
+use armfortas::testing::{capture_from_path, CaptureRequest, CapturedStage, Stage};
6
+
7
+fn fixture(name: &str) -> PathBuf {
8
+    let path = PathBuf::from("test_programs").join(name);
9
+    assert!(path.exists(), "missing test fixture {}", path.display());
10
+    path
11
+}
12
+
13
+fn capture_run_stdout(request: CaptureRequest) -> String {
14
+    let result = capture_from_path(&request).expect("capture should succeed");
15
+    match result.get(Stage::Run) {
16
+        Some(CapturedStage::Run(run)) => run.stdout.clone(),
17
+        _ => panic!("missing run stage"),
18
+    }
19
+}
20
+
21
+#[test]
22
+fn o2_partial_unrolls_trip16_loop() {
23
+    let source = fixture("loop_partial_unroll.f90");
24
+    let stdout = capture_run_stdout(CaptureRequest {
25
+        input: source,
26
+        requested: BTreeSet::from([Stage::Run]),
27
+        opt_level: OptLevel::O2,
28
+    });
29
+    let trimmed: Vec<&str> = stdout
30
+        .lines()
31
+        .map(|l| l.trim())
32
+        .filter(|l| !l.is_empty())
33
+        .collect();
34
+    assert_eq!(trimmed.len(), 4, "expected 4 print lines:\n{}", stdout);
35
+    assert_eq!(trimmed[0], "1496", "sum 1..16² wrong: {:?}", trimmed[0]);
36
+    assert_eq!(trimmed[1], "1", "a(1) wrong");
37
+    assert_eq!(trimmed[2], "64", "a(8) wrong");
38
+    assert_eq!(trimmed[3], "256", "a(16) wrong");
39
+}