2019-02-14 12:36:18 -05:00
|
|
|
import tempfile
|
|
|
|
import shutil
|
|
|
|
import os
|
2019-12-31 15:30:13 -05:00
|
|
|
from lbry.testcase import AsyncioTestCase
|
2019-06-20 21:02:58 -04:00
|
|
|
from lbry.conf import Config
|
|
|
|
from lbry.extras.daemon.storage import SQLiteStorage
|
|
|
|
from lbry.blob.blob_manager import BlobManager
|
2019-02-14 12:36:18 -05:00
|
|
|
|
|
|
|
|
|
|
|
class TestBlobManager(AsyncioTestCase):
|
2019-04-15 16:14:19 -04:00
|
|
|
async def setup_blob_manager(self, save_blobs=True):
|
2019-02-14 12:36:18 -05:00
|
|
|
tmp_dir = tempfile.mkdtemp()
|
|
|
|
self.addCleanup(lambda: shutil.rmtree(tmp_dir))
|
2019-04-15 16:14:19 -04:00
|
|
|
self.config = Config(save_blobs=save_blobs)
|
|
|
|
self.storage = SQLiteStorage(self.config, os.path.join(tmp_dir, "lbrynet.sqlite"))
|
|
|
|
self.blob_manager = BlobManager(self.loop, tmp_dir, self.storage, self.config)
|
|
|
|
await self.storage.open()
|
2019-02-14 12:36:18 -05:00
|
|
|
|
2019-07-17 02:49:08 -03:00
|
|
|
async def test_memory_blobs_arent_verifie_but_real_ones_are(self):
|
|
|
|
for save_blobs in (False, True):
|
|
|
|
await self.setup_blob_manager(save_blobs=save_blobs)
|
|
|
|
# add a blob file
|
|
|
|
blob_hash = "7f5ab2def99f0ddd008da71db3a3772135f4002b19b7605840ed1034c8955431bd7079549e65e6b2a3b9c17c773073ed"
|
|
|
|
blob_bytes = b'1' * ((2 * 2 ** 20) - 1)
|
|
|
|
blob = self.blob_manager.get_blob(blob_hash, len(blob_bytes))
|
|
|
|
blob.save_verified_blob(blob_bytes)
|
|
|
|
self.assertTrue(blob.get_is_verified())
|
|
|
|
self.blob_manager.blob_completed(blob)
|
|
|
|
self.assertEqual(self.blob_manager.is_blob_verified(blob_hash), save_blobs)
|
|
|
|
|
2019-04-15 16:14:19 -04:00
|
|
|
async def test_sync_blob_file_manager_on_startup(self):
|
|
|
|
await self.setup_blob_manager(save_blobs=True)
|
2019-02-14 12:36:18 -05:00
|
|
|
|
|
|
|
# add a blob file
|
|
|
|
blob_hash = "7f5ab2def99f0ddd008da71db3a3772135f4002b19b7605840ed1034c8955431bd7079549e65e6b2a3b9c17c773073ed"
|
|
|
|
blob_bytes = b'1' * ((2 * 2 ** 20) - 1)
|
2019-04-15 16:14:19 -04:00
|
|
|
with open(os.path.join(self.blob_manager.blob_dir, blob_hash), 'wb') as f:
|
2019-02-14 12:36:18 -05:00
|
|
|
f.write(blob_bytes)
|
|
|
|
|
|
|
|
# it should not have been added automatically on startup
|
2019-04-15 16:14:19 -04:00
|
|
|
|
|
|
|
await self.blob_manager.setup()
|
|
|
|
self.assertSetEqual(self.blob_manager.completed_blob_hashes, set())
|
2019-02-14 12:36:18 -05:00
|
|
|
|
|
|
|
# make sure we can add the blob
|
2019-04-17 13:32:24 -04:00
|
|
|
await self.blob_manager.blob_completed(self.blob_manager.get_blob(blob_hash, len(blob_bytes)))
|
2019-04-15 16:14:19 -04:00
|
|
|
self.assertSetEqual(self.blob_manager.completed_blob_hashes, {blob_hash})
|
2019-02-14 12:36:18 -05:00
|
|
|
|
|
|
|
# stop the blob manager and restart it, make sure the blob is there
|
2019-04-15 16:14:19 -04:00
|
|
|
self.blob_manager.stop()
|
|
|
|
self.assertSetEqual(self.blob_manager.completed_blob_hashes, set())
|
|
|
|
await self.blob_manager.setup()
|
|
|
|
self.assertSetEqual(self.blob_manager.completed_blob_hashes, {blob_hash})
|
2019-02-14 12:36:18 -05:00
|
|
|
|
|
|
|
# test that the blob is removed upon the next startup after the file being manually deleted
|
2019-04-15 16:14:19 -04:00
|
|
|
self.blob_manager.stop()
|
2019-02-14 12:36:18 -05:00
|
|
|
|
|
|
|
# manually delete the blob file and restart the blob manager
|
2019-04-15 16:14:19 -04:00
|
|
|
os.remove(os.path.join(self.blob_manager.blob_dir, blob_hash))
|
|
|
|
await self.blob_manager.setup()
|
|
|
|
self.assertSetEqual(self.blob_manager.completed_blob_hashes, set())
|
2019-02-14 12:36:18 -05:00
|
|
|
|
|
|
|
# check that the deleted blob was updated in the database
|
|
|
|
self.assertEqual(
|
|
|
|
'pending', (
|
2019-04-15 16:14:19 -04:00
|
|
|
await self.storage.run_and_return_one_or_none('select status from blob where blob_hash=?', blob_hash)
|
2019-02-14 12:36:18 -05:00
|
|
|
)
|
|
|
|
)
|