diff options
Diffstat (limited to 'git/objects/submodule/base.py')
| -rw-r--r-- | git/objects/submodule/base.py | 24 | 
1 files changed, 19 insertions, 5 deletions
| diff --git a/git/objects/submodule/base.py b/git/objects/submodule/base.py index 90f796bd..bacfd8f0 100644 --- a/git/objects/submodule/base.py +++ b/git/objects/submodule/base.py @@ -1,4 +1,3 @@ -from . import util  from .util import (      mkhead,      sm_name, @@ -39,6 +38,9 @@ import git  import os  import logging  import uuid +from unittest.case import SkipTest +from git.test.lib.helper import HIDE_WINDOWS_KNOWN_ERRORS +from git.objects.base import IndexObject, Object  __all__ = ["Submodule", "UpdateProgress"] @@ -67,7 +69,7 @@ UPDWKTREE = UpdateProgress.UPDWKTREE  # IndexObject comes via util module, its a 'hacky' fix thanks to pythons import  # mechanism which cause plenty of trouble of the only reason for packages and  # modules is refactoring - subpackages shoudn't depend on parent packages -class Submodule(util.IndexObject, Iterable, Traversable): +class Submodule(IndexObject, Iterable, Traversable):      """Implements access to a git submodule. They are special in that their sha      represents a commit in the submodule's repository which is to be checked out @@ -526,7 +528,7 @@ class Submodule(util.IndexObject, Iterable, Traversable):                          # have a valid branch, but no checkout - make sure we can figure                          # that out by marking the commit with a null_sha -                        local_branch.set_object(util.Object(mrepo, self.NULL_BIN_SHA)) +                        local_branch.set_object(Object(mrepo, self.NULL_BIN_SHA))                          # END initial checkout + branch creation                          # make sure HEAD is not detached @@ -856,13 +858,25 @@ class Submodule(util.IndexObject, Iterable, Traversable):                      del(mod)        # release file-handles (windows)                      import gc                      gc.collect() -                    rmtree(wtd) +                    try: +                        rmtree(wtd) +                    except Exception as ex: +                        if HIDE_WINDOWS_KNOWN_ERRORS: +                            raise SkipTest("FIXME: fails with: PermissionError\n  %s", ex) +                        else: +                            raise                  # END delete tree if possible              # END handle force              if not dry_run and os.path.isdir(git_dir):                  self._clear_cache() -                rmtree(git_dir) +                try: +                    rmtree(git_dir) +                except Exception as ex: +                    if HIDE_WINDOWS_KNOWN_ERRORS: +                        raise SkipTest("FIXME: fails with: PermissionError\n  %s", ex) +                    else: +                        raise              # end handle separate bare repository          # END handle module deletion | 
