Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Token 22: Add functionality to update extra_account_metas after initializing. #5894

Merged
merged 40 commits into from
Dec 7, 2023
Merged
Changes from 1 commit
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
e6bba4a
Added update function for ExtraAccountMetaList
tonton-sol Nov 26, 2023
fda5712
Updated interface to handle new update instruction
tonton-sol Nov 26, 2023
cf13287
Updated Cli to handle update command
tonton-sol Nov 26, 2023
84d8ac0
updated example program to handle updating
tonton-sol Nov 26, 2023
ca29fdc
Rust fmt trailing whitespace fix
tonton-sol Nov 27, 2023
2882a06
Removed unused variable
tonton-sol Nov 27, 2023
986e639
Added more explicit update instruction doc comment
tonton-sol Nov 27, 2023
3b177ce
Allow for resizing to smaller account size
tonton-sol Nov 28, 2023
5dc4a1a
Removed system program from update instruction
tonton-sol Nov 28, 2023
12c84cd
Added helper fn to calculate transfer lamports
tonton-sol Nov 28, 2023
155319d
Added unit tests for update function
tonton-sol Nov 28, 2023
2f3e041
Added unit test for update instruction
tonton-sol Nov 28, 2023
8b477d5
removed unnecessary commented out code
tonton-sol Nov 28, 2023
3a438b7
re-added checks on initialization
tonton-sol Nov 28, 2023
6334120
turned of zero_init for realloc for performance
tonton-sol Nov 28, 2023
b34c50c
Fixed update doc comments
tonton-sol Nov 29, 2023
2003517
Used block-scoping rather than explicit drop()
tonton-sol Nov 29, 2023
a69cfef
Removed unnecessary convert to vec
tonton-sol Nov 29, 2023
32d638b
refactored updated test into single test
tonton-sol Nov 29, 2023
93dfae6
added additional off-chain test of update instruct
tonton-sol Nov 29, 2023
666a36b
made on-chain invoke update test to match original
tonton-sol Nov 29, 2023
4262199
moved helper function up to others
tonton-sol Nov 29, 2023
54e77be
refactored create and update with helpers
tonton-sol Nov 29, 2023
de0e2f8
rustfmt: fix
tonton-sol Nov 30, 2023
f5b1a36
rustfmt: fix
tonton-sol Nov 30, 2023
f20c007
removed commented out system program in update
tonton-sol Nov 30, 2023
5e62a04
renamed helpers and removed unnecessary helper
tonton-sol Nov 30, 2023
1ba6c59
moved test helper up
tonton-sol Dec 1, 2023
9a22ce8
fixed test attribute location
tonton-sol Dec 1, 2023
9cf2129
removed multiple init extra account metas in test
tonton-sol Dec 1, 2023
4350929
added instruction assert to update test
tonton-sol Dec 1, 2023
a3e6c7e
renamed transfer address to extra account metas
tonton-sol Dec 2, 2023
58d7011
rustfmt: comment fix
tonton-sol Dec 3, 2023
451aaf4
clippy: fix
tonton-sol Dec 3, 2023
9fe5c86
added update test with simple PDA
tonton-sol Dec 3, 2023
a944952
made more changes to updated metas in test
tonton-sol Dec 3, 2023
ce76bf9
added check for if extra metas have be initialized
tonton-sol Dec 3, 2023
b8299b3
Merge branch 'master' into master
tonton-sol Dec 5, 2023
20d9185
spelling fix
tonton-sol Dec 7, 2023
9a508de
fixed initialized condition
tonton-sol Dec 7, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
131 changes: 131 additions & 0 deletions libraries/tlv-account-resolution/src/state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1308,6 +1308,137 @@ mod tests {
}
}

#[tokio::test]
async fn update_extra_account_meta_list() {
// Create new ExtraAccountMeta
let metas = [
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), false, true).unwrap(),
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), true, false).unwrap(),
];

// Create a buffer and get its size
let account_size = ExtraAccountMetaList::size_of(metas.len()).unwrap();
let mut buffer = vec![0; account_size];

// Initialize
ExtraAccountMetaList::init::<TestInstruction>(&mut buffer, &metas).unwrap();

// Create new metas to overwrite the initial
let updated_metas = [
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), true, true).unwrap(),
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), false, false).unwrap(),
];

// Update
ExtraAccountMetaList::update::<TestInstruction>(&mut buffer, &updated_metas).unwrap();

