2018-07-31 13:20:25 -04:00
|
|
|
import json
|
|
|
|
import mock
|
2016-11-04 11:34:42 -05:00
|
|
|
from twisted.trial import unittest
|
2018-03-27 17:35:31 -04:00
|
|
|
from twisted.internet import defer
|
2016-11-04 11:34:42 -05:00
|
|
|
|
2018-07-31 13:20:25 -04:00
|
|
|
from cryptography.hazmat.primitives.ciphers.algorithms import AES
|
|
|
|
from lbrynet.database.storage import SQLiteStorage
|
2018-02-21 16:41:15 -05:00
|
|
|
from lbrynet.core.StreamDescriptor import get_sd_info, BlobStreamDescriptorReader
|
2018-08-02 14:34:02 -04:00
|
|
|
from lbrynet.core.StreamDescriptor import StreamDescriptorIdentifier
|
|
|
|
from lbrynet.core.BlobManager import DiskBlobManager
|
|
|
|
from lbrynet.core.PeerManager import PeerManager
|
|
|
|
from lbrynet.core.RateLimiter import DummyRateLimiter
|
|
|
|
from lbrynet.core.PaymentRateManager import OnlyFreePaymentsManager
|
|
|
|
from lbrynet.database.storage import SQLiteStorage
|
2017-06-25 21:04:04 -04:00
|
|
|
from lbrynet.file_manager import EncryptedFileCreator
|
2018-08-02 14:34:02 -04:00
|
|
|
from lbrynet.file_manager.EncryptedFileManager import EncryptedFileManager
|
2018-07-31 13:20:25 -04:00
|
|
|
from lbrynet.core.StreamDescriptor import JSONBytesEncoder
|
2018-07-06 16:16:58 -04:00
|
|
|
from tests import mocks
|
|
|
|
from tests.util import mk_db_and_blob_dir, rm_db_and_blob_dir
|
2016-11-04 11:34:42 -05:00
|
|
|
|
2018-08-02 14:34:02 -04:00
|
|
|
|
|
|
|
FakeNode = mocks.Node
|
|
|
|
FakeWallet = mocks.Wallet
|
|
|
|
FakePeerFinder = mocks.PeerFinder
|
|
|
|
FakeAnnouncer = mocks.Announcer
|
|
|
|
GenFile = mocks.GenFile
|
|
|
|
test_create_stream_sd_file = mocks.create_stream_sd_file
|
|
|
|
DummyBlobAvailabilityTracker = mocks.BlobAvailabilityTracker
|
|
|
|
|
2016-11-04 11:34:42 -05:00
|
|
|
MB = 2**20
|
|
|
|
|
2018-02-21 16:41:15 -05:00
|
|
|
|
2016-11-04 11:34:42 -05:00
|
|
|
def iv_generator():
|
|
|
|
while True:
|
2018-07-31 13:20:25 -04:00
|
|
|
yield b'3' * (AES.block_size // 8)
|
2016-11-04 11:34:42 -05:00
|
|
|
|
|
|
|
|
|
|
|
class CreateEncryptedFileTest(unittest.TestCase):
|
|
|
|
timeout = 5
|
2018-02-21 16:41:15 -05:00
|
|
|
|
2016-11-04 11:34:42 -05:00
|
|
|
def setUp(self):
|
2017-01-16 22:23:20 -05:00
|
|
|
mocks.mock_conf_settings(self)
|
2017-07-27 00:11:12 -04:00
|
|
|
self.tmp_db_dir, self.tmp_blob_dir = mk_db_and_blob_dir()
|
2018-08-02 14:34:02 -04:00
|
|
|
self.wallet = FakeWallet()
|
|
|
|
self.peer_manager = PeerManager()
|
|
|
|
self.peer_finder = FakePeerFinder(5553, self.peer_manager, 2)
|
|
|
|
self.rate_limiter = DummyRateLimiter()
|
|
|
|
self.sd_identifier = StreamDescriptorIdentifier()
|
|
|
|
self.storage = SQLiteStorage(self.tmp_db_dir)
|
|
|
|
self.blob_manager = DiskBlobManager(self.tmp_blob_dir, self.storage)
|
|
|
|
self.prm = OnlyFreePaymentsManager()
|
|
|
|
self.lbry_file_manager = EncryptedFileManager(self.peer_finder, self.rate_limiter, self.blob_manager,
|
|
|
|
self.wallet, self.prm, self.storage, self.sd_identifier)
|
|
|
|
d = self.storage.setup()
|
|
|
|
d.addCallback(lambda _: self.lbry_file_manager.setup())
|
|
|
|
return d
|
2018-02-12 14:19:15 -05:00
|
|
|
|
2017-07-27 00:11:12 -04:00
|
|
|
@defer.inlineCallbacks
|
2016-11-04 11:34:42 -05:00
|
|
|
def tearDown(self):
|
2018-08-02 14:34:02 -04:00
|
|
|
yield self.lbry_file_manager.stop()
|
2017-07-27 00:11:12 -04:00
|
|
|
yield self.blob_manager.stop()
|
2018-08-02 14:34:02 -04:00
|
|
|
yield self.storage.stop()
|
2017-07-27 00:11:12 -04:00
|
|
|
rm_db_and_blob_dir(self.tmp_db_dir, self.tmp_blob_dir)
|
2016-11-04 11:34:42 -05:00
|
|
|
|
2017-09-13 00:15:57 -04:00
|
|
|
@defer.inlineCallbacks
|
2016-11-04 11:34:42 -05:00
|
|
|
def create_file(self, filename):
|
|
|
|
handle = mocks.GenFile(3*MB, '1')
|
2018-07-13 00:21:45 -04:00
|
|
|
key = b'2' * (AES.block_size // 8)
|
2018-08-03 09:36:03 -04:00
|
|
|
out = yield EncryptedFileCreator.create_lbry_file(
|
|
|
|
self.blob_manager, self.storage, self.prm, self.lbry_file_manager, filename, handle, key, iv_generator()
|
|
|
|
)
|
2017-09-13 00:15:57 -04:00
|
|
|
defer.returnValue(out)
|
2016-11-04 11:34:42 -05:00
|
|
|
|
2017-10-12 11:14:03 -04:00
|
|
|
@defer.inlineCallbacks
|
2016-11-04 11:34:42 -05:00
|
|
|
def test_can_create_file(self):
|
2018-07-13 00:21:45 -04:00
|
|
|
expected_stream_hash = b"41e6b247d923d191b154fb6f1b8529d6ddd6a73d65c35" \
|
|
|
|
b"7b1acb742dd83151fb66393a7709e9f346260a4f4db6de10c25"
|
2018-07-06 16:16:58 -04:00
|
|
|
expected_sd_hash = "40c485432daec586c1a2d247e6c08d137640a5af6e81f3f652" \
|
|
|
|
"3e62e81a2e8945b0db7c94f1852e70e371d917b994352c"
|
2016-11-04 11:34:42 -05:00
|
|
|
filename = 'test.file'
|
2018-02-12 14:19:15 -05:00
|
|
|
lbry_file = yield self.create_file(filename)
|
2018-08-02 14:34:02 -04:00
|
|
|
sd_hash = yield self.storage.get_sd_blob_hash_for_stream(lbry_file.stream_hash)
|
2018-02-12 14:19:15 -05:00
|
|
|
|
2018-02-21 16:41:15 -05:00
|
|
|
# read the sd blob file
|
|
|
|
sd_blob = self.blob_manager.blobs[sd_hash]
|
|
|
|
sd_reader = BlobStreamDescriptorReader(sd_blob)
|
|
|
|
sd_file_info = yield sd_reader.get_info()
|
|
|
|
|
|
|
|
# this comes from the database, the blobs returned are sorted
|
2018-08-02 14:34:02 -04:00
|
|
|
sd_info = yield get_sd_info(self.storage, lbry_file.stream_hash, include_blobs=True)
|
2018-07-13 00:21:45 -04:00
|
|
|
self.maxDiff = None
|
2018-07-31 13:20:25 -04:00
|
|
|
unicode_sd_info = json.loads(json.dumps(sd_info, sort_keys=True, cls=JSONBytesEncoder))
|
|
|
|
self.assertDictEqual(unicode_sd_info, sd_file_info)
|
2018-02-21 16:41:15 -05:00
|
|
|
self.assertEqual(sd_info['stream_hash'], expected_stream_hash)
|
|
|
|
self.assertEqual(len(sd_info['blobs']), 3)
|
|
|
|
self.assertNotEqual(sd_info['blobs'][0]['length'], 0)
|
|
|
|
self.assertNotEqual(sd_info['blobs'][1]['length'], 0)
|
|
|
|
self.assertEqual(sd_info['blobs'][2]['length'], 0)
|
2018-02-12 14:19:15 -05:00
|
|
|
self.assertEqual(expected_stream_hash, lbry_file.stream_hash)
|
|
|
|
self.assertEqual(sd_hash, lbry_file.sd_hash)
|
|
|
|
self.assertEqual(sd_hash, expected_sd_hash)
|
2017-10-12 11:14:03 -04:00
|
|
|
blobs = yield self.blob_manager.get_all_verified_blobs()
|
2018-02-12 14:19:15 -05:00
|
|
|
self.assertEqual(3, len(blobs))
|
2017-10-12 11:14:03 -04:00
|
|
|
num_should_announce_blobs = yield self.blob_manager.count_should_announce_blobs()
|
2018-02-12 14:19:15 -05:00
|
|
|
self.assertEqual(2, num_should_announce_blobs)
|
2016-11-04 11:34:42 -05:00
|
|
|
|
2017-10-12 11:14:03 -04:00
|
|
|
@defer.inlineCallbacks
|
2016-11-04 11:34:42 -05:00
|
|
|
def test_can_create_file_with_unicode_filename(self):
|
2018-07-13 00:21:45 -04:00
|
|
|
expected_stream_hash = (b'd1da4258f3ce12edb91d7e8e160d091d3ab1432c2e55a6352dce0'
|
|
|
|
b'2fd5adb86fe144e93e110075b5865fff8617776c6c0')
|
2016-11-04 11:34:42 -05:00
|
|
|
filename = u'☃.file'
|
2018-02-12 14:19:15 -05:00
|
|
|
lbry_file = yield self.create_file(filename)
|
|
|
|
self.assertEqual(expected_stream_hash, lbry_file.stream_hash)
|