From 22154f14dd11f45230491cf0e93038ccfee8c85a Mon Sep 17 00:00:00 2001 From: Andreas Grois Date: Mon, 20 Mar 2023 23:27:45 +0100 Subject: Partial support for multiple generic parameters. --- tests/multiple_generics.rs | 65 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 tests/multiple_generics.rs (limited to 'tests') diff --git a/tests/multiple_generics.rs b/tests/multiple_generics.rs new file mode 100644 index 0000000..ce13414 --- /dev/null +++ b/tests/multiple_generics.rs @@ -0,0 +1,65 @@ +//! Tests if multiple generic parameters work, for the case that lifetimes are independent of mapping functions. +//! For simplicity, it just creates a FreeResult + +use higher_free_macro::free; +use higher::{Functor, Bind, Apply}; + +free!(FreeResult, Result,E>); + +#[test] +fn test_multiple_generics(){ + let m : FreeResult<_, String> = FreeResult::lift_f(Ok(37u32)); + let m = m.fmap(|x| x*2); + let m = m.bind(|x| FreeResult::Free(Box::new(Ok(FreeResult::Pure(x))))); + let f = FreeResult::Pure((|x| x*3).into()); + let m = m.apply(f); + match m { + FreeResult::Free(b) => { + match *b { + Ok(f) => { + match f { + FreeResult::Free(b) => { + match *b { + Ok(f) => { + match f{ + FreeResult::Pure(x) => assert_eq!(x, 37*6), + _ => unreachable!() + } + } + _ => unreachable!() + } + }, + _ => unreachable!() + } + } + _ => unreachable!() + } + } + _ => unreachable!() + } +} + +#[test] +fn test_multiple_generics2(){ + let m : FreeResult<_, String> = FreeResult::lift_f(Ok(37u32)); + let m = m.bind(|_| FreeResult::::lift_f(Err("An early out.".to_owned()))); + match m{ + FreeResult::Free(m) => { + match &*m { + Ok(m) => { + match m{ + FreeResult::Free(m) => { + match &**m { + Err(e) => assert_eq!(e, "An early out."), + _ => unreachable!() + } + } + _ => unreachable!() + } + }, + _ => unreachable!() + } + }, + _ => unreachable!() + } +} \ No newline at end of file -- cgit v1.2.3