add timeout->retry tests]

This commit is contained in:
Victor Shyba 2019-02-12 18:50:43 -03:00 committed by Lex Berezhny
parent cabc58feb4
commit 6c68ba1d22

View file

@ -1,5 +1,5 @@
import logging import logging
from asyncio import CancelledError import asyncio
from torba.testcase import IntegrationTestCase from torba.testcase import IntegrationTestCase
@ -21,7 +21,7 @@ class ReconnectTests(IntegrationTestCase):
d = self.ledger.network.get_transaction(sendtxid) d = self.ledger.network.get_transaction(sendtxid)
# what's that smoke on my ethernet cable? oh no! # what's that smoke on my ethernet cable? oh no!
self.ledger.network.client.connection_lost(Exception()) self.ledger.network.client.connection_lost(Exception())
with self.assertRaises(CancelledError): with self.assertRaises(asyncio.CancelledError):
await d await d
# rich but offline? no way, no water, let's retry # rich but offline? no way, no water, let's retry
with self.assertRaisesRegex(ConnectionError, 'connection is not available'): with self.assertRaisesRegex(ConnectionError, 'connection is not available'):
@ -31,3 +31,11 @@ class ReconnectTests(IntegrationTestCase):
await self.blockchain.generate(1) await self.blockchain.generate(1)
# omg, the burned cable still works! torba is fire proof! # omg, the burned cable still works! torba is fire proof!
await self.ledger.network.get_transaction(sendtxid) await self.ledger.network.get_transaction(sendtxid)
async def test_timeout_then_reconnect(self):
await self.ledger.stop()
conf = self.ledger.config
self.ledger.config['connect_timeout'] = 1
self.ledger.config['default_servers'] = [('10.0.0.1', 12)] + list(conf['default_servers'])
await self.ledger.start()
self.assertTrue(self.ledger.network.is_connected)