diff options
| author | Antoine Musso <hashar@free.fr> | 2014-11-16 20:15:50 +0100 | 
|---|---|---|
| committer | Antoine Musso <hashar@free.fr> | 2014-11-16 20:46:41 +0100 | 
| commit | f5d11b750ecc982541d1f936488248f0b42d75d3 (patch) | |
| tree | 8be522510315f5adc32c0c55acd45dc1074294da /git/test/test_submodule.py | |
| parent | 7aba59a2609ec768d5d495dafd23a4bce8179741 (diff) | |
| download | gitpython-f5d11b750ecc982541d1f936488248f0b42d75d3.tar.gz | |
pep8 linting (whitespaces)
W191 indentation contains tabs
E221 multiple spaces before operator
E222 multiple spaces after operator
E225 missing whitespace around operator
E271 multiple spaces after keyword
W292 no newline at end of file
W293 blank line contains whitespace
W391 blank line at end of file
Diffstat (limited to 'git/test/test_submodule.py')
| -rw-r--r-- | git/test/test_submodule.py | 201 | 
1 files changed, 100 insertions, 101 deletions
| diff --git a/git/test/test_submodule.py b/git/test/test_submodule.py index 37bf9f13..827705cf 100644 --- a/git/test/test_submodule.py +++ b/git/test/test_submodule.py @@ -26,10 +26,10 @@ if sys.platform == 'win32':  class TestRootProgress(RootUpdateProgress):      """Just prints messages, for now without checking the correctness of the states""" -     +      def update(self, op, index, max_count, message=''):          print message -         +  prog = TestRootProgress()  class TestSubmodule(TestBase): @@ -37,7 +37,7 @@ class TestSubmodule(TestBase):      k_subm_current = "468cad66ff1f80ddaeee4123c24e4d53a032c00d"      k_subm_changed = "394ed7006ee5dc8bddfd132b64001d5dfc0ffdd3"      k_no_subm_tag = "0.1.6" -     +      def _do_base_tests(self, rwrepo):          """Perform all tests in the given repository, it may be bare or nonbare""" @@ -45,15 +45,15 @@ class TestSubmodule(TestBase):          smm = Submodule(rwrepo, "\0"*20)          # name needs to be set in advance          self.failUnlessRaises(AttributeError, getattr, smm, 'name')  -         +          # iterate - 1 submodule          sms = Submodule.list_items(rwrepo, self.k_subm_current)          assert len(sms) == 1          sm = sms[0] -         +          # at a different time, there is None          assert len(Submodule.list_items(rwrepo, self.k_no_subm_tag)) == 0 -         +          assert sm.path == 'git/ext/gitdb'          assert sm.path != sm.name                   # in our case, we have ids there, which don't equal the path          assert sm.url == 'git://github.com/gitpython-developers/gitdb.git' @@ -64,22 +64,22 @@ class TestSubmodule(TestBase):          assert sm.size == 0          # the module is not checked-out yet          self.failUnlessRaises(InvalidGitRepositoryError, sm.module) -         +          # which is why we can't get the branch either - it points into the module() repository          self.failUnlessRaises(InvalidGitRepositoryError, getattr, sm, 'branch') -         +          # branch_path works, as its just a string          assert isinstance(sm.branch_path, basestring) -         +          # some commits earlier we still have a submodule, but its at a different commit          smold = Submodule.iter_items(rwrepo, self.k_subm_changed).next()          assert smold.binsha != sm.binsha          assert smold != sm                  # the name changed -         +          # force it to reread its information          del(smold._url)          smold.url == sm.url -         +          # test config_reader/writer methods          sm.config_reader()          new_smclone_path = None             # keep custom paths for later  @@ -96,25 +96,25 @@ class TestSubmodule(TestBase):              assert sm.url == new_smclone_path          # END handle bare repo          smold.config_reader() -         +          # cannot get a writer on historical submodules          if not rwrepo.bare:              self.failUnlessRaises(ValueError, smold.config_writer)          # END handle bare repo -         +          # make the old into a new - this doesn't work as the name changed          prev_parent_commit = smold.parent_commit          self.failUnlessRaises(ValueError, smold.set_parent_commit, self.k_subm_current)          # the sha is properly updated          smold.set_parent_commit(self.k_subm_changed+"~1")          assert smold.binsha != sm.binsha -         +          # raises if the sm didn't exist in new parent - it keeps its           # parent_commit unchanged          self.failUnlessRaises(ValueError, smold.set_parent_commit, self.k_no_subm_tag) -         +          # TEST TODO: if a path in the gitmodules file, but not in the index, it raises -         +          # TEST UPDATE          ##############          # module retrieval is not always possible @@ -126,107 +126,107 @@ class TestSubmodule(TestBase):              # its not checked out in our case              self.failUnlessRaises(InvalidGitRepositoryError, sm.module)              assert not sm.module_exists() -             +              # currently there is only one submodule              assert len(list(rwrepo.iter_submodules())) == 1              assert sm.binsha != "\0"*20 -             +              # TEST ADD              ###########              # preliminary tests              # adding existing returns exactly the existing              sma = Submodule.add(rwrepo, sm.name, sm.path)              assert sma.path == sm.path -             +              # no url and no module at path fails              self.failUnlessRaises(ValueError, Submodule.add, rwrepo, "newsubm", "pathtorepo", url=None) -             +              # CONTINUE UPDATE              ################# -             +              # lets update it - its a recursive one too              newdir = os.path.join(sm.abspath, 'dir')              os.makedirs(newdir) -             +              # update fails if the path already exists non-empty              self.failUnlessRaises(OSError, sm.update)              os.rmdir(newdir) -             +              # dry-run does nothing              sm.update(dry_run=True, progress=prog)              assert not sm.module_exists() -             +              assert sm.update() is sm              sm_repopath = sm.path               # cache for later              assert sm.module_exists()              assert isinstance(sm.module(), git.Repo)              assert sm.module().working_tree_dir == sm.abspath -             +              # INTERLEAVE ADD TEST              #####################              # url must match the one in the existing repository ( if submodule name suggests a new one )              # or we raise              self.failUnlessRaises(ValueError, Submodule.add, rwrepo, "newsubm", sm.path, "git://someurl/repo.git") -             -             + +              # CONTINUE UPDATE              #################              # we should have setup a tracking branch, which is also active              assert sm.module().head.ref.tracking_branch() is not None -             +              # delete the whole directory and re-initialize              shutil.rmtree(sm.abspath)              assert len(sm.children()) == 0              # dry-run does nothing              sm.update(dry_run=True, recursive=False, progress=prog)              assert len(sm.children()) == 0 -             +              sm.update(recursive=False)              assert len(list(rwrepo.iter_submodules())) == 2              assert len(sm.children()) == 1          # its not checked out yet              csm = sm.children()[0]              assert not csm.module_exists()              csm_repopath = csm.path -             +              # adjust the path of the submodules module to point to the local destination              new_csmclone_path = to_native_path_linux(join_path_native(self.rorepo.working_tree_dir, sm.path, csm.path))              csm.config_writer().set_value('url', new_csmclone_path)              assert csm.url == new_csmclone_path -             +              # dry-run does nothing              assert not csm.module_exists()              sm.update(recursive=True, dry_run=True, progress=prog)              assert not csm.module_exists() -             +              # update recursively again              sm.update(recursive=True)              assert csm.module_exists() -             +              # tracking branch once again              csm.module().head.ref.tracking_branch() is not None -             +              # this flushed in a sub-submodule              assert len(list(rwrepo.iter_submodules())) == 2 -             -             + +              # reset both heads to the previous version, verify that to_latest_revision works              smods = (sm.module(), csm.module())              for repo in smods:                  repo.head.reset('HEAD~2', working_tree=1)              # END for each repo to reset -             +              # dry run does nothing               sm.update(recursive=True, dry_run=True, progress=prog)              for repo in smods:                  assert repo.head.commit != repo.head.ref.tracking_branch().commit              # END for each repo to check -             +              sm.update(recursive=True, to_latest_revision=True)              for repo in smods:                  assert repo.head.commit == repo.head.ref.tracking_branch().commit              # END for each repo to check              del(smods) -             +              # if the head is detached, it still works ( but warns )              smref = sm.module().head.ref              sm.module().head.ref = 'HEAD~1' @@ -234,15 +234,15 @@ class TestSubmodule(TestBase):              csm_tracking_branch = csm.module().head.ref.tracking_branch()              csm.module().head.ref.set_tracking_branch(None)              sm.update(recursive=True, to_latest_revision=True) -             +              # to_latest_revision changes the child submodule's commit, it needs an              # update now              csm.set_parent_commit(csm.repo.head.commit) -             +              # undo the changes              sm.module().head.ref = smref              csm.module().head.ref.set_tracking_branch(csm_tracking_branch) -             +              # REMOVAL OF REPOSITOTRY              ########################              # must delete something @@ -260,21 +260,21 @@ class TestSubmodule(TestBase):              # still, we have the file modified              self.failUnlessRaises(InvalidGitRepositoryError, sm.remove, dry_run=True)              sm.module().index.reset(working_tree=True) -             +              # enforce the submodule to be checked out at the right spot as well.              csm.update() -             +              # this would work              assert sm.remove(dry_run=True) is sm              assert sm.module_exists()              sm.remove(force=True, dry_run=True)              assert sm.module_exists() -             +              # but ... we have untracked files in the child submodule              fn = join_path_native(csm.module().working_tree_dir, "newfile")              open(fn, 'w').write("hi")              self.failUnlessRaises(InvalidGitRepositoryError, sm.remove) -             +              # forcibly delete the child repository              prev_count = len(sm.children())              assert csm.remove(force=True) is csm @@ -284,21 +284,21 @@ class TestSubmodule(TestBase):              # now we have a changed index, as configuration was altered.              # fix this              sm.module().index.reset(working_tree=True) -             +              # now delete only the module of the main submodule              assert sm.module_exists()              sm.remove(configuration=False)              assert sm.exists()              assert not sm.module_exists()              assert sm.config_reader().get_value('url') -             +              # delete the rest              sm.remove()              assert not sm.exists()              assert not sm.module_exists() -             +              assert len(rwrepo.submodules) == 0 -             +              # ADD NEW SUBMODULE              ###################              # add a simple remote repo - trailing slashes are no problem @@ -311,33 +311,33 @@ class TestSubmodule(TestBase):              # its not checked out              assert not os.path.isfile(join_path_native(nsm.module().working_tree_dir, Submodule.k_modules_file))              assert len(rwrepo.submodules) == 1 -             +              # add another submodule, but into the root, not as submodule              osm = Submodule.add(rwrepo, osmid, csm_repopath, new_csmclone_path, Submodule.k_head_default)              assert osm != nsm              assert osm.module_exists()              assert osm.exists()              assert os.path.isfile(join_path_native(osm.module().working_tree_dir, 'setup.py')) -             +              assert len(rwrepo.submodules) == 2 -             +              # commit the changes, just to finalize the operation              rwrepo.index.commit("my submod commit")              assert len(rwrepo.submodules) == 2 -             +              # needs update as the head changed, it thinks its in the history               # of the repo otherwise              nsm.set_parent_commit(rwrepo.head.commit)              osm.set_parent_commit(rwrepo.head.commit) -             +              # MOVE MODULE              #############              # invalid inptu              self.failUnlessRaises(ValueError, nsm.move, 'doesntmatter', module=False, configuration=False) -             +              # renaming to the same path does nothing              assert nsm.move(sm.path) is nsm -             +              # rename a module              nmp = join_path_native("new", "module", "dir") + "/" # new module path              pmp = nsm.path @@ -347,49 +347,49 @@ class TestSubmodule(TestBase):              nmpl = to_native_path_linux(nmp)              assert nsm.path == nmpl              assert rwrepo.submodules[0].path == nmpl -             +              mpath = 'newsubmodule'              absmpath = join_path_native(rwrepo.working_tree_dir, mpath)              open(absmpath, 'w').write('')              self.failUnlessRaises(ValueError, nsm.move, mpath)              os.remove(absmpath) -             +              # now it works, as we just move it back              nsm.move(pmp)              assert nsm.path == pmp              assert rwrepo.submodules[0].path == pmp -             +              # TODO lowprio: test remaining exceptions ... for now its okay, the code looks right -             +              # REMOVE 'EM ALL              ################              # if a submodule's repo has no remotes, it can't be added without an explicit url              osmod = osm.module() -             +              osm.remove(module=False)              for remote in osmod.remotes:                  remote.remove(osmod, remote.name)              assert not osm.exists()              self.failUnlessRaises(ValueError, Submodule.add, rwrepo, osmid, csm_repopath, url=None)             # END handle bare mode -         +          # Error if there is no submodule file here          self.failUnlessRaises(IOError, Submodule._config_parser, rwrepo, rwrepo.commit(self.k_no_subm_tag), True) -         +      @with_rw_repo(k_subm_current)      def test_base_rw(self, rwrepo):          self._do_base_tests(rwrepo) -         +      @with_rw_repo(k_subm_current, bare=True)      def test_base_bare(self, rwrepo):          self._do_base_tests(rwrepo) -         +      @with_rw_repo(k_subm_current, bare=False)      def test_root_module(self, rwrepo):          # Can query everything without problems          rm = RootModule(self.rorepo)          assert rm.module() is self.rorepo -         +          # try attributes          rm.binsha          rm.mode @@ -398,24 +398,24 @@ class TestSubmodule(TestBase):          assert rm.parent_commit == self.rorepo.head.commit          rm.url          rm.branch -         +          assert len(rm.list_items(rm.module())) == 1          rm.config_reader()          rm.config_writer() -         +          # deep traversal gitdb / async          rsmsp = [sm.path for sm in rm.traverse()]          assert len(rsmsp) >= 2          # gitdb and async [and smmap], async being a child of gitdb -         +          # cannot set the parent commit as root module's path didn't exist          self.failUnlessRaises(ValueError, rm.set_parent_commit, 'HEAD') -         +          # TEST UPDATE          #############          # setup commit which remove existing, add new and modify existing submodules          rm = RootModule(rwrepo)          assert len(rm.children()) == 1 -         +          # modify path without modifying the index entry          # ( which is what the move method would do properly )          #================================================== @@ -424,37 +424,37 @@ class TestSubmodule(TestBase):          fp = join_path_native(pp, sm.path)          prep = sm.path          assert not sm.module_exists()               # was never updated after rwrepo's clone -         +          # assure we clone from a local source           sm.config_writer().set_value('url', to_native_path_linux(join_path_native(self.rorepo.working_tree_dir, sm.path))) -         +          # dry-run does nothing          sm.update(recursive=False, dry_run=True, progress=prog)          assert not sm.module_exists() -         +          sm.update(recursive=False)          assert sm.module_exists()          sm.config_writer().set_value('path', fp)    # change path to something with prefix AFTER url change -         +          # update fails as list_items in such a situations cannot work, as it cannot          # find the entry at the changed path          self.failUnlessRaises(InvalidGitRepositoryError, rm.update, recursive=False) -         +          # move it properly - doesn't work as it its path currently points to an indexentry          # which doesn't exist ( move it to some path, it doesn't matter here )          self.failUnlessRaises(InvalidGitRepositoryError, sm.move, pp)          # reset the path(cache) to where it was, now it works          sm.path = prep          sm.move(fp, module=False)       # leave it at the old location -         +          assert not sm.module_exists()          cpathchange = rwrepo.index.commit("changed sm path") # finally we can commit -         +          # update puts the module into place          rm.update(recursive=False, progress=prog)          sm.set_parent_commit(cpathchange)          assert sm.module_exists() -         +          # add submodule          #================          nsmn = "newsubmodule" @@ -468,17 +468,17 @@ class TestSubmodule(TestBase):          # repo and a new submodule comes into life          nsm.remove(configuration=False, module=True)          assert not nsm.module_exists() and nsm.exists() -         -         + +          # dry-run does nothing          rm.update(recursive=False, dry_run=True, progress=prog) -         +          # otherwise it will work          rm.update(recursive=False, progress=prog)          assert nsm.module_exists() -         -         -         + + +          # remove submodule - the previous one          #====================================          sm.set_parent_commit(csmadded) @@ -486,16 +486,16 @@ class TestSubmodule(TestBase):          assert not sm.remove(module=False).exists()          assert os.path.isdir(smp)           # module still exists          csmremoved = rwrepo.index.commit("Removed submodule") -         +          # an update will remove the module          # not in dry_run          rm.update(recursive=False, dry_run=True)          assert os.path.isdir(smp) -         +          rm.update(recursive=False)          assert not os.path.isdir(smp) -         -         + +          # change url           #=============          # to the first repository, this way we have a fast checkout, and a completely different  @@ -505,23 +505,23 @@ class TestSubmodule(TestBase):          nsm.config_writer().set_value('url', nsmurl)          csmpathchange = rwrepo.index.commit("changed url")          nsm.set_parent_commit(csmpathchange) -         +          prev_commit = nsm.module().head.commit          # dry-run does nothing          rm.update(recursive=False, dry_run=True, progress=prog)          assert nsm.module().remotes.origin.url != nsmurl -         +          rm.update(recursive=False, progress=prog)          assert nsm.module().remotes.origin.url == nsmurl          # head changed, as the remote url and its commit changed          assert prev_commit != nsm.module().head.commit -         +          # add the submodule's changed commit to the index, which is what the          # user would do          # beforehand, update our instance's binsha with the new one          nsm.binsha = nsm.module().head.commit.binsha          rwrepo.index.add([nsm]) -         +          # change branch          #=================          # we only have one branch, so we switch to a virtual one, and back  @@ -534,22 +534,22 @@ class TestSubmodule(TestBase):              csmbranchchange = rwrepo.index.commit("changed branch to %s" % branch)              nsm.set_parent_commit(csmbranchchange)          # END for each branch to change -         +          # Lets remove our tracking branch to simulate some changes          nsmmh = nsmm.head          assert nsmmh.ref.tracking_branch() is None                  # never set it up until now          assert not nsmmh.is_detached -         +          #dry run does nothing          rm.update(recursive=False, dry_run=True, progress=prog)          assert nsmmh.ref.tracking_branch() is None -         +          # the real thing does          rm.update(recursive=False, progress=prog) -         +          assert nsmmh.ref.tracking_branch() is not None          assert not nsmmh.is_detached -         +          # recursive update          # =================          # finally we recursively update a module, just to run the code at least once @@ -561,7 +561,6 @@ class TestSubmodule(TestBase):          nsmc.config_writer().set_value('url', async_url)          rm.update(recursive=True, progress=prog, dry_run=True)      # just to run the code          rm.update(recursive=True, progress=prog) -         +          # gitdb: has either 1 or 2 submodules depending on the version          assert len(nsm.children()) >= 1 and nsmc.module_exists() -         | 
