fix and test case for blob_clean after disabling network storage

This commit is contained in:
Victor Shyba 2022-02-11 16:13:08 -03:00
parent 68a940f3a6
commit dde4a5b495
2 changed files with 15 additions and 11 deletions

View file

@ -36,31 +36,29 @@ class DiskSpaceManager:
await self._clean(True) await self._clean(True)
async def _clean(self, is_network_blob=False): async def _clean(self, is_network_blob=False):
space_used_bytes = await self.get_space_used_bytes() space_used_mb = await self.get_space_used_mb(cached=False)
if is_network_blob: if is_network_blob:
space_used_bytes = space_used_bytes['network_storage'] space_used_mb = space_used_mb['network_storage']
else: else:
space_used_bytes = space_used_bytes['content_storage'] + space_used_bytes['private_storage'] space_used_mb = space_used_mb['content_storage'] + space_used_mb['private_storage']
storage_limit_mb = self.config.network_storage_limit if is_network_blob else self.config.blob_storage_limit storage_limit_mb = self.config.network_storage_limit if is_network_blob else self.config.blob_storage_limit
storage_limit = storage_limit_mb*1024*1024 if storage_limit_mb else None
if self.analytics: if self.analytics:
asyncio.create_task( asyncio.create_task(
self.analytics.send_disk_space_used(space_used_bytes, storage_limit, is_network_blob) self.analytics.send_disk_space_used(space_used_mb, storage_limit_mb, is_network_blob)
) )
if not storage_limit:
return 0
delete = [] delete = []
available = storage_limit - space_used_bytes available = storage_limit_mb - space_used_mb
if available > 0: if storage_limit_mb == 0 if not is_network_blob else available >= 0:
return 0 return 0
for blob_hash, file_size, _ in await self.db.get_stored_blobs(is_mine=False, is_network_blob=is_network_blob): for blob_hash, file_size, _ in await self.db.get_stored_blobs(is_mine=False, is_network_blob=is_network_blob):
delete.append(blob_hash) delete.append(blob_hash)
available += file_size available += int(file_size/1024.0/1024.0)
if available > 0: if available >= 0:
break break
if delete: if delete:
await self.db.stop_all_files() await self.db.stop_all_files()
await self.blob_manager.delete_blobs(delete, delete_from_db=True) await self.blob_manager.delete_blobs(delete, delete_from_db=True)
self._used_space_bytes = None
return len(delete) return len(delete)
async def cleaning_loop(self): async def cleaning_loop(self):

View file

@ -617,6 +617,7 @@ class TestBackgroundDownloaderComponent(CommandTestCase):
self.assertEqual(0, (await self.status())['disk_space']['content_blobs_storage_used_mb']) self.assertEqual(0, (await self.status())['disk_space']['content_blobs_storage_used_mb'])
background_downloader = BackgroundDownloader(self.daemon.conf, self.daemon.storage, self.daemon.blob_manager) background_downloader = BackgroundDownloader(self.daemon.conf, self.daemon.storage, self.daemon.blob_manager)
self.daemon.conf.network_storage_limit = 32
await self.clear() await self.clear()
await self.blob_clean() await self.blob_clean()
self.assertEqual(0, (await self.status())['disk_space']['total_used_mb']) self.assertEqual(0, (await self.status())['disk_space']['total_used_mb'])
@ -625,6 +626,7 @@ class TestBackgroundDownloaderComponent(CommandTestCase):
await self.blob_clean() await self.blob_clean()
self.assertEqual(0, (await self.status())['disk_space']['content_blobs_storage_used_mb']) self.assertEqual(0, (await self.status())['disk_space']['content_blobs_storage_used_mb'])
self.assertEqual(32, (await self.status())['disk_space']['seed_blobs_storage_used_mb']) self.assertEqual(32, (await self.status())['disk_space']['seed_blobs_storage_used_mb'])
self.daemon.conf.network_storage_limit = 48
await background_downloader.download_blobs(content2) await background_downloader.download_blobs(content2)
await self.assertBlobs(content1, content2) await self.assertBlobs(content1, content2)
await self.blob_clean() await self.blob_clean()
@ -654,3 +656,7 @@ class TestBackgroundDownloaderComponent(CommandTestCase):
self.daemon.conf.blob_storage_limit = 1 self.daemon.conf.blob_storage_limit = 1
await self.blob_clean() await self.blob_clean()
await self.assertBlobs(content1, no_files=False) await self.assertBlobs(content1, no_files=False)
self.daemon.conf.network_storage_limit = 0
await self.blob_clean()
self.assertEqual(0, (await self.status())['disk_space']['seed_blobs_storage_used_mb'])