Merge rust-bitcoin/rust-bitcoin#4049: hashes: Test macros in function scope
8c2439550a
hashes: Test macros in function scope (Tobin C. Harding) Pull request description: The two main public macros can be used in function scope - prove it. While we are at it prove that additional attributes are supported by them both as well as visability keywords. ACKs for top commit: apoelstra: ACK 8c2439550acdf3cb52c78d69eb55160f9d03a139; successfully ran local tests Kixunil: ACK8c2439550a
Tree-SHA512: 66d6a9fd142966f6e68e9a5cb849345a77357dc6e415a10507418425a4cf6a1440deaf47515db43b9ec5b5d337d53164c617db165cb2ff782cf6a6e4ff195c77
This commit is contained in:
commit
bee652d7fd
|
@ -576,6 +576,25 @@ mod test {
|
||||||
fn all_zeros() -> Self { Self::from_byte_array([0; 32]) }
|
fn all_zeros() -> Self { Self::from_byte_array([0; 32]) }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn macros_work_in_function_scope() {
|
||||||
|
use crate::sha256t;
|
||||||
|
|
||||||
|
sha256t_tag! {
|
||||||
|
#[repr(align(2))] // This tests that we can add additional attributes.
|
||||||
|
pub struct FunctionScopeTag = hash_str("It works");
|
||||||
|
}
|
||||||
|
|
||||||
|
hash_newtype! {
|
||||||
|
/// Some docs.
|
||||||
|
#[repr(align(4))] // This tests that we can add additional attributes.
|
||||||
|
pub struct FunctionScopeHash(pub(crate) sha256t::Hash<FunctionScopeTag>);
|
||||||
|
}
|
||||||
|
|
||||||
|
assert_eq!(2, core::mem::align_of::<FunctionScopeTag>());
|
||||||
|
assert_eq!(4, core::mem::align_of::<FunctionScopeHash>());
|
||||||
|
}
|
||||||
|
|
||||||
// NB: This runs with and without `hex` feature enabled, testing different code paths for each.
|
// NB: This runs with and without `hex` feature enabled, testing different code paths for each.
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(feature = "alloc")]
|
#[cfg(feature = "alloc")]
|
||||||
|
|
Loading…
Reference in New Issue