mirror of
https://gerrit.googlesource.com/git-repo
synced 2024-12-21 07:16:21 +00:00
f7f9dd4deb
If a user is not authenticated, repo continues execution and it will likely result in more of the same errors being printed. A user is also likely to SIGTERM the process resulting in more errors. This change stops repo sync if any of repositories can't be fetched to Git authentcation using sso helper. We could extend this to all Git authentication Change-Id: I9e471e063450c0a51f25a5e7f12a83064dfb170c Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/438522 Reviewed-by: Gavin Mak <gavinmak@google.com> Tested-by: Josip Sokcevic <sokcevic@google.com> Commit-Queue: Josip Sokcevic <sokcevic@google.com>
194 lines
4.9 KiB
Python
194 lines
4.9 KiB
Python
# Copyright (C) 2008 The Android Open Source Project
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
from typing import List
|
|
|
|
|
|
class BaseRepoError(Exception):
|
|
"""All repo specific exceptions derive from BaseRepoError."""
|
|
|
|
|
|
class RepoError(BaseRepoError):
|
|
"""Exceptions thrown inside repo that can be handled."""
|
|
|
|
def __init__(self, *args, project: str = None) -> None:
|
|
super().__init__(*args)
|
|
self.project = project
|
|
|
|
|
|
class RepoExitError(BaseRepoError):
|
|
"""Exception thrown that result in termination of repo program.
|
|
- Should only be handled in main.py
|
|
"""
|
|
|
|
def __init__(
|
|
self,
|
|
*args,
|
|
exit_code: int = 1,
|
|
aggregate_errors: List[Exception] = None,
|
|
**kwargs,
|
|
) -> None:
|
|
super().__init__(*args, **kwargs)
|
|
self.exit_code = exit_code
|
|
self.aggregate_errors = aggregate_errors
|
|
|
|
|
|
class RepoUnhandledExceptionError(RepoExitError):
|
|
"""Exception that maintains error as reason for program exit."""
|
|
|
|
def __init__(
|
|
self,
|
|
error: BaseException,
|
|
**kwargs,
|
|
) -> None:
|
|
super().__init__(error, **kwargs)
|
|
self.error = error
|
|
|
|
|
|
class SilentRepoExitError(RepoExitError):
|
|
"""RepoExitError that should no include CLI logging of issue/issues."""
|
|
|
|
|
|
class ManifestParseError(RepoExitError):
|
|
"""Failed to parse the manifest file."""
|
|
|
|
|
|
class ManifestInvalidRevisionError(ManifestParseError):
|
|
"""The revision value in a project is incorrect."""
|
|
|
|
|
|
class ManifestInvalidPathError(ManifestParseError):
|
|
"""A path used in <copyfile> or <linkfile> is incorrect."""
|
|
|
|
|
|
class NoManifestException(RepoExitError):
|
|
"""The required manifest does not exist."""
|
|
|
|
def __init__(self, path, reason, **kwargs):
|
|
super().__init__(path, reason, **kwargs)
|
|
self.path = path
|
|
self.reason = reason
|
|
|
|
def __str__(self):
|
|
return self.reason
|
|
|
|
|
|
class EditorError(RepoError):
|
|
"""Unspecified error from the user's text editor."""
|
|
|
|
def __init__(self, reason, **kwargs):
|
|
super().__init__(reason, **kwargs)
|
|
self.reason = reason
|
|
|
|
def __str__(self):
|
|
return self.reason
|
|
|
|
|
|
class GitError(RepoError):
|
|
"""Unspecified git related error."""
|
|
|
|
def __init__(self, message, command_args=None, **kwargs):
|
|
super().__init__(message, **kwargs)
|
|
self.message = message
|
|
self.command_args = command_args
|
|
|
|
def __str__(self):
|
|
return self.message
|
|
|
|
|
|
class GitAuthError(RepoExitError):
|
|
"""Cannot talk to remote due to auth issue."""
|
|
|
|
|
|
class GitcUnsupportedError(RepoExitError):
|
|
"""Gitc no longer supported."""
|
|
|
|
|
|
class UploadError(RepoError):
|
|
"""A bundle upload to Gerrit did not succeed."""
|
|
|
|
def __init__(self, reason, **kwargs):
|
|
super().__init__(reason, **kwargs)
|
|
self.reason = reason
|
|
|
|
def __str__(self):
|
|
return self.reason
|
|
|
|
|
|
class DownloadError(RepoExitError):
|
|
"""Cannot download a repository."""
|
|
|
|
def __init__(self, reason, **kwargs):
|
|
super().__init__(reason, **kwargs)
|
|
self.reason = reason
|
|
|
|
def __str__(self):
|
|
return self.reason
|
|
|
|
|
|
class InvalidArgumentsError(RepoExitError):
|
|
"""Invalid command Arguments."""
|
|
|
|
|
|
class SyncError(RepoExitError):
|
|
"""Cannot sync repo."""
|
|
|
|
|
|
class UpdateManifestError(RepoExitError):
|
|
"""Cannot update manifest."""
|
|
|
|
|
|
class NoSuchProjectError(RepoExitError):
|
|
"""A specified project does not exist in the work tree."""
|
|
|
|
def __init__(self, name=None, **kwargs):
|
|
super().__init__(**kwargs)
|
|
self.name = name
|
|
|
|
def __str__(self):
|
|
if self.name is None:
|
|
return "in current directory"
|
|
return self.name
|
|
|
|
|
|
class InvalidProjectGroupsError(RepoExitError):
|
|
"""A specified project is not suitable for the specified groups"""
|
|
|
|
def __init__(self, name=None, **kwargs):
|
|
super().__init__(**kwargs)
|
|
self.name = name
|
|
|
|
def __str__(self):
|
|
if self.name is None:
|
|
return "in current directory"
|
|
return self.name
|
|
|
|
|
|
class RepoChangedException(BaseRepoError):
|
|
"""Thrown if 'repo sync' results in repo updating its internal
|
|
repo or manifest repositories. In this special case we must
|
|
use exec to re-execute repo with the new code and manifest.
|
|
"""
|
|
|
|
def __init__(self, extra_args=None):
|
|
super().__init__(extra_args)
|
|
self.extra_args = extra_args or []
|
|
|
|
|
|
class HookError(RepoError):
|
|
"""Thrown if a 'repo-hook' could not be run.
|
|
|
|
The common case is that the file wasn't present when we tried to run it.
|
|
"""
|