diff options
Diffstat (limited to 'vendor/wasm-bindgen/tests/wasm/option.rs')
-rw-r--r-- | vendor/wasm-bindgen/tests/wasm/option.rs | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/vendor/wasm-bindgen/tests/wasm/option.rs b/vendor/wasm-bindgen/tests/wasm/option.rs new file mode 100644 index 000000000..4b4cc4379 --- /dev/null +++ b/vendor/wasm-bindgen/tests/wasm/option.rs @@ -0,0 +1,61 @@ +use wasm_bindgen::prelude::*; +use wasm_bindgen_test::*; + +#[wasm_bindgen(module = "tests/wasm/option.js")] +extern "C" { + pub type MyType; + #[wasm_bindgen(constructor)] + fn new() -> MyType; + + fn take_none_byval(t: Option<MyType>); + fn take_some_byval(t: Option<MyType>); + fn return_undef_byval() -> Option<MyType>; + fn return_null_byval() -> Option<MyType>; + fn return_some_byval() -> Option<MyType>; + fn test_option_values(); + + #[wasm_bindgen(js_name = take_none_byval)] + fn take_none_byref(t: Option<&MyType>); + #[wasm_bindgen(js_name = take_some_byval)] + fn take_some_byref(t: Option<&MyType>); +} + +#[wasm_bindgen_test] +fn import_by_value() { + take_none_byval(None); + take_some_byval(Some(MyType::new())); + assert!(return_null_byval().is_none()); + assert!(return_undef_byval().is_none()); + assert!(return_some_byval().is_some()); +} + +#[wasm_bindgen_test] +fn export_by_value() { + test_option_values(); +} + +#[wasm_bindgen] +pub fn rust_take_none_byval(t: Option<MyType>) { + assert!(t.is_none()); +} + +#[wasm_bindgen] +pub fn rust_take_some_byval(t: Option<MyType>) { + assert!(t.is_some()); +} + +#[wasm_bindgen] +pub fn rust_return_none_byval() -> Option<MyType> { + None +} + +#[wasm_bindgen] +pub fn rust_return_some_byval() -> Option<MyType> { + Some(MyType::new()) +} + +#[wasm_bindgen_test] +fn import_by_ref() { + take_none_byref(None); + take_some_byref(Some(&MyType::new())); +} |