sync: Improve UI and error reporting for interleaved mode
This fixes two issues: 1. the progress bar could show a count greater than the total if new projects were discovered mid-sync. Update the progress bar total dynamically 2. Make "Stall detected" error message more actionable Bug: 432206932 Change-Id: Ie2a4ada5b1770cae0302fb06590641c522cbb7e7
This commit is contained in:
		
							parent
							
								
									5d95ba8d85
								
							
						
					
					
						commit
						0e027bf46e
					
				
					 2 changed files with 19 additions and 5 deletions
				
			
		|  | @ -119,6 +119,11 @@ class Progress: | ||||||
|         if not quiet and show_elapsed: |         if not quiet and show_elapsed: | ||||||
|             self._update_thread.start() |             self._update_thread.start() | ||||||
| 
 | 
 | ||||||
|  |     def update_total(self, new_total): | ||||||
|  |         """Updates the total if the new total is larger.""" | ||||||
|  |         if new_total > self._total: | ||||||
|  |             self._total = new_total | ||||||
|  | 
 | ||||||
|     def _update_loop(self): |     def _update_loop(self): | ||||||
|         while True: |         while True: | ||||||
|             self.update(inc=0) |             self.update(inc=0) | ||||||
|  |  | ||||||
|  | @ -2505,12 +2505,20 @@ later is required to fix a server side protocol bug. | ||||||
| 
 | 
 | ||||||
|                         pending_relpaths = {p.relpath for p in projects_to_sync} |                         pending_relpaths = {p.relpath for p in projects_to_sync} | ||||||
|                         if previously_pending_relpaths == pending_relpaths: |                         if previously_pending_relpaths == pending_relpaths: | ||||||
|                             logger.error( |                             stalled_projects_str = "\n".join( | ||||||
|                                 "Stall detected in interleaved sync, not all " |                                 f" - {path}" | ||||||
|                                 "projects could be synced." |                                 for path in sorted(list(pending_relpaths)) | ||||||
|                             ) |                             ) | ||||||
|                             err_event.set() |                             logger.error( | ||||||
|                             break |                                 "The following projects failed and could not " | ||||||
|  |                                 "be synced:\n%s", | ||||||
|  |                                 stalled_projects_str, | ||||||
|  |                             ) | ||||||
|  |                             # Include these in the final error report. | ||||||
|  |                             self._interleaved_err_checkout = True | ||||||
|  |                             self._interleaved_err_checkout_results.extend( | ||||||
|  |                                 list(pending_relpaths) | ||||||
|  |                              ) | ||||||
|                         previously_pending_relpaths = pending_relpaths |                         previously_pending_relpaths = pending_relpaths | ||||||
| 
 | 
 | ||||||
|                         self.get_parallel_context()[ |                         self.get_parallel_context()[ | ||||||
|  | @ -2570,6 +2578,7 @@ later is required to fix a server side protocol bug. | ||||||
|                             manifest=manifest, |                             manifest=manifest, | ||||||
|                             all_manifests=not opt.this_manifest_only, |                             all_manifests=not opt.this_manifest_only, | ||||||
|                         ) |                         ) | ||||||
|  |                         pm.update_total(len(project_list)) | ||||||
|                 finally: |                 finally: | ||||||
|                     sync_event.set() |                     sync_event.set() | ||||||
|                     sync_progress_thread.join() |                     sync_progress_thread.join() | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue