use anchor_lang::{AnchorDeserialize, AnchorSerialize, Discriminator, InstructionData};
#[test]
fn test_instruction_data() {
#[derive(Default, AnchorSerialize, AnchorDeserialize, PartialEq, Eq)]
struct MyType {
foo: [u8; 8],
bar: String,
}
impl Discriminator for MyType {
const DISCRIMINATOR: &'static [u8] = &[1, 2, 3, 4, 5, 6, 7, 8];
}
impl InstructionData for MyType {}
let instance = MyType {
foo: [0, 2, 4, 6, 8, 10, 12, 14],
bar: "sharding sucks".into(),
};
let data = instance.data();
let mut write = vec![];
instance.write_to(&mut write);
let correct_disc = &data[0..8] == MyType::DISCRIMINATOR;
let correct_data = MyType::deserialize(&mut &data[8..]).is_ok_and(|result| result == instance);
let correct_serialization = correct_disc & correct_data;
assert!(correct_serialization, "serialization was not correct");
assert_eq!(
&data, &write,
"the different methods produced different serialized representations"
);
}
#[cfg(not(feature = "lazy-account"))]
#[test]
fn test_borsh_attributes() {
#[derive(AnchorSerialize, AnchorDeserialize)]
#[borsh(use_discriminant = true)]
#[repr(u8)]
pub enum Animal {
Cat = 0,
Dog = 1,
Mouse = 5,
}
assert_eq!(borsh::to_vec(&Animal::Cat).unwrap(), vec![0]);
assert_eq!(borsh::to_vec(&Animal::Dog).unwrap(), vec![1]);
assert_eq!(borsh::to_vec(&Animal::Mouse).unwrap(), vec![5]);
}