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

187 lines
7 KiB
Python
Raw Normal View History

import types
from unittest import mock
from twisted.trial import unittest
2017-06-14 17:28:37 -04:00
from twisted.internet import defer, task
2018-07-04 23:16:52 -04:00
from lbrynet.p2p import PaymentRateManager
from lbrynet.p2p.Error import DownloadDataTimeout, DownloadSDTimeout
from lbrynet.p2p.StreamDescriptor import StreamDescriptorIdentifier
from lbrynet.p2p.BlobManager import DiskBlobManager
from lbrynet.p2p.RateLimiter import DummyRateLimiter
2018-11-16 10:50:08 -05:00
from lbrynet.p2p.client.DownloadManager import DownloadManager
from lbrynet.extras.daemon import Downloader
from lbrynet.extras.daemon import ExchangeRateManager
from lbrynet.extras.daemon.storage import SQLiteStorage
2018-11-07 15:15:05 -05:00
from lbrynet.extras.daemon.PeerFinder import DummyPeerFinder
from lbrynet.blob.EncryptedFileStatusReport import EncryptedFileStatusReport
from lbrynet.blob.EncryptedFileDownloader import ManagedEncryptedFileDownloader
from lbrynet.extras.wallet import LbryWalletManager
2018-08-04 21:08:22 -04:00
from tests.mocks import mock_conf_settings
2017-09-27 17:47:50 -04:00
class MocDownloader:
2017-06-14 17:28:37 -04:00
def __init__(self):
self.finish_deferred = defer.Deferred(None)
self.stop_called = False
2018-11-16 10:50:08 -05:00
self.file_name = 'test'
2017-06-14 17:28:37 -04:00
self.name = 'test'
self.num_completed = 0
self.num_known = 1
self.running_status = ManagedEncryptedFileDownloader.STATUS_RUNNING
@defer.inlineCallbacks
def status(self):
out = yield EncryptedFileStatusReport(
self.name, self.num_completed, self.num_known, self.running_status)
2017-06-14 17:28:37 -04:00
defer.returnValue(out)
def start(self):
return self.finish_deferred
def stop(self):
self.stop_called = True
self.finish_deferred.callback(True)
2017-09-29 11:44:22 +01:00
def moc_initialize(self, stream_info):
self.sd_hash = "d5169241150022f996fa7cd6a9a1c421937276a3275eb912" \
"790bd07ba7aec1fac5fd45431d226b8fb402691e79aeb24b"
2017-06-14 17:28:37 -04:00
return None
2017-06-14 17:28:37 -04:00
def moc_download_sd_blob(self):
return None
def moc_download(self, sd_blob, name, txid, nout, key_fee, file_name):
2017-06-14 17:28:37 -04:00
self.pay_key_fee(key_fee, name)
self.downloader = MocDownloader()
self.downloader.start()
2018-11-16 10:50:08 -05:00
def moc_pay_key_fee(d):
def _moc_pay_key_fee(self, key_fee, name):
d.callback(True)
return _moc_pay_key_fee
2017-06-14 17:28:37 -04:00
class GetStreamTests(unittest.TestCase):
def init_getstream_with_mocs(self):
mock_conf_settings(self)
sd_identifier = mock.Mock(spec=StreamDescriptorIdentifier)
2018-08-04 21:08:22 -04:00
wallet = mock.Mock(spec=LbryWalletManager)
prm = mock.Mock(spec=PaymentRateManager.NegotiatedPaymentRateManager)
exchange_rate_manager = mock.Mock(spec=ExchangeRateManager)
storage = mock.Mock(spec=SQLiteStorage)
peer_finder = DummyPeerFinder()
blob_manager = mock.Mock(spec=DiskBlobManager)
max_key_fee = {'currency': "LBC", 'amount': 10, 'address': ''}
disable_max_key_fee = False
data_rate = {'currency': "LBC", 'amount': 0, 'address': ''}
2018-08-03 09:36:03 -04:00
getstream = Downloader.GetStream(
sd_identifier, wallet, exchange_rate_manager, blob_manager, peer_finder, DummyRateLimiter(), prm,
storage, max_key_fee, disable_max_key_fee, timeout=3, data_rate=data_rate
)
2018-11-16 10:50:08 -05:00
getstream.download_manager = mock.Mock(spec=DownloadManager)
return getstream
@defer.inlineCallbacks
def test_init_exception(self):
"""
2018-10-18 14:40:37 +03:00
test that if initialization would fail, by giving it invalid
stream_info, that an exception is thrown
"""
getstream = self.init_getstream_with_mocs()
name = 'test'
stream_info = None
with self.assertRaises(AttributeError):
yield getstream.start(stream_info, name, "deadbeef" * 12, 0)
2017-06-14 17:28:37 -04:00
@defer.inlineCallbacks
def test_sd_blob_download_timeout(self):
"""
test that if download_sd_blob fails due to timeout,
DownloadTimeoutError is raised
"""
def download_sd_blob(self):
2018-01-04 21:28:09 -05:00
raise DownloadSDTimeout(self)
2017-06-14 17:28:37 -04:00
2018-11-16 10:50:08 -05:00
called_pay_fee = defer.Deferred()
2017-09-29 11:44:22 +01:00
getstream = self.init_getstream_with_mocs()
2017-06-14 17:28:37 -04:00
getstream._initialize = types.MethodType(moc_initialize, getstream)
getstream._download_sd_blob = types.MethodType(download_sd_blob, getstream)
getstream._download = types.MethodType(moc_download, getstream)
2018-11-16 10:50:08 -05:00
getstream.pay_key_fee = types.MethodType(moc_pay_key_fee(called_pay_fee), getstream)
2017-09-29 11:44:22 +01:00
name = 'test'
2017-06-14 17:28:37 -04:00
stream_info = None
2017-09-27 17:47:50 -04:00
with self.assertRaises(DownloadSDTimeout):
yield getstream.start(stream_info, name, "deadbeef" * 12, 0)
2018-11-16 10:50:08 -05:00
self.assertFalse(called_pay_fee.called)
2017-06-14 17:28:37 -04:00
@defer.inlineCallbacks
def test_timeout(self):
"""
2017-09-28 11:04:36 -04:00
test that timeout (set to 3 here) exception is raised
2017-06-14 17:28:37 -04:00
when download times out while downloading first blob, and key fee is paid
"""
2018-11-16 10:50:08 -05:00
called_pay_fee = defer.Deferred()
2017-09-29 11:44:22 +01:00
getstream = self.init_getstream_with_mocs()
2017-06-14 17:28:37 -04:00
getstream._initialize = types.MethodType(moc_initialize, getstream)
getstream._download_sd_blob = types.MethodType(moc_download_sd_blob, getstream)
getstream._download = types.MethodType(moc_download, getstream)
2018-11-16 10:50:08 -05:00
getstream.pay_key_fee = types.MethodType(moc_pay_key_fee(called_pay_fee), getstream)
2017-09-29 11:44:22 +01:00
name = 'test'
2017-06-14 17:28:37 -04:00
stream_info = None
start = getstream.start(stream_info, name, "deadbeef" * 12, 0)
2017-09-28 11:04:36 -04:00
with self.assertRaises(DownloadDataTimeout):
2017-06-14 17:28:37 -04:00
yield start
@defer.inlineCallbacks
def test_finish_one_blob(self):
"""
test that if we have 1 completed blob, start() returns
and key fee is paid
"""
2018-11-16 10:50:08 -05:00
called_pay_fee = defer.Deferred()
2017-09-29 11:44:22 +01:00
getstream = self.init_getstream_with_mocs()
2017-06-14 17:28:37 -04:00
getstream._initialize = types.MethodType(moc_initialize, getstream)
getstream._download_sd_blob = types.MethodType(moc_download_sd_blob, getstream)
getstream._download = types.MethodType(moc_download, getstream)
2018-11-16 10:50:08 -05:00
getstream.pay_key_fee = types.MethodType(moc_pay_key_fee(called_pay_fee), getstream)
2017-09-29 11:44:22 +01:00
name = 'test'
2017-06-14 17:28:37 -04:00
stream_info = None
2018-11-16 10:50:08 -05:00
self.assertFalse(getstream.wrote_data)
getstream.data_downloading_deferred.callback(None)
yield getstream.start(stream_info, name, "deadbeef" * 12, 0)
self.assertTrue(getstream.wrote_data)
2017-06-14 17:28:37 -04:00
2018-11-16 10:50:08 -05:00
# self.assertTrue(getstream.pay_key_fee_called)
2017-06-14 17:28:37 -04:00
2017-09-27 17:47:50 -04:00
# @defer.inlineCallbacks
# def test_finish_stopped_downloader(self):
# """
# test that if we have a stopped downloader, beforfe a blob is downloaded,
# start() returns
# """
# getstream = self.init_getstream_with_mocs()
# getstream._initialize = types.MethodType(moc_initialize, getstream)
# getstream._download_sd_blob = types.MethodType(moc_download_sd_blob, getstream)
# getstream._download = types.MethodType(moc_download, getstream)
# name='test'
# stream_info = None
# start = getstream.start(stream_info,name)
#
# getstream.downloader.running_status = ManagedEncryptedFileDownloader.STATUS_STOPPED
# self.clock.advance(1)
# downloader, f_deferred = yield start