* Fixes symbolic reentrancy example * Fix coverage Issue# 527 * Remove debug unused code * New solidity biased API and reporting * Updated examples to new api WIP * simple_mapping FIXED. new api * Simple transaction example added. msg.value can be symbolic now * Reentrancy symbolic now updated to new API + bugfixes
41 lines
1.1 KiB
Python
41 lines
1.1 KiB
Python
from seth import *
|
|
seth = ManticoreEVM()
|
|
#And now make the contract account to analyze
|
|
source_code = '''
|
|
pragma solidity ^0.4.15;
|
|
contract Overflow {
|
|
event Log(string);
|
|
uint private sellerBalance=0;
|
|
|
|
function add(uint value) returns (bool){
|
|
sellerBalance += value; // complicated math with possible overflow
|
|
|
|
// possible auditor assert
|
|
assert(sellerBalance >= value);
|
|
}
|
|
}
|
|
'''
|
|
#Initialize user and contracts
|
|
user_account = seth.create_account(balance=1000)
|
|
contract_account = seth.solidity_create_contract(source_code, owner=user_account, balance=0)
|
|
|
|
#First add wont owerflow uint256 representation
|
|
contract_account.add(seth.SValue)
|
|
|
|
#Potential overflow
|
|
contract_account.add(seth.SValue)
|
|
|
|
|
|
print "[+] There are %d reverted states now"% len(seth.final_state_ids)
|
|
for state_id in seth.final_state_ids:
|
|
seth.report(state_id)
|
|
|
|
print "[+] There are %d alive states now"% len(seth.running_state_ids)
|
|
for state_id in seth.running_state_ids:
|
|
seth.report(state_id)
|
|
|
|
print "[+] Global coverage: %x"% contract_account
|
|
print seth.coverage(contract_account)
|
|
|
|
|