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

Markers for the First and Last Account/Storage for the State Manager #1192

Draft
wants to merge 83 commits into
base: arith-dev
Choose a base branch
from
Draft
Changes from 1 commit
Commits
Show all changes
83 commits
Select commit Hold shift + click to select a range
f8b4577
Adding transaction level map
arijitdutta67 Sep 10, 2024
b3fee90
adding map update method
arijitdutta67 Sep 10, 2024
58ec254
block level maps—first idea
bogdanbear Sep 11, 2024
56b90f8
fixing minor typos
arijitdutta67 Sep 12, 2024
0c8e16d
remove update from post transaction defer.
bogdanbear Sep 13, 2024
459005c
StateManagerMetadata class
bogdanbear Sep 13, 2024
7e08c94
TxMetadataInStorage
bogdanbear Sep 13, 2024
b7373cd
Generic class for accounts and storage
bogdanbear Sep 13, 2024
4eb9b77
refactor
bogdanbear Sep 13, 2024
850ddf8
refactor
bogdanbear Sep 13, 2024
d556f4a
refactor and (addr, storage) pair
bogdanbear Sep 13, 2024
da23d1d
update for storage
bogdanbear Sep 13, 2024
8f53510
map update for storage fragments
bogdanbear Sep 13, 2024
808611e
adding deployment numbers in StorageFragment
bogdanbear Sep 13, 2024
06773a4
adding comments
arijitdutta67 Sep 16, 2024
9bbcfaa
Min/Max DeplNo maps
bogdanbear Sep 18, 2024
6045a65
adding conflation level map for account
arijitdutta67 Sep 18, 2024
8e3da28
adding the remaining maps for the storage
arijitdutta67 Sep 18, 2024
dbb0f9c
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
arijitdutta67 Sep 19, 2024
d111681
fixing import
arijitdutta67 Sep 19, 2024
0d359f7
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
arijitdutta67 Sep 19, 2024
7ce5ad0
fixing gradlew formatting
arijitdutta67 Sep 19, 2024
5d1d8ff
Fix multi block tests
gauravahuja Sep 23, 2024
704aa6a
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
arijitdutta67 Sep 23, 2024
77ffad9
Adding simple multiblock account test
arijitdutta67 Sep 24, 2024
3f5b9ee
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
arijitdutta67 Sep 25, 2024
765ff27
Fixing conflation-level account maps
bogdanbear Sep 27, 2024
deaffdc
annotations
bogdanbear Sep 27, 2024
659dff2
Adding simple multiblock storage test
arijitdutta67 Sep 27, 2024
bf596c0
Adding storage test with warming of accounts
arijitdutta67 Oct 1, 2024
bd30f8e
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
arijitdutta67 Oct 4, 2024
a9382b5
Bug fix
arijitdutta67 Oct 4, 2024
261fdc6
new multi-block test with solidity integration
bogdanbear Oct 11, 2024
741d473
.yul functions and events, and calls from java
bogdanbear Oct 14, 2024
646e718
refactoring—prepping for tests
bogdanbear Oct 14, 2024
6315837
refactoring
bogdanbear Oct 15, 2024
90abb31
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
bogdanbear Oct 15, 2024
690ba09
refactor after merging from main
bogdanbear Oct 15, 2024
cd34771
refactor to use plugin-generated .yul
bogdanbear Oct 15, 2024
6f3030a
seld destruct
bogdanbear Oct 16, 2024
b162f42
self-destruct calls, to be tested more
bogdanbear Oct 16, 2024
dc969d0
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
bogdanbear Oct 23, 2024
18ac0b6
updating with latest .yul and latest arith-dev
bogdanbear Oct 23, 2024
ec3bd15
Create StateManagerEvents.sol
bogdanbear Oct 23, 2024
9f9ace8
first basic storage test
bogdanbear Oct 24, 2024
c38f025
predict create2 address function wip
bogdanbear Oct 24, 2024
0d4ad1f
testing writes after creates
bogdanbear Oct 24, 2024
94a08a5
debugging create2
bogdanbear Oct 24, 2024
669c360
testing create2 storage
bogdanbear Oct 24, 2024
4c33994
refactor
bogdanbear Oct 24, 2024
6e29c45
bug in bytecode
bogdanbear Oct 24, 2024
3612c88
bug in bytecode
bogdanbear Oct 24, 2024
b643a5d
self destructs
bogdanbear Oct 24, 2024
9728748
typo
bogdanbear Oct 24, 2024
15f9036
adding some reverts
bogdanbear Oct 24, 2024
0c53280
explanations
bogdanbear Oct 24, 2024
5202005
reverts, but the validator is wip
bogdanbear Oct 25, 2024
f8476ba
transfer tests wip
bogdanbear Oct 25, 2024
bc9808a
testing Gaurav's bytecode utilities PR
bogdanbear Oct 28, 2024
3ef5435
fixed nonce bug when running tests all the once
bogdanbear Oct 28, 2024
72dc1b5
found a bug
bogdanbear Oct 28, 2024
300ce6f
account map
bogdanbear Oct 28, 2024
ff547ed
account maps
bogdanbear Oct 29, 2024
9a8dd04
account operations
bogdanbear Oct 29, 2024
50a7660
bug fix
bogdanbear Oct 29, 2024
ae5efd2
better transaction validator
bogdanbear Oct 29, 2024
b93f02c
refactor
bogdanbear Oct 29, 2024
cc62290
refactor to avoid batched testing bug
bogdanbear Oct 29, 2024
5310763
bug fix + debugging blockwise storage
bogdanbear Oct 29, 2024
ac67471
transaction map storage testing
bogdanbear Oct 29, 2024
bb1977f
two tx testing in the txMap
bogdanbear Oct 29, 2024
ff93b7e
refactor asserts
bogdanbear Oct 30, 2024
045487a
refactor
bogdanbear Oct 30, 2024
ca6bb51
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
bogdanbear Oct 30, 2024
405ff2c
fix: added tracing for FIRST/AGAIN/FINAL in the account perspective
OlivierBBB Oct 30, 2024
096942b
fix: added tracing for FIRST/AGAIN/FINAL in the storage perspective
OlivierBBB Oct 30, 2024
aa20124
spotless
OlivierBBB Oct 30, 2024
11a9127
fixing bugs
bogdanbear Oct 31, 2024
279bcea
Merge branch 'arith-dev' into arijit-bogdan/account-first-last
bogdanbear Nov 24, 2024
ce70bfb
fixing compiler errors
bogdanbear Nov 25, 2024
0bf8270
adding the tests from debug branch
bogdanbear Nov 25, 2024
0760c5d
small bug in storage tracing
bogdanbear Nov 26, 2024
aa31579
refactor
bogdanbear Dec 3, 2024
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
Prev Previous commit
Next Next commit
transfer tests wip
bogdanbear committed Oct 25, 2024
commit f8476ba60ec7d57ec87102ca4a959015c78576a6
Original file line number Diff line number Diff line change
@@ -196,6 +196,49 @@ Transaction selfDestruct(ToyAccount sender, KeyPair senderKeyPair, Address desti
return tx;
}

