aboutsummaryrefslogtreecommitdiff
path: root/src/type/case.rs
diff options
context:
space:
mode:
authorJoel Kronqvist <joel.kronqvist@iki.fi>2025-08-19 13:55:05 +0300
committerJoel Kronqvist <joel.kronqvist@iki.fi>2025-08-19 13:55:05 +0300
commita70dcaa949f41c585f9aea5e79f2550053d8e857 (patch)
tree9366f0b1e026c009708ebc243d006a79cbf452c9 /src/type/case.rs
parentd4d6e972650370d529363f7db3946e58bdbd7bca (diff)
downloadmyslip-a70dcaa949f41c585f9aea5e79f2550053d8e857.tar.gz
myslip-a70dcaa949f41c585f9aea5e79f2550053d8e857.zip
test: added boilerplate and tests for coproduct parsing, type checking and evaluation
Diffstat (limited to 'src/type/case.rs')
-rw-r--r--src/type/case.rs18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/type/case.rs b/src/type/case.rs
index c53bbd0..d8871af 100644
--- a/src/type/case.rs
+++ b/src/type/case.rs
@@ -324,4 +324,22 @@ mod tests {
Ok(vec![])
);
}
+
+ #[test]
+ fn test_sumtype_match() {
+ assert_eq!(
+ scons(Inl, scons(var("x"), Nil)).matches_type(&sumtype(Integer, Boolean)),
+ Ok(vec![("x".to_string(), Integer)])
+ );
+ assert_eq!(
+ scons(Inr, scons(var("x"), Nil)).matches_type(&sumtype(Integer, Boolean)),
+ Ok(vec![("x".to_string(), Boolean)])
+ );
+ assert!(
+ scons(Inl, scons(True, Nil)).matches_type(&sumtype(Integer, Boolean)).is_err()
+ );
+ assert!(
+ scons(Inr, scons(1, Nil)).matches_type(&sumtype(Integer, Boolean)).is_err()
+ );
+ }
}