-
Notifications
You must be signed in to change notification settings - Fork 52
/
Copy pathbankdivisicoin_tests.py
30 lines (26 loc) · 1.03 KB
/
bankdivisicoin_tests.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import uuid
from ecdsa import SigningKey, SECP256k1
from mybankdivisicoin import TxIn, TxOut, Tx, Bank
# The usual suspects
bob_private_key = SigningKey.generate(curve=SECP256k1)
alice_private_key = SigningKey.generate(curve=SECP256k1)
bob_public_key = bob_private_key.get_verifying_key()
alice_public_key = alice_private_key.get_verifying_key()
def test_bank_balances():
# Create bank and issue Alice some coins
bank = Bank()
coinbase = bank.issue(1000, alice_public_key)
# Alice sends 10 coins to Bob
tx_ins = [
TxIn(tx_id=coinbase.id, index=0, signature=None),
]
tx_id = uuid.uuid4()
tx_outs = [
TxOut(tx_id=tx_id, index=0, amount=10, public_key=bob_public_key),
TxOut(tx_id=tx_id, index=1, amount=990, public_key=alice_public_key),
]
alice_to_bob = Tx(id=tx_id, tx_ins=tx_ins, tx_outs=tx_outs)
alice_to_bob.sign_input(0, alice_private_key)
bank.handle_tx(alice_to_bob)
assert 990 == bank.fetch_balance(alice_public_key)
assert 10 == bank.fetch_balance(bob_public_key)