From 838ed1d75412f8c4ccb3750da6e67687af427520 Mon Sep 17 00:00:00 2001 From: hyd-dev Date: Sun, 15 Aug 2021 17:18:00 +0800 Subject: [PATCH] Update tests for `#[no_mangle]` associated functions --- test-cargo-miri/exported-symbol-dep/src/lib.rs | 4 ++-- tests/run-pass/function_calls/exported_symbol.rs | 14 ++++++++++++++ 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/test-cargo-miri/exported-symbol-dep/src/lib.rs b/test-cargo-miri/exported-symbol-dep/src/lib.rs index db257dcb22c..5b8a314ae73 100644 --- a/test-cargo-miri/exported-symbol-dep/src/lib.rs +++ b/test-cargo-miri/exported-symbol-dep/src/lib.rs @@ -3,11 +3,11 @@ fn exported_symbol() -> i32 { 123456 } -pub struct AssocFn; +struct AssocFn; impl AssocFn { #[no_mangle] - pub fn assoc_fn_as_exported_symbol() -> i32 { + fn assoc_fn_as_exported_symbol() -> i32 { -123456 } } diff --git a/tests/run-pass/function_calls/exported_symbol.rs b/tests/run-pass/function_calls/exported_symbol.rs index 58115542332..ff56bb78a21 100644 --- a/tests/run-pass/function_calls/exported_symbol.rs +++ b/tests/run-pass/function_calls/exported_symbol.rs @@ -15,6 +15,16 @@ fn baz() -> i32 { -3 } +struct AssocFn; + +impl AssocFn { + #[no_mangle] + fn qux() -> i32 { + -4 + } +} + + fn main() { // Repeat calls to make sure the `Instance` cache is not broken. for _ in 0..3 { @@ -32,10 +42,12 @@ fn main() { extern "Rust" { fn bar() -> i32; fn baz() -> i32; + fn qux() -> i32; } assert_eq!(unsafe { bar() }, -2); assert_eq!(unsafe { baz() }, -3); + assert_eq!(unsafe { qux() }, -4); #[allow(clashing_extern_declarations)] { @@ -53,6 +65,7 @@ fn main() { extern "C" { fn bar() -> i32; fn baz() -> i32; + fn qux() -> i32; } unsafe { @@ -61,6 +74,7 @@ fn main() { }; assert_eq!(transmute(bar)(), -2); assert_eq!(transmute(baz)(), -3); + assert_eq!(transmute(qux)(), -4); } } }