lbry-sdk/tests/unit/lbrynet_daemon/test_ExchangeRateManager.py

187 lines
6.9 KiB
Python
Raw Normal View History

from lbrynet.schema.fee import Fee
from lbrynet.extras.daemon import ExchangeRateManager
from lbrynet.p2p.Error import InvalidExchangeRateResponse
2017-02-27 20:18:57 -05:00
from twisted.trial import unittest
from twisted.internet import defer
2018-11-07 15:15:05 -05:00
from tests import test_utils
from tests.mocks import ExchangeRateManager as DummyExchangeRateManager
from tests.mocks import BTCLBCFeed, USDBTCFeed
2017-02-27 20:18:57 -05:00
class FeeFormatTest(unittest.TestCase):
def test_fee_created_with_correct_inputs(self):
fee_dict = {
'currency': 'USD',
2017-04-04 19:42:35 -04:00
'amount': 10.0,
'address': "bRcHraa8bYJZL7vkh5sNmGwPDERFUjGPP9"
2017-02-27 20:18:57 -05:00
}
2017-05-29 16:38:08 -04:00
fee = Fee(fee_dict)
2017-04-04 19:42:35 -04:00
self.assertEqual(10.0, fee['amount'])
self.assertEqual('USD', fee['currency'])
2017-02-27 20:18:57 -05:00
2017-05-31 14:15:15 -04:00
def test_fee_zero(self):
fee_dict = {
'currency': 'LBC',
2017-05-31 14:15:15 -04:00
'amount': 0.0,
'address': "bRcHraa8bYJZL7vkh5sNmGwPDERFUjGPP9"
}
fee = Fee(fee_dict)
self.assertEqual(0.0, fee['amount'])
self.assertEqual('LBC', fee['currency'])
class ExchangeRateTest(unittest.TestCase):
def setUp(self):
test_utils.reset_time(self)
2017-05-31 14:15:15 -04:00
def test_invalid_rates(self):
with self.assertRaises(ValueError):
2018-11-07 15:15:05 -05:00
ExchangeRateManager.ExchangeRate('USDBTC', 0, test_utils.DEFAULT_ISO_TIME)
with self.assertRaises(ValueError):
2018-11-07 15:15:05 -05:00
ExchangeRateManager.ExchangeRate('USDBTC', -1, test_utils.DEFAULT_ISO_TIME)
2017-05-31 14:15:15 -04:00
2017-02-27 20:18:57 -05:00
class FeeTest(unittest.TestCase):
def setUp(self):
test_utils.reset_time(self)
2017-02-27 20:18:57 -05:00
def test_fee_converts_to_lbc(self):
2017-05-30 17:07:23 -04:00
fee = Fee({
'currency': 'USD',
2017-04-04 19:42:35 -04:00
'amount': 10.0,
'address': "bRcHraa8bYJZL7vkh5sNmGwPDERFUjGPP9"
2017-05-30 17:07:23 -04:00
})
2017-04-04 19:42:35 -04:00
2017-02-27 20:18:57 -05:00
rates = {
2018-11-07 15:15:05 -05:00
'BTCLBC': {'spot': 3.0, 'ts': test_utils.DEFAULT_ISO_TIME + 1},
'USDBTC': {'spot': 2.0, 'ts': test_utils.DEFAULT_ISO_TIME + 2}
2017-02-27 20:18:57 -05:00
}
2017-05-31 14:15:15 -04:00
market_feeds = [BTCLBCFeed(), USDBTCFeed()]
2017-09-29 11:44:22 +01:00
manager = DummyExchangeRateManager(market_feeds, rates)
2017-05-30 17:07:23 -04:00
result = manager.convert_currency(fee.currency, "LBC", fee.amount)
2017-02-27 20:18:57 -05:00
self.assertEqual(60.0, result)
2017-05-31 14:15:15 -04:00
def test_missing_feed(self):
# test when a feed is missing for conversion
fee = Fee({
'currency':'USD',
'amount': 1.0,
'address': "bRcHraa8bYJZL7vkh5sNmGwPDERFUjGPP9"
})
rates = {
2018-11-07 15:15:05 -05:00
'BTCLBC': {'spot': 1.0, 'ts': test_utils.DEFAULT_ISO_TIME + 1},
2017-05-31 14:15:15 -04:00
}
market_feeds = [BTCLBCFeed()]
2017-09-29 11:44:22 +01:00
manager = DummyExchangeRateManager(market_feeds, rates)
2017-05-31 14:15:15 -04:00
with self.assertRaises(Exception):
2017-09-07 14:01:06 -04:00
manager.convert_currency(fee.currency, "LBC", fee.amount)
2017-05-31 14:15:15 -04:00
2017-09-07 14:01:06 -04:00
class LBRYioFeedTest(unittest.TestCase):
2017-02-27 20:18:57 -05:00
@defer.inlineCallbacks
def test_handle_response(self):
2017-09-07 14:01:06 -04:00
feed = ExchangeRateManager.LBRYioFeed()
2017-02-27 20:18:57 -05:00
response = '{\"data\": {\"fresh\": 0, \"lbc_usd\": 0.05863062523378918, ' \
'\"lbc_btc\": 5.065289549855739e-05, \"btc_usd\": 1157.498}, ' \
'\"success\": true, \"error\": null}'
2017-02-27 20:18:57 -05:00
out = yield feed._handle_response(response)
2017-09-07 14:01:06 -04:00
expected = 1.0 / 5.065289549855739e-05
self.assertEqual(expected, out)
2017-09-29 11:44:22 +01:00
response = '{}'
2017-09-07 14:01:06 -04:00
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
2017-02-27 20:18:57 -05:00
2017-09-29 11:44:22 +01:00
response = '{"success":true,"result":[]}'
2017-02-27 20:18:57 -05:00
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
2017-09-07 14:01:06 -04:00
class LBRYioBTCFeedTest(unittest.TestCase):
2017-02-27 20:18:57 -05:00
@defer.inlineCallbacks
def test_handle_response(self):
2017-09-07 14:01:06 -04:00
feed = ExchangeRateManager.LBRYioBTCFeed()
2017-02-27 20:18:57 -05:00
response = '{\"data\": {\"fresh\": 0, \"lbc_usd\": 0.05863062523378918, ' \
'\"lbc_btc\": 5.065289549855739e-05, \"btc_usd\": 1157.498}, ' \
'\"success\": true, \"error\": null}'
2017-02-27 20:18:57 -05:00
out = yield feed._handle_response(response)
2017-09-07 14:01:06 -04:00
expected = 1.0 / 1157.498
2017-02-27 20:18:57 -05:00
self.assertEqual(expected, out)
2017-09-29 11:44:22 +01:00
response = '{}'
2017-02-27 20:18:57 -05:00
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
2017-09-29 11:44:22 +01:00
response = '{"success":true,"result":[]}'
2017-02-27 20:18:57 -05:00
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
2017-10-08 16:15:53 +02:00
class CryptonatorFeedTest(unittest.TestCase):
@defer.inlineCallbacks
def test_handle_response(self):
feed = ExchangeRateManager.CryptonatorFeed()
response = '{\"ticker\":{\"base\":\"BTC\",\"target\":\"LBC\",\"price\":\"23657.44026496\"' \
',\"volume\":\"\",\"change\":\"-5.59806916\"},\"timestamp\":1507470422' \
',\"success\":true,\"error\":\"\"}'
out = yield feed._handle_response(response)
expected = 23657.44026496
self.assertEqual(expected, out)
response = '{}'
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
response = '{"success":true,"ticker":{}}'
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
class CryptonatorBTCFeedTest(unittest.TestCase):
@defer.inlineCallbacks
def test_handle_response(self):
feed = ExchangeRateManager.CryptonatorBTCFeed()
response = '{\"ticker\":{\"base\":\"USD\",\"target\":\"BTC\",\"price\":\"0.00022123\",' \
'\"volume\":\"\",\"change\":\"-0.00000259\"},\"timestamp\":1507471141,' \
'\"success\":true,\"error\":\"\"}'
out = yield feed._handle_response(response)
expected = 0.00022123
self.assertEqual(expected, out)
response = '{}'
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
response = '{"success":true,"ticker":{}}'
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
class BittrexFeedTest(unittest.TestCase):
@defer.inlineCallbacks
def test_handle_response(self):
feed = ExchangeRateManager.BittrexFeed()
response = '{"success":true,"message":"","result":[{"Id":6902471,"TimeStamp":"2017-02-2'\
'7T23:41:52.213","Quantity":56.12611239,"Price":0.00001621,"Total":0.00090980,"FillType":"'\
'PARTIAL_FILL","OrderType":"SELL"},{"Id":6902403,"TimeStamp":"2017-02-27T23:31:40.463","Qu'\
'antity":430.99988180,"Price":0.00001592,"Total":0.00686151,"FillType":"PARTIAL_FILL","Ord'\
'erType":"SELL"}]}'
out = yield feed._handle_response(response)
expected = 1.0 / ((0.00090980+0.00686151) / (56.12611239+430.99988180))
self.assertEqual(expected, out)
response = '{}'
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)
response = '{"success":true,"result":[]}'
with self.assertRaises(InvalidExchangeRateResponse):
out = yield feed._handle_response(response)