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

Adapting the test to the latest client code #7

Draft
wants to merge 126 commits into
base: develop
Choose a base branch
from
Draft
Changes from 1 commit
Commits
Show all changes
126 commits
Select commit Hold shift + click to select a range
c8b4b4d
Committing KaaS Compute Setup for RV Testing / Development
F-WRunTime Jun 12, 2024
c2db612
Test using variables to get org name / repo name
F-WRunTime Jun 12, 2024
bb73582
Merge conflict resolution
F-WRunTime Jun 12, 2024
ef5a282
Revert changes to lido-ci.yml for merge into parent repo
lucasmt Jun 12, 2024
740b5c5
Committing KaaS Compute Setup for RV Testing / Development
F-WRunTime Jun 12, 2024
3e2804d
Test using variables to get org name / repo name
F-WRunTime Jun 12, 2024
979bd73
Merge conflict resolution
F-WRunTime Jun 12, 2024
bef8491
Adding workflow_dispatch event triggers
F-WRunTime Jun 14, 2024
49c836f
Add StETH token model
lucasmt Jun 17, 2024
29d4c76
Add new version of Escrow model using rebasable StETH token
lucasmt Jun 17, 2024
dd713cf
Rename original Escrow model to EscrowNonRebasable.sol
lucasmt Jun 18, 2024
e145cbc
Make the Escrow version using StETH the default Escrow contract in th…
lucasmt Jun 18, 2024
ee7d042
Adapt VetoSignalling tests to StETH
lucasmt Jun 18, 2024
51c4470
Split off test set-up and helper functions into separate base contract
lucasmt Jun 18, 2024
ac347ff
Reduce SMT timeout in run-kontrol.sh script
lucasmt Jun 18, 2024
b074a16
Add test to run-kontrol.sh script
lucasmt Jun 18, 2024
1cc7737
Update versions.json to the latest kontrol version
lucasmt Jun 18, 2024
4eff4c7
Adjust StETH model to be closer to original StETH contract
lucasmt Jun 21, 2024
748790e
renaming contracts for easier use with Kontrol
PetarMax Jun 21, 2024
19fb17a
additional lemma for cleaning up specification of getRageQuitSupport
PetarMax Jun 22, 2024
e26f832
assumptions
PetarMax Jun 22, 2024
5f84969
Refactor DualGovernanceSetUp into 3 contracts for more fine-grained f…
lucasmt Jun 24, 2024
a8b7377
Make Escrow storage setup compatible with the new storage layout of t…
lucasmt Jun 24, 2024
f26be16
Fix assumptions on StETHModel to avoid division by 0 problem
lucasmt Jun 25, 2024
ac4dde4
Rename variable in comment of DualGovernanceSetUp
lucasmt Jun 25, 2024
538c657
Add --verbose and --max-frontier-parallel options to run-kontrol.sh s…
lucasmt Jun 25, 2024
28ee0ed
further limiting branching
PetarMax Jun 22, 2024
7ab371f
additional constraints to minimise calls to calculateDynamicTimelock
PetarMax Jun 22, 2024
5e3c1e8
merge
PetarMax Jun 26, 2024
a825995
Update unlock function in EscrowModel to unlock all of the user's shares
lucasmt Jul 1, 2024
eb9461c
Add EscrowAccountingTest
lucasmt Jul 1, 2024
7320f8d
Add EscrowAccounting tests to run-kontrol.sh script
lucasmt Jul 1, 2024
5317bd2
Add EscrowOperationsTest and update Setup
qian-hu Jul 4, 2024
235f93d
Add EscrowOperations tests to run-kontrol.sh script
qian-hu Jul 4, 2024
9e0f326
Add postconditions to testLockStEth and testUnlockStEth, accounting f…
lucasmt Jul 5, 2024
2946832
Adapt tests from model to client code
lucasmt Jul 8, 2024
9c3062c
Add VetoCooldownTest
lucasmt Jul 8, 2024
51e37c5
Merge branch 'develop' into tests-on-client-code
lucasmt Jul 8, 2024
6fa07ac
Adapt to latest updates
lucasmt Jul 8, 2024
22d1d3b
Remove VetoCooldown test from list for now
lucasmt Jul 8, 2024
fb9de96
Fix issues in DualGovernanceModel and EmergencyProtectedTimelockModel
qian-hu Jul 9, 2024
89217a2
Update kontrol to latest version
lucasmt Jul 10, 2024
d7ee973
Move top-level Status enum inside WithdrawalBatchesQueue library
lucasmt Jul 10, 2024
d6d86de
Add constants to WithdrawalQueue model
lucasmt Jul 10, 2024
ef49604
Fix issues in setUp() function
lucasmt Jul 10, 2024
efc341d
Set a concrete block.chainid in EscrowAccountingTest
lucasmt Jul 10, 2024
97f97ec
Relabel comments on STORAGE and WORD symbolic variables
lucasmt Jul 10, 2024
625220e
Relabel STORAGE and WORD comments on EscrowAccountingTest as well
lucasmt Jul 10, 2024
cd197c0
Remove unused arguments in storage setup functions
lucasmt Jul 10, 2024
0fa97c4
Fixed assumptions on _signallingEscrowStorageSetup to adapt to the cl…
lucasmt Jul 10, 2024
bc55c63
polishing of lemmas
PetarMax Jul 10, 2024
ef29411
Limiting times to year 3058
PetarMax Jul 10, 2024
326d8ae
correction
PetarMax Jul 11, 2024
9a24862
one more correction
PetarMax Jul 11, 2024
a49c11c
Add RageQuitTest
lucasmt Jul 12, 2024
9ad09b0
Add additional EscrowAccounting tests
lucasmt Jul 12, 2024
03f7acf
Add batchesQueue to storage setup
lucasmt Jul 15, 2024
08fba87
Update comment on EscrowAccountingTest to account for batchesQueue
lucasmt Jul 15, 2024
f3caac7
StorageSetup: Status -> WithdrawalsBatchesQueue.Status
lucasmt Jul 15, 2024
31a3351
Changes to reproduce mockFunction crash
lucasmt Jul 17, 2024
cef5dd0
New version of kontrol-cheatcodes
lucasmt Jul 17, 2024
3d2f27b
Refactor tests for using mockFunction cheatcode
lucasmt Jul 20, 2024
5336955
Move assumptions back to ...StorageSetup functions to avoid TooManyIt…
lucasmt Jul 21, 2024
ed2cb4e
further externals
PetarMax Jul 22, 2024
be33180
further external calls
PetarMax Jul 23, 2024
acad7bb
removing mock
PetarMax Jul 23, 2024
76553bc
minor adjustments
PetarMax Jul 23, 2024
05baf70
Adapt EscrowOperations tests to latest updates
qian-hu Jul 23, 2024
6baf163
Revert EscrowOperationsTest base to EscrowAccountingTest
qian-hu Jul 23, 2024
b170211
simplified mocks and more
PetarMax Jul 24, 2024
12b447b
full test with full mock
PetarMax Jul 24, 2024
97feb0d
full test
PetarMax Jul 24, 2024
b19c812
unlock test, further simplifications, streamlining of fresh variables
PetarMax Jul 26, 2024
cc713a5
merge with tests-on-client-code
PetarMax Jul 26, 2024
d127e46
further merging
PetarMax Jul 26, 2024
acaf186
corrections
PetarMax Jul 26, 2024
cfdb6a1
Revert EscrowOperationsTest base to EscrowAccountingTest
qian-hu Jul 23, 2024
83e85fa
further corrections
PetarMax Jul 26, 2024
b6c977d
Merge remote-tracking branch 'origin/petar/external-functions-in-setu…
PetarMax Jul 26, 2024
f4e2678
Refine assumptions in testUnlockStEth
lucasmt Jul 27, 2024
7895266
Fix asserts in testUnlockStEth
lucasmt Jul 29, 2024
d27e88b
Fix typo in testVetoCooldownDuration
lucasmt Jul 29, 2024
0ca16a0
tests
PetarMax Jul 29, 2024
34e3adf
much better slot update lemmas, version 1
PetarMax Jul 29, 2024
15351bc
more tests and lemmas
PetarMax Jul 29, 2024
c55fe77
corrections to storage slot 8
PetarMax Jul 29, 2024
de0de8d
escrow correctness test
PetarMax Jul 30, 2024
38d0724
isolating rageQuit cases
PetarMax Jul 30, 2024
d2160f8
simplification correction
PetarMax Jul 30, 2024
1bd6f38
Move to master branch to run code
F-WRunTime Jul 31, 2024
37a27e3
KOntrol version > 0.1.380
F-WRunTime Jul 31, 2024
d4ee537
Fix calculation for rage quit support
qian-hu Aug 1, 2024
e4762ca
invariant check correction
PetarMax Aug 2, 2024
eb7ebd3
rearranging testDeactivationNotCancelled
PetarMax Aug 3, 2024
ad10520
Update test and summary for unlockStETH
lucasmt Aug 6, 2024
3bfceaf
Add missing bound in StorageSetup
lucasmt Aug 6, 2024
bc09d7a
Add lemmas for testUnlockStEth
lucasmt Aug 6, 2024
6f5cb23
Add stETH assumptions and invariants
lucasmt Aug 6, 2024
e73ae0a
redesigning establish
PetarMax Aug 5, 2024
73aef2a
gradually establishing invariants
PetarMax Aug 7, 2024
485e593
adding VetoSignalling invariant
PetarMax Aug 8, 2024
aa72a4d
VetoCooldown
PetarMax Aug 8, 2024
a7d9694
Update CI configurations
qian-hu Aug 8, 2024
18e0047
testDeactivationNotCancelled
PetarMax Aug 8, 2024
e61ea55
removing fourth invariant from ...ArePreserved
PetarMax Aug 8, 2024
b3c083d
Add ProposalOperations tests
qian-hu Aug 9, 2024
0dc5424
Refactor ProposalOperation tests
qian-hu Aug 9, 2024
9cbf486
proposal tests, mirroring mechanism
PetarMax Aug 9, 2024
c0dca20
corrections
PetarMax Aug 10, 2024
25ac0b5
corrections
PetarMax Aug 10, 2024
98d46e3
correction
PetarMax Aug 10, 2024
8ac38de
corrections
PetarMax Aug 12, 2024
b3394e6
new tests
PetarMax Aug 13, 2024
c2fd803
Add assumptions to EscrowAccountingTest
qian-hu Aug 16, 2024
ad66780
Update CI configurations
qian-hu Aug 16, 2024
0fda36c
Update dependencies
qian-hu Aug 16, 2024
473bcd7
Add kontrol.toml, restructure scripts, and update CI config
qian-hu Aug 16, 2024
1c9abbc
tweaking parameters
PetarMax Aug 16, 2024
272c711
lemma correction
PetarMax Aug 21, 2024
63727d8
lemma corrections
PetarMax Aug 21, 2024
9ac62f3
Update Kontrol version
qian-hu Aug 21, 2024
a6eb909
adjusting lemmas to Kontrol 1.0
PetarMax Aug 24, 2024
088597b
adding auxiliary lemmas
PetarMax Sep 2, 2024
b03139f
minor corrections, adding syntactics
PetarMax Sep 3, 2024
2922d2e
Update Kontrol version
qian-hu Sep 30, 2024
d48291a
Update lido-ci.yml and run-kontrol.sh
qian-hu Oct 2, 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
Fix asserts in testUnlockStEth
lucasmt committed Jul 29, 2024
commit 7895266345200b19c630127547f03269a4e6d123
15 changes: 8 additions & 7 deletions test/kontrol/EscrowLockUnlock.t.sol
Original file line number Diff line number Diff line change
@@ -191,13 +191,14 @@ contract EscrowLockUnlockTest is EscrowInvariants, DualGovernanceSetUp {

// Accounts for rounding errors in the conversion to and from shares
uint256 amount = stEth.getPooledEthByShares(pre.userSharesLocked);
assert(pre.escrowBalance - amount <= post.escrowBalance);
assert(pre.totalEth - amount <= post.totalEth);
assert(post.userBalance <= post.userBalance + amount);

uint256 errorTerm = stEth.getPooledEthByShares(1) + 1;
assert(post.escrowBalance <= pre.escrowBalance - amount + errorTerm);
assert(post.totalEth <= pre.totalEth - amount + errorTerm);
assert(pre.userBalance + amount < errorTerm || pre.userBalance + amount - errorTerm <= post.userBalance);
assert(pre.escrowBalance - amount < 1 || pre.escrowBalance - amount - 1 <= post.escrowBalance);
assert(post.escrowBalance <= pre.escrowBalance - amount);

assert(pre.totalEth - amount < 1 || pre.totalEth - amount - 1 <= post.totalEth);
assert(post.totalEth <= pre.totalEth - amount);

assert(pre.userBalance + amount <= post.userBalance);
assert(post.userBalance <= pre.userBalance + amount + 1);
}
}