test_proto.py 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. from time import sleep
  2. import logging
  3. #logging.basicConfig(level=logging.DEBUG)
  4. from src.protocol import Protocol
  5. from src.mining import Miner
  6. from src.block import GENESIS_BLOCK
  7. from src.crypto import Signing
  8. from src.transaction import Transaction, TransactionInput, TransactionTarget
  9. def test_proto():
  10. reward_key = Signing.generate_private_key()
  11. proto1 = Protocol([], GENESIS_BLOCK, 1337)
  12. proto2 = Protocol([("127.0.0.1", 1337)], GENESIS_BLOCK, 1338)
  13. miner1 = Miner(proto1, reward_key)
  14. miner2 = Miner(proto2, reward_key)
  15. miner2.start_mining()
  16. miner1.start_mining()
  17. try:
  18. sleep(5)
  19. target_key = Signing.generate_private_key()
  20. chain = miner1.chainbuilder.primary_block_chain
  21. reward_trans = chain.blocks[20].transactions[0]
  22. trans_in = TransactionInput(reward_trans.get_hash(), 0)
  23. trans_targ = TransactionTarget(target_key, reward_trans.targets[0].amount)
  24. trans = Transaction([trans_in], [trans_targ])
  25. trans.sign([reward_key])
  26. assert trans.verify(chain, set()), "transaction should be valid"
  27. proto2.received('transaction', trans.to_json_compatible(), None)
  28. sleep(5)
  29. chain_len1 = len(miner1.chainbuilder.primary_block_chain.blocks)
  30. chain_len2 = len(miner2.chainbuilder.primary_block_chain.blocks)
  31. print("Length of chain of miner 1: {}".format(chain_len1))
  32. print("Length of chain of miner 2: {}".format(chain_len2))
  33. finally:
  34. miner1.stop_mining()
  35. miner2.stop_mining()
  36. assert max(chain_len1, chain_len2) * 90 // 100 < min(chain_len1, chain_len2), "chain lengths are VERY different"
  37. chain1 = miner1.chainbuilder.primary_block_chain
  38. hashes1 = [b.hash for b in chain1.blocks[:chain_len1 * 90 // 100]]
  39. hashes2 = [b.hash for b in miner2.chainbuilder.primary_block_chain.blocks[:chain_len1 * 90 // 100]]
  40. assert hashes1 == hashes2, "first 90% of chains should be identical"
  41. assert not trans.verify(miner1.chainbuilder.primary_block_chain, set()), "inserted transaction should be spent and therefore invalid"
  42. assert TransactionInput(trans.get_hash(), 0) in chain1.unspent_coins, "someone spent our coins?"