// destination must be our .yul smart contract
Transaction transferTo(ToyAccount sender, KeyPair senderKeyPair, Address destination, Address recipient, long amount, boolean revertFlag, BigInteger callType) {
String recipientAddressString = recipient.toHexString();
Function yulFunction = new Function("transferTo",
Arrays.asList(new org.web3j.abi.datatypes.Address(recipientAddressString), new Uint256(amount), new org.web3j.abi.datatypes.Bool(revertFlag)),
Collections.emptyList());


var encoding = FunctionEncoder.encode(yulFunction);
FrameworkEntrypoint.ContractCall snippetContractCall =
new FrameworkEntrypoint.ContractCall(
/*Address*/ destination.toHexString(),
/*calldata*/ Bytes.fromHexStringLenient(encoding).toArray(),
/*gasLimit*/ BigInteger.ZERO,
/*value*/ BigInteger.ZERO,
/*callType*/ callType); // Normal call, not a delegate call as would be the default

List<FrameworkEntrypoint.ContractCall> contractCalls = List.of(snippetContractCall);
Function frameworkEntryPointFunction =
new Function(
FrameworkEntrypoint.FUNC_EXECUTECALLS,
List.of(new DynamicArray<>(FrameworkEntrypoint.ContractCall.class, contractCalls)),
Collections.emptyList());
Bytes txPayload =
Bytes.fromHexStringLenient(FunctionEncoder.encode(frameworkEntryPointFunction));

ToyTransaction.ToyTransactionBuilder tempTx = ToyTransaction.builder()
.sender(sender)
.to(this.ctxt.frameworkEntryPointAccount)
.payload(txPayload)
.keyPair(senderKeyPair)
.gasLimit(TestContext.gasLimit);

if (TestContext.txNonce != null) {
tempTx = tempTx.nonce(++TestContext.txNonce);
}
Transaction tx = tempTx.build();
if (TestContext.txNonce == null) {
TestContext.txNonce = tx.getNonce();
}
return tx;
}