// Get the tlv state then unpack
let state = TlvStateBorrowed::unpack(&buffer).unwrap();
let unpacked_metas =
ExtraAccountMetaList::unpack_with_tlv_state::<TestInstruction>(&state).unwrap();

// Convert to Vec<ExtraAccountMeta>
let unpacked_metas_vec = unpacked_metas.data().to_vec();

// Assert that the unpacked metas match the updated metas
assert_eq!(unpacked_metas_vec, updated_metas.to_vec(), "The updated ExtraAccountMetas in the buffer should match the ones provided to the update function.");
tonton-sol marked this conversation as resolved.
Show resolved Hide resolved
}

#[tokio::test]
async fn update_extra_account_meta_list_to_larger() {
tonton-sol marked this conversation as resolved.
Show resolved Hide resolved
// Create new ExtraAccountMeta
let initial_metas = [
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), false, true).unwrap(),
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), true, false).unwrap(),
];

// Create a buffer and get its size
let initial_account_size = ExtraAccountMetaList::size_of(initial_metas.len()).unwrap();
let mut buffer = vec![0; initial_account_size];

// Initialize
ExtraAccountMetaList::init::<TestInstruction>(&mut buffer, &initial_metas).unwrap();

// Create new metas to overwrite the initial, adding one
let updated_metas = [
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), true, true).unwrap(),
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), false, false).unwrap(),
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), false, true).unwrap(),
];

// Calculate the new size
let updated_account_size = ExtraAccountMetaList::size_of(updated_metas.len()).unwrap();

// Must resize buffer first
buffer.resize(updated_account_size, 0);

// Update
ExtraAccountMetaList::update::<TestInstruction>(&mut buffer, &updated_metas).unwrap();

// Get the tlv state then unpack
let state = TlvStateBorrowed::unpack(&buffer).unwrap();
let unpacked_metas =
ExtraAccountMetaList::unpack_with_tlv_state::<TestInstruction>(&state).unwrap();

// Convert to Vec<ExtraAccountMeta>
let unpacked_metas_vec = unpacked_metas.data().to_vec();
tonton-sol marked this conversation as resolved.
Show resolved Hide resolved

// Assert that the unpacked metas match the updated metas and their lengths
assert_eq!(
unpacked_metas_vec.len(),
updated_metas.len(),
"The length of the updated ExtraAccountMetas should match the updated array length."
);
assert_eq!(unpacked_metas_vec, updated_metas.to_vec(), "The updated ExtraAccountMetas in the buffer should match the ones provided to the update function.");
}

#[tokio::test]
async fn update_extra_account_meta_list_to_smaller() {
// Create new ExtraAccountMeta
let initial_metas = [
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), false, true).unwrap(),
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), true, false).unwrap(),
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), true, true).unwrap(),
];

// Create a buffer and get its size
let initial_account_size = ExtraAccountMetaList::size_of(initial_metas.len()).unwrap();
let mut buffer = vec![0; initial_account_size];

// Initialize
ExtraAccountMetaList::init::<TestInstruction>(&mut buffer, &initial_metas).unwrap();

// Create new metas to overwrite the initial, with one fewer
let updated_metas = [
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), true, true).unwrap(),
ExtraAccountMeta::new_with_pubkey(&Pubkey::new_unique(), false, false).unwrap(),
];

// Resizing the buffer gives InvalidAccountData from
// `let mut state = TlvStateMut::unpack(data).unwrap();`.
// This is because the size is checked against byte 9 in the buffer
// Not sure if this is the ideal behavior

// Update
ExtraAccountMetaList::update::<TestInstruction>(&mut buffer, &updated_metas).unwrap();

// Get the tlv state then unpack
let state = TlvStateBorrowed::unpack(&buffer).unwrap();
let unpacked_metas =
ExtraAccountMetaList::unpack_with_tlv_state::<TestInstruction>(&state).unwrap();

// Convert to Vec<ExtraAccountMeta>
let unpacked_metas_vec = unpacked_metas.data().to_vec();

// Assert that the unpacked metas match the updated metas and their lengths
assert_eq!(
unpacked_metas_vec.len(),
updated_metas.len(),
"The length of the updated ExtraAccountMetas should match the updated array length."
);
assert_eq!(unpacked_metas_vec, updated_metas.to_vec(), "The updated ExtraAccountMetas in the buffer should match the ones provided to the update function.");
}

#[test]
fn check_account_infos_test() {
let program_id = Pubkey::new_unique();
Expand Down