2022-03-11 12:02:47 +01:00
|
|
|
# standard imports
|
|
|
|
import os
|
|
|
|
import logging
|
|
|
|
import unittest
|
|
|
|
|
|
|
|
# external imports
|
|
|
|
from hexathon import add_0x
|
|
|
|
from shep.error import StateTransitionInvalid
|
|
|
|
|
|
|
|
# local imports
|
2022-03-11 20:38:12 +01:00
|
|
|
from chainqueue import QueueEntry
|
|
|
|
|
|
|
|
# test imports
|
|
|
|
from tests.base_shep import TestShepBase
|
2022-03-11 12:02:47 +01:00
|
|
|
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
logg = logging.getLogger()
|
|
|
|
|
|
|
|
|
|
|
|
class TestShep(TestShepBase):
|
|
|
|
|
|
|
|
def test_shep_setup(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
def test_shep_tx(self):
|
|
|
|
tx_hash = add_0x(os.urandom(20).hex())
|
|
|
|
signed_tx = add_0x(os.urandom(128).hex())
|
|
|
|
nonce = 42
|
2022-03-11 20:38:12 +01:00
|
|
|
tx = QueueEntry(self.store, tx_hash)
|
2022-03-11 15:10:16 +01:00
|
|
|
tx.create(nonce, signed_tx)
|
|
|
|
|
2022-03-11 20:38:12 +01:00
|
|
|
tx_retrieved = QueueEntry(self.store, tx_hash)
|
2022-03-11 15:10:16 +01:00
|
|
|
tx_retrieved.load()
|
|
|
|
self.assertEqual(tx_retrieved.signed_tx, signed_tx)
|
2022-03-11 12:02:47 +01:00
|
|
|
|
|
|
|
|
2022-03-11 13:15:44 +01:00
|
|
|
def test_shep_valid(self):
|
|
|
|
self.state.put('foo', 'bar')
|
|
|
|
self.state.set('foo', self.state.IN_NETWORK)
|
|
|
|
self.state.set('foo', self.state.FINAL)
|
|
|
|
|
|
|
|
|
2022-03-11 12:02:47 +01:00
|
|
|
def test_shep_invalid(self):
|
|
|
|
self.state.put('foo', 'bar')
|
|
|
|
self.state.set('foo', self.state.FINAL)
|
|
|
|
with self.assertRaises(StateTransitionInvalid):
|
2022-03-11 12:05:56 +01:00
|
|
|
self.state.move('foo', self.state.INSUFFICIENT_FUNDS)
|
2022-03-11 12:02:47 +01:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|