1
0
Fork 0

Add Flexpool tests for API failures

Signed-off-by: Julien Riou <julien@riou.xyz>
This commit is contained in:
Julien Riou 2021-02-17 16:21:08 +01:00
parent 0a2bef6192
commit 7f5bd0a1cf
No known key found for this signature in database
GPG key ID: FF42D23B580C89F7
2 changed files with 68 additions and 21 deletions

View file

@ -152,6 +152,7 @@ class FlexpoolHandler(Handler):
@staticmethod @staticmethod
def get_blocks(exchange_rate=None, currency=None): def get_blocks(exchange_rate=None, currency=None):
try:
remote_blocks = flexpoolapi.pool.last_blocks(count=MAX_BLOCKS_COUNT) remote_blocks = flexpoolapi.pool.last_blocks(count=MAX_BLOCKS_COUNT)
# convert to blocks # convert to blocks
blocks = [] blocks = []
@ -163,19 +164,27 @@ class FlexpoolHandler(Handler):
blocks.append(block) blocks.append(block)
# sort by block number # sort by block number
return sorted(blocks) return sorted(blocks)
except flexpoolapi.exceptions.APIError as err:
logger.warning('failed to get blocks from Flexpool API')
logger.debug(err)
def watch_miner(self, address, last_balance=None, last_transaction=None): def watch_miner(self, address, last_balance=None, last_transaction=None):
logger.debug(f'watching miner {address}') logger.debug(f'watching miner {address}')
try: try:
miner = Miner(address=address, exchange_rate=self.exchange_rate, currency=self.currency) miner = Miner(address=address, exchange_rate=self.exchange_rate, currency=self.currency)
except Exception as err:
logger.error(f'miner {address} not found')
logger.exception(err)
return
logger.debug(miner) logger.debug(miner)
last_balance = self._watch_miner_balance(miner=miner, last_balance=last_balance) last_balance = self._watch_miner_balance(miner=miner, last_balance=last_balance)
last_transaction = self._watch_miner_payments(miner=miner, last_transaction=last_transaction) last_transaction = self._watch_miner_payments(miner=miner, last_transaction=last_transaction)
return last_balance, last_transaction return last_balance, last_transaction
except flexpoolapi.exceptions.InvalidMinerAddress as err:
logger.error(f'miner address {address} is invalid')
logger.debug(err)
except flexpoolapi.exceptions.MinerDoesNotExist as err:
logger.error(f'miner {address} not found')
logger.debug(err)
except flexpoolapi.exceptions.APIError as err:
logger.warning('failed to get miner from Flexpool API')
logger.debug(err)
return None, None

View file

@ -34,6 +34,20 @@ class TestFlexpoolHandler:
else: else:
notifier.notify_balance.assert_not_called() notifier.notify_balance.assert_not_called()
def test_balance_with_api_failure(self, mocker):
"""An API failure should not send a balance notification"""
notifier = mocker.Mock()
notifier.notify_balance = mocker.Mock()
handler = FlexpoolHandler(notifier=notifier)
request_get = mocker.patch('requests.get')
request_get.return_value.status_code = 503
mocker.patch('companion.pools.flexpool.FlexpoolHandler._watch_miner_payments')
mocker.patch('companion.pools.flexpool.Miner.get_payements')
last_balance, last_transaction = handler.watch_miner(address='0000000000000000000000000000000000000001',
last_balance=1)
assert last_balance is None
notifier.notify_balance.assert_not_called()
@staticmethod @staticmethod
def _create_transactions(names): def _create_transactions(names):
if names: if names:
@ -66,6 +80,19 @@ class TestFlexpoolHandler:
else: else:
notifier.notify_payment.assert_not_called() notifier.notify_payment.assert_not_called()
def test_payment_with_api_failure(self, mocker):
"""An API failure should not send a payment notification"""
notifier = mocker.Mock()
notifier.notify_payment = mocker.Mock()
handler = FlexpoolHandler(notifier=notifier)
request_get = mocker.patch('requests.get')
request_get.return_value.status_code = 503
mocker.patch('companion.pools.flexpool.FlexpoolHandler._watch_miner_balance')
last_balance, last_transaction = handler.watch_miner(address='0000000000000000000000000000000000000001',
last_transaction=1)
assert last_transaction is None
notifier.notify_payment.assert_not_called()
@staticmethod @staticmethod
def _create_blocks(numbers): def _create_blocks(numbers):
if numbers: if numbers:
@ -102,3 +129,14 @@ class TestFlexpoolHandler:
notifier.notify_block.assert_called_once() notifier.notify_block.assert_called_once()
else: else:
notifier.notify_block.assert_not_called() notifier.notify_block.assert_not_called()
def test_block_with_api_failure(self, mocker):
"""An API failure should not send a block notification"""
notifier = mocker.Mock()
notifier.notify_block = mocker.Mock()
handler = FlexpoolHandler(notifier=notifier)
request_get = mocker.patch('requests.get')
request_get.return_value.status_code = 503
block = handler.watch_blocks(last_block=1)
assert block is None
notifier.notify_block.assert_not_called()