2020-08-04 23:41:31 +02:00
|
|
|
#!/usr/bin/python
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from rlp import encode as rlp_encode
|
|
|
|
|
2020-08-08 11:33:15 +02:00
|
|
|
from crypto_dev_signer.eth.signer import ReferenceSigner
|
|
|
|
from crypto_dev_signer.eth.transaction import EIP155Transaction
|
2020-08-04 23:41:31 +02:00
|
|
|
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
logg = logging.getLogger()
|
|
|
|
|
|
|
|
|
2020-10-26 09:02:29 +01:00
|
|
|
tx_ints = {
|
|
|
|
'nonce': 0,
|
2020-08-04 23:41:31 +02:00
|
|
|
'from': "0xEB014f8c8B418Db6b45774c326A0E64C78914dC0",
|
|
|
|
'gasPrice': "20000000000",
|
2020-10-26 09:02:29 +01:00
|
|
|
'gas': "21000",
|
2020-08-04 23:41:31 +02:00
|
|
|
'to': '0x3535353535353535353535353535353535353535',
|
|
|
|
'value': "1000",
|
|
|
|
'data': "deadbeef",
|
|
|
|
}
|
|
|
|
|
2020-10-26 09:02:29 +01:00
|
|
|
tx_hexs = {
|
|
|
|
'nonce': '0x0',
|
|
|
|
'from': "0xEB014f8c8B418Db6b45774c326A0E64C78914dC0",
|
|
|
|
'gasPrice': "0x4a817c800",
|
|
|
|
'gas': "0x5208",
|
|
|
|
'to': '0x3535353535353535353535353535353535353535',
|
|
|
|
'value': "0x3e8",
|
|
|
|
'data': "deadbeef",
|
|
|
|
}
|
|
|
|
|
2020-08-06 11:07:18 +02:00
|
|
|
class pkGetter:
|
|
|
|
|
|
|
|
def __init__(self, pk):
|
|
|
|
self.pk = pk
|
|
|
|
|
|
|
|
def get(self, address, password=None):
|
|
|
|
return self.pk
|
|
|
|
|
|
|
|
|
2020-08-04 23:41:31 +02:00
|
|
|
class TestSign(unittest.TestCase):
|
|
|
|
|
|
|
|
pk = None
|
|
|
|
nonce = -1
|
2020-08-06 11:07:18 +02:00
|
|
|
pk_getter = None
|
2020-08-04 23:41:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
def getNonce(self):
|
|
|
|
self.nonce += 1
|
|
|
|
return self.nonce
|
|
|
|
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.pk = bytes.fromhex('5087503f0a9cc35b38665955eb830c63f778453dd11b8fa5bd04bc41fd2cc6d6')
|
2020-08-06 11:07:18 +02:00
|
|
|
self.pk_getter = pkGetter(self.pk)
|
2020-08-04 23:41:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
logg.info('teardown empty')
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-08-06 11:07:18 +02:00
|
|
|
# TODO: verify rlp tx output
|
2020-08-04 23:41:31 +02:00
|
|
|
def test_serialize_transaction(self):
|
2020-10-26 09:02:29 +01:00
|
|
|
t = EIP155Transaction(tx_ints, 0)
|
|
|
|
self.assertRegex(t.__class__.__name__, "Transaction")
|
|
|
|
s = t.serialize()
|
2021-01-12 14:50:52 +01:00
|
|
|
self.assertEqual('{}'.format(s), "{'nonce': '', 'gasPrice': '0x04a817c800', 'gas': '0x5208', 'to': '0x3535353535353535353535353535353535353535', 'value': '0x03e8', 'data': '0xdeadbeef', 'v': '0x01', 'r': '', 's': ''}")
|
2020-10-26 09:02:29 +01:00
|
|
|
r = t.rlp_serialize()
|
|
|
|
self.assertEqual(r.hex(), 'ea808504a817c8008252089435353535353535353535353535353535353535358203e884deadbeef018080')
|
|
|
|
|
|
|
|
t = EIP155Transaction(tx_hexs, 0)
|
2020-08-04 23:41:31 +02:00
|
|
|
self.assertRegex(t.__class__.__name__, "Transaction")
|
2020-08-06 11:07:18 +02:00
|
|
|
s = t.serialize()
|
2021-01-12 14:50:52 +01:00
|
|
|
self.assertEqual('{}'.format(s), "{'nonce': '', 'gasPrice': '0x04a817c800', 'gas': '0x5208', 'to': '0x3535353535353535353535353535353535353535', 'value': '0x03e8', 'data': '0xdeadbeef', 'v': '0x01', 'r': '', 's': ''}")
|
2020-08-06 11:07:18 +02:00
|
|
|
r = t.rlp_serialize()
|
2020-10-26 09:02:29 +01:00
|
|
|
self.assertEqual(r.hex(), 'ea808504a817c8008252089435353535353535353535353535353535353535358203e884deadbeef018080')
|
2020-08-06 11:07:18 +02:00
|
|
|
|
2020-08-04 23:41:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_sign_transaction(self):
|
2020-10-26 09:02:29 +01:00
|
|
|
t = EIP155Transaction(tx_ints, 461, 8995)
|
2020-08-06 11:07:18 +02:00
|
|
|
s = ReferenceSigner(self.pk_getter)
|
2020-08-04 23:41:31 +02:00
|
|
|
z = s.signTransaction(t)
|
2020-08-05 19:47:38 +02:00
|
|
|
|
2020-08-04 23:41:31 +02:00
|
|
|
|
2020-12-19 08:47:21 +01:00
|
|
|
def test_sign_message(self):
|
|
|
|
s = ReferenceSigner(self.pk_getter)
|
2021-01-09 20:37:16 +01:00
|
|
|
z = s.signEthereumMessage(tx_ints['from'], '666f6f')
|
2020-12-25 12:53:16 +01:00
|
|
|
z = s.signEthereumMessage(tx_ints['from'], b'foo')
|
2021-01-09 20:25:47 +01:00
|
|
|
logg.debug('zzz {}'.format(str(z)))
|
2020-12-19 08:47:21 +01:00
|
|
|
|
|
|
|
|
2020-08-04 23:41:31 +02:00
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|