From b6d84f81ec39ee05898e15876db46e2887afbe2f Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sat, 2 May 2020 19:38:38 +0100 Subject: [PATCH] gdrive: add progress Part of #2865 See https://github.com/iterative/dvc/issues/2865#issuecomment-622984785 --- dvc/remote/gdrive.py | 36 ++++++++++++++++++++++++++++-------- 1 file changed, 28 insertions(+), 8 deletions(-) diff --git a/dvc/remote/gdrive.py b/dvc/remote/gdrive.py index b7688a166a..1095300164 100644 --- a/dvc/remote/gdrive.py +++ b/dvc/remote/gdrive.py @@ -396,14 +396,34 @@ def _gdrive_download_file( param = {"id": item_id} # it does not create a file on the remote gdrive_file = self._drive.CreateFile(param) - bar_format = ( - "Downloading {desc:{ncols_desc}.{ncols_desc}}... " - + Tqdm.format_sizeof(int(gdrive_file["fileSize"]), "B", 1024) - ) - with Tqdm( - bar_format=bar_format, desc=progress_desc, disable=no_progress_bar - ): - gdrive_file.GetContentFile(to_file) # TODO: actually use pbar + + import httplib2 + + OrigClass = httplib2.HTTPConnectionWithTimeout.response_class + + class Custom(OrigClass): + def _readall_chunked(self): + assert self.chunked != "UNKNOWN" + value = [] + with Tqdm( + total=int(gdrive_file["fileSize"]), + desc=progress_desc, + disable=no_progress_bar, + bytes=True, + ) as pbar: + while True: + chunk_left = self._get_chunk_left() + if chunk_left is None: + break + chunk = self._safe_read(chunk_left) + value.append(chunk) + pbar.update(len(chunk)) + self.chunk_left = 0 + return b"".join(value) + + httplib2.HTTPConnectionWithTimeout.response_class = Custom + gdrive_file.GetContentFile(to_file) + httplib2.HTTPConnectionWithTimeout.response_class = OrigClass @_gdrive_retry def _gdrive_delete_file(self, item_id):