2017-06-07 13:01:29 -04:00
|
|
|
import types
|
|
|
|
import mock
|
|
|
|
from twisted.trial import unittest
|
2017-06-14 17:28:37 -04:00
|
|
|
from twisted.internet import defer, task
|
2017-06-07 13:01:29 -04:00
|
|
|
|
2018-07-04 23:16:52 -04:00
|
|
|
from lbrynet.wallet.manager import LbryWalletManager
|
|
|
|
|
2018-07-06 16:16:58 -04:00
|
|
|
from lbrynet.core import PaymentRateManager
|
2017-09-27 17:47:50 -04:00
|
|
|
from lbrynet.core.Error import DownloadDataTimeout, DownloadSDTimeout
|
2017-06-25 21:04:33 -04:00
|
|
|
from lbrynet.daemon import Downloader
|
2017-09-29 11:44:22 +01:00
|
|
|
from lbrynet.core.StreamDescriptor import StreamDescriptorIdentifier
|
2018-08-02 14:34:02 -04:00
|
|
|
from lbrynet.database.storage import SQLiteStorage
|
|
|
|
from lbrynet.core.BlobManager import DiskBlobManager
|
|
|
|
from lbrynet.dht.peerfinder import DummyPeerFinder
|
|
|
|
from lbrynet.core.RateLimiter import DummyRateLimiter
|
2017-06-14 17:28:37 -04:00
|
|
|
from lbrynet.file_manager.EncryptedFileStatusReport import EncryptedFileStatusReport
|
2017-09-29 11:44:22 +01:00
|
|
|
from lbrynet.file_manager.EncryptedFileDownloader import ManagedEncryptedFileDownloader
|
2017-06-25 21:04:33 -04:00
|
|
|
from lbrynet.daemon.ExchangeRateManager import ExchangeRateManager
|
2017-06-07 13:01:29 -04:00
|
|
|
|
2018-07-06 16:16:58 -04:00
|
|
|
from lbrynet.tests.mocks import ExchangeRateManager as DummyExchangeRateManager
|
2017-09-28 18:21:26 +01:00
|
|
|
from lbrynet.tests.mocks import mock_conf_settings
|
2017-06-07 13:01:29 -04:00
|
|
|
|
2017-09-27 17:47:50 -04:00
|
|
|
|
2017-06-14 17:28:37 -04:00
|
|
|
class MocDownloader(object):
|
|
|
|
def __init__(self):
|
|
|
|
self.finish_deferred = defer.Deferred(None)
|
|
|
|
self.stop_called = False
|
|
|
|
|
|
|
|
self.name = 'test'
|
|
|
|
self.num_completed = 0
|
|
|
|
self.num_known = 1
|
|
|
|
self.running_status = ManagedEncryptedFileDownloader.STATUS_RUNNING
|
|
|
|
|
|
|
|
@defer.inlineCallbacks
|
|
|
|
def status(self):
|
2017-10-02 17:13:45 +01:00
|
|
|
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)
|
|
|
|
|
2018-02-12 14:19:15 -05:00
|
|
|
|
2017-09-29 11:44:22 +01:00
|
|
|
def moc_initialize(self, stream_info):
|
2017-10-02 17:13:45 +01:00
|
|
|
self.sd_hash = "d5169241150022f996fa7cd6a9a1c421937276a3275eb912" \
|
|
|
|
"790bd07ba7aec1fac5fd45431d226b8fb402691e79aeb24b"
|
2017-06-14 17:28:37 -04:00
|
|
|
return None
|
|
|
|
|
2018-02-12 14:19:15 -05:00
|
|
|
|
2017-06-14 17:28:37 -04:00
|
|
|
def moc_download_sd_blob(self):
|
|
|
|
return None
|
|
|
|
|
2018-02-12 14:19:15 -05:00
|
|
|
|
|
|
|
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-02-12 14:19:15 -05:00
|
|
|
|
2017-06-14 17:28:37 -04:00
|
|
|
def moc_pay_key_fee(self, key_fee, name):
|
|
|
|
self.pay_key_fee_called = True
|
|
|
|
|
2018-02-12 14:19:15 -05:00
|
|
|
|
2017-06-07 13:01:29 -04:00
|
|
|
class GetStreamTests(unittest.TestCase):
|
2018-07-06 16:16:58 -04:00
|
|
|
|
2017-06-07 13:01:29 -04:00
|
|
|
def init_getstream_with_mocs(self):
|
2017-06-13 15:28:49 -04:00
|
|
|
mock_conf_settings(self)
|
2018-07-06 16:16:58 -04:00
|
|
|
|
2017-06-07 13:01:29 -04:00
|
|
|
sd_identifier = mock.Mock(spec=StreamDescriptorIdentifier)
|
2018-07-04 23:16:52 -04:00
|
|
|
wallet = mock.Mock(spec=LbryWalletmanager)
|
2017-06-07 13:01:29 -04:00
|
|
|
prm = mock.Mock(spec=PaymentRateManager.NegotiatedPaymentRateManager)
|
|
|
|
exchange_rate_manager = mock.Mock(spec=ExchangeRateManager)
|
2018-08-02 14:34:02 -04:00
|
|
|
storage = mock.Mock(spec=SQLiteStorage)
|
|
|
|
peer_finder = DummyPeerFinder()
|
|
|
|
blob_manager = mock.Mock(spec=DiskBlobManager)
|
|
|
|
max_key_fee = {'currency': "LBC", 'amount': 10, 'address': ''}
|
2017-07-07 00:23:16 +05:30
|
|
|
disable_max_key_fee = False
|
2018-08-02 14:34:02 -04:00
|
|
|
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
|
|
|
|
)
|
2017-06-14 17:28:37 -04:00
|
|
|
getstream.pay_key_fee_called = False
|
2017-06-07 13:01:29 -04:00
|
|
|
|
2017-06-14 17:28:37 -04:00
|
|
|
self.clock = task.Clock()
|
|
|
|
getstream.checker.clock = self.clock
|
2017-06-07 13:01:29 -04:00
|
|
|
return getstream
|
|
|
|
|
|
|
|
@defer.inlineCallbacks
|
|
|
|
def test_init_exception(self):
|
|
|
|
"""
|
|
|
|
test that if initialization would fail, by giving it invaild
|
|
|
|
stream_info, that an exception is thrown
|
|
|
|
"""
|
|
|
|
|
|
|
|
getstream = self.init_getstream_with_mocs()
|
|
|
|
name = 'test'
|
|
|
|
stream_info = None
|
|
|
|
|
|
|
|
with self.assertRaises(AttributeError):
|
2018-02-12 14:19:15 -05:00
|
|
|
yield getstream.start(stream_info, name, "deadbeef" * 12, 0)
|
2017-06-07 13:01:29 -04:00
|
|
|
|
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
|
|
|
|
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)
|
|
|
|
getstream.pay_key_fee = types.MethodType(moc_pay_key_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):
|
2018-02-12 14:19:15 -05:00
|
|
|
yield getstream.start(stream_info, name, "deadbeef" * 12, 0)
|
2017-06-14 17:28:37 -04:00
|
|
|
self.assertFalse(getstream.pay_key_fee_called)
|
|
|
|
|
|
|
|
@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
|
|
|
|
"""
|
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)
|
|
|
|
getstream.pay_key_fee = types.MethodType(moc_pay_key_fee, getstream)
|
2017-09-29 11:44:22 +01:00
|
|
|
name = 'test'
|
2017-06-14 17:28:37 -04:00
|
|
|
stream_info = None
|
2018-02-12 14:19:15 -05:00
|
|
|
start = getstream.start(stream_info, name, "deadbeef" * 12, 0)
|
2017-06-14 17:28:37 -04:00
|
|
|
self.clock.advance(1)
|
|
|
|
self.clock.advance(1)
|
2017-09-28 11:04:36 -04:00
|
|
|
self.clock.advance(1)
|
|
|
|
with self.assertRaises(DownloadDataTimeout):
|
2017-06-14 17:28:37 -04:00
|
|
|
yield start
|
|
|
|
self.assertTrue(getstream.pay_key_fee_called)
|
|
|
|
|
|
|
|
@defer.inlineCallbacks
|
|
|
|
def test_finish_one_blob(self):
|
|
|
|
"""
|
|
|
|
test that if we have 1 completed blob, start() returns
|
|
|
|
and key fee is paid
|
|
|
|
"""
|
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)
|
|
|
|
getstream.pay_key_fee = types.MethodType(moc_pay_key_fee, getstream)
|
2017-09-29 11:44:22 +01:00
|
|
|
name = 'test'
|
2017-06-14 17:28:37 -04:00
|
|
|
stream_info = None
|
2018-02-12 14:19:15 -05:00
|
|
|
start = getstream.start(stream_info, name, "deadbeef" * 12, 0)
|
2017-06-14 17:28:37 -04:00
|
|
|
getstream.downloader.num_completed = 1
|
|
|
|
self.clock.advance(1)
|
|
|
|
|
|
|
|
downloader, f_deferred = yield start
|
|
|
|
self.assertTrue(getstream.pay_key_fee_called)
|
|
|
|
|
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
|