// destination must be our .yul smart contract
Transaction deployWithCreate2(ToyAccount sender, KeyPair senderKeyPair, Address destination, String saltString, Bytes contractBytes) {
Bytes salt = Bytes.fromHexStringLenient(saltString);
@@ -252,6 +295,7 @@ Transaction deployWithCreate2(ToyAccount sender, KeyPair senderKeyPair, Address
class TestContext {
static Long txNonce = null;
static final Long gasLimit = 5000000L;
static final Wei defaultBalance = Wei.fromEth(3);
static final int numberOfAccounts = 6;
static final Bytes snippetsCode = SmartContractUtils.getYulContractByteCode("StateManagerSnippets.yul");
static final Bytes snippetsCodeForCreate2 = Bytes.fromHexStringLenient("0x61037d61001060003961037d6000f3fe6100076102e1565b63a770741d8114610064576397deb47b81146100715763acf07154811461007d57632d97bf1081146100b45763eba7ff7f81146100e757632b261e94811461012157633ecfd51e811461015b5763ffffffff811461017057600080fd5b61006c610177565b610171565b60005460005260206000f35b6004356024356044356100918183856102c7565b61009b828461019d565b600181036100ac576100ab61034d565b5b505050610171565b6004356024356100c481836102cf565b6100ce81846101da565b600182036100df576100de61034d565b5b505050610171565b6004356024356100f682610253565b600081036101095761010881836102db565b5b6001810361011a5761011961034d565b5b5050610171565b6004356024356044353061013682848661030a565b610141838583610217565b600182036101525761015161034d565b5b50505050610171565b61016361028b565b61016b61037a565b610171565b5b5061037c565b7f0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef600055565b7f577269746528616464726573732c75696e743235362c75696e74323536290000604051818152601e8120308585828460606020a4505050505050565b7f5265616428616464726573732c75696e743235362c75696e7432353629202020604051818152601d8120308585828460606020a4505050505050565b7f50617945544828616464726573732c616464726573732c75696e743235362900604051818152601f81208585858360606020a4505050505050565b7f436f6e747261637444657374726f796564286164647265737329000000000000604051818152601a8120838160606020a250505050565b7f52656345544828616464726573732c75696e743235362900000000000000000060405181815260178120303480828460606020a35050505050565b818155505050565b60008154905092915050565b80ff5050565b60007c010000000000000000000000000000000000000000000000000000000060003504905090565b6040517f3ecfd51e0000000000000000000000000000000000000000000000000000000080825260008060208487875af18061034557600080fd5b505050505050565b7f526576657274696e67000000000000000000000000000000000000000000000060206040518281528181fd5b565b");
@@ -271,7 +315,7 @@ public void initializeTestContext() {
frameworkEntryPointAccount =
ToyAccount.builder()
.address(Address.fromHexString("0x22222"))
.balance(Wei.ONE)
.balance(defaultBalance)
.nonce(5)
.code(SmartContractUtils.getSolidityContractByteCode(FrameworkEntrypoint.class))
.build();
@@ -281,7 +325,7 @@ public void initializeTestContext() {
initialAccounts[0] =
ToyAccount.builder()
.address(Address.fromHexString("0x11111"))
.balance(Wei.ONE)
.balance(defaultBalance)
.nonce(6)
.code(TestContext.snippetsCode)
.build();
@@ -299,7 +343,7 @@ public void initializeTestContext() {
initialAccounts[2] =
ToyAccount.builder()
.address(Address.fromHexString("0x44444"))
.balance(Wei.ONE)
.balance(defaultBalance)
.nonce(8)
.code(SmartContractUtils.getYulContractByteCode("StateManagerSnippets.yul"))
.build();
@@ -330,7 +374,7 @@ TransactionProcessingResultValidator getValidator() {
.equals(logTopic)) {
FrameworkEntrypoint.CallExecutedEventResponse response =
FrameworkEntrypoint.getCallExecutedEventFromLog(Web3jUtils.fromBesuLog(log));
assertTrue(response.isSuccess);
//assertTrue(response.isSuccess);
if (logTopic.equals(createdEventSignature)) {
assertEquals(response.destination, this.ctxt.frameworkEntryPointAccount.getAddress().toHexString());
} else {
@@ -388,7 +432,7 @@ void testCreate2Snippets() {
ctxt.initialKeyPairs[1],
ctxt.frameworkEntryPointAddress,
"0x0000000000000000000000000000000000000000000000000000000000000002",
SmartContractUtils.getYulContractByteCode("StateManagerSnippets.yul"))))
TestContext.snippetsCodeForCreate2)))
.transactionProcessingResultValidator(resultValidator)
.build()
.run();
@@ -437,8 +481,6 @@ void testConflationMap() {
.addBlock(List.of(writeToStorage(ctxt.initialAccounts[1], ctxt.initialKeyPairs[1], ctxt.addresses[4], 400L, 99L, false, BigInteger.ONE)))
// deploy a new account and check revert operations on it
.addBlock(List.of(deployWithCreate2(ctxt.initialAccounts[1], ctxt.initialKeyPairs[1], ctxt.frameworkEntryPointAddress, "0x0000000000000000000000000000000000000000000000000000000000000004", TestContext.snippetsCodeForCreate2)))
.addBlock(List.of(writeToStorage(ctxt.initialAccounts[1], ctxt.initialKeyPairs[1], ctxt.addresses[4], 500L, 53L, true, BigInteger.ONE))) // revert flag on
.addBlock(List.of(writeToStorage(ctxt.initialAccounts[1], ctxt.initialKeyPairs[1], ctxt.addresses[4], 500L, 63L, true, BigInteger.ONE))) // revert flag on
.addBlock(List.of(writeToStorage(ctxt.initialAccounts[1], ctxt.initialKeyPairs[1], ctxt.addresses[5], 500L, 23L, false, BigInteger.ONE)))
.addBlock(List.of(writeToStorage(ctxt.initialAccounts[1], ctxt.initialKeyPairs[1], ctxt.addresses[5], 500L, 53L, true, BigInteger.ONE))) // revert flag on
.addBlock(List.of(writeToStorage(ctxt.initialAccounts[1], ctxt.initialKeyPairs[1], ctxt.addresses[5], 500L, 63L, true, BigInteger.ONE))) // revert flag on
@@ -485,6 +527,32 @@ void testConflationMap() {
}


@Test
void testConflationMapTransfers() {
// initialize the test context
this.ctxt = new TestContext();
this.ctxt.initializeTestContext();
// prepare the transaction validator
TransactionProcessingResultValidator resultValidator = getValidator();
// fetch the Hub metadata for the state manager maps
StateManagerMetadata stateManagerMetadata = Hub.stateManagerMetadata();
// compute the addresses for several accounts that will be deployed later
ctxt.addresses[3] = getCreate2AddressForSnippet("0x0000000000000000000000000000000000000000000000000000000000000002");
ctxt.addresses[4] = getCreate2AddressForSnippet("0x0000000000000000000000000000000000000000000000000000000000000003");
ctxt.addresses[5] = getCreate2AddressForSnippet("0x0000000000000000000000000000000000000000000000000000000000000004");

// prepare a multi-block execution of transactions
MultiBlockExecutionEnvironment.builder()
// initialize accounts
.accounts(List.of(ctxt.initialAccounts[0], ctxt.initialAccounts[1], ctxt.frameworkEntryPointAccount))
// test storage operations for an account prexisting in the state
.addBlock(List.of(transferTo(ctxt.initialAccounts[1], ctxt.initialKeyPairs[1], ctxt.addresses[0], ctxt.addresses[2], 8L, false, BigInteger.ONE)))
.transactionProcessingResultValidator(resultValidator)
.build()
.run();

System.out.println("Done");
}



Loading