From c90c0149efc2eef50cdf0425bda85d3b82f4c549 Mon Sep 17 00:00:00 2001 From: Aumetra Weisman Date: Thu, 25 Apr 2024 11:21:42 +0200 Subject: [PATCH] Test attribute on non-migrate function --- packages/derive/src/lib.rs | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/packages/derive/src/lib.rs b/packages/derive/src/lib.rs index a01999b7e7..e43499af41 100644 --- a/packages/derive/src/lib.rs +++ b/packages/derive/src/lib.rs @@ -131,7 +131,7 @@ fn expand_attributes(func: &mut ItemFn) -> syn::Result { if func.sig.ident != "migrate" { return Err(syn::Error::new_spanned( &attribute, - "you only want to add this macro to your migrate function", + "you only want to add this attribute to your migrate function", )); } @@ -192,6 +192,23 @@ mod test { use crate::entry_point_impl; + #[test] + fn contract_state_version_on_non_migratee() { + let code = quote! { + #[state_version(42)] + fn anything_else() -> Response { + // Logic here + } + }; + + let actual = entry_point_impl(TokenStream::new(), code); + let expected = quote! { + ::core::compile_error! { "you only want to add this attribute to your migrate function" } + }; + + assert_eq!(actual.to_string(), expected.to_string()); + } + #[test] fn contract_state_version_in_u64() { let code = quote! {