/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to breezy/git/tests/test_dir.py

  • Committer: Jelmer Vernooij
  • Date: 2020-02-19 23:18:42 UTC
  • mto: (7490.3.4 work)
  • mto: This revision was merged to the branch mainline in revision 7495.
  • Revision ID: jelmer@jelmer.uk-20200219231842-agwjh2db66cpajqg
Consistent return values.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2009-2018 Jelmer Vernooij <jelmer@jelmer.uk>
1
2
# Copyright (C) 2007 Canonical Ltd
2
3
#
3
4
# This program is free software; you can redistribute it and/or modify
12
13
#
13
14
# You should have received a copy of the GNU General Public License
14
15
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
17
 
17
18
"""Test the GitDir class"""
18
19
 
19
 
from bzrlib import bzrdir, errors
20
 
 
21
 
from bzrlib.plugins.git import dir, tests, workingtree
 
20
from __future__ import absolute_import
 
21
 
 
22
from dulwich.repo import Repo as GitRepo
 
23
import os
 
24
 
 
25
from ... import (
 
26
    controldir,
 
27
    errors,
 
28
    urlutils,
 
29
    )
 
30
from ...transport import get_transport
 
31
from ...tests import TestSkipped
 
32
 
 
33
from .. import (
 
34
    dir,
 
35
    tests,
 
36
    workingtree,
 
37
    )
22
38
 
23
39
 
24
40
class TestGitDir(tests.TestCaseInTempDir):
25
41
 
26
 
    _test_needs_features = [tests.GitCommandFeature]
 
42
    def test_get_head_branch_reference(self):
 
43
        GitRepo.init(".")
 
44
 
 
45
        gd = controldir.ControlDir.open('.')
 
46
        self.assertEqual(
 
47
            "%s,branch=master" %
 
48
            urlutils.local_path_to_url(os.path.abspath(".")),
 
49
            gd.get_branch_reference())
27
50
 
28
51
    def test_open_existing(self):
29
 
        tests.run_git('init')
 
52
        GitRepo.init(".")
30
53
 
31
 
        gd = bzrdir.BzrDir.open('.')
 
54
        gd = controldir.ControlDir.open('.')
32
55
        self.assertIsInstance(gd, dir.LocalGitDir)
33
56
 
 
57
    def test_open_ref_parent(self):
 
58
        r = GitRepo.init(".")
 
59
        cid = r.do_commit(message=b"message", ref=b'refs/heads/foo/bar')
 
60
        gd = controldir.ControlDir.open('.')
 
61
        self.assertRaises(errors.NotBranchError, gd.open_branch, 'foo')
 
62
 
34
63
    def test_open_workingtree(self):
35
 
        tests.run_git('init')
 
64
        r = GitRepo.init(".")
 
65
        r.do_commit(message=b"message")
36
66
 
37
 
        gd = bzrdir.BzrDir.open('.')
 
67
        gd = controldir.ControlDir.open('.')
38
68
        wt = gd.open_workingtree()
39
69
        self.assertIsInstance(wt, workingtree.GitWorkingTree)
40
70
 
41
71
    def test_open_workingtree_bare(self):
42
 
        tests.run_git('--bare', 'init')
 
72
        GitRepo.init_bare(".")
43
73
 
44
 
        gd = bzrdir.BzrDir.open('.')
 
74
        gd = controldir.ControlDir.open('.')
45
75
        self.assertRaises(errors.NoWorkingTree, gd.open_workingtree)
46
76
 
47
 
 
48
 
class TestGitDirFormat(tests.TestCaseInTempDir):
49
 
 
50
 
    _test_needs_features = [tests.GitCommandFeature]
 
77
    def test_git_file(self):
 
78
        gitrepo = GitRepo.init("blah", mkdir=True)
 
79
        self.build_tree_contents(
 
80
            [('foo/', ), ('foo/.git', b'gitdir: ../blah/.git\n')])
 
81
 
 
82
        gd = controldir.ControlDir.open('foo')
 
83
        self.assertEqual(gd.control_url.rstrip('/'),
 
84
                         urlutils.local_path_to_url(os.path.abspath(gitrepo.controldir())))
 
85
 
 
86
    def test_shared_repository(self):
 
87
        t = get_transport('.')
 
88
        self.assertRaises(
 
89
            errors.SharedRepositoriesUnsupported,
 
90
            dir.LocalGitControlDirFormat().initialize_on_transport_ex, t,
 
91
            shared_repo=True)
 
92
 
 
93
 
 
94
class TestGitDirFormat(tests.TestCase):
51
95
 
52
96
    def setUp(self):
53
97
        super(TestGitDirFormat, self).setUp()
54
 
        self.format = dir.LocalGitBzrDirFormat()
 
98
        self.format = dir.LocalGitControlDirFormat()
55
99
 
56
100
    def test_get_format_description(self):
57
 
        self.assertEquals("Local Git Repository",
58
 
                          self.format.get_format_description())
 
101
        self.assertEqual("Local Git Repository",
 
102
                         self.format.get_format_description())
59
103
 
 
104
    def test_eq(self):
 
105
        format2 = dir.LocalGitControlDirFormat()
 
106
        self.assertEqual(self.format, format2)
 
107
        self.assertEqual(self.format, self.format)
 
108
        bzr_format = controldir.format_registry.make_controldir("default")
 
109
        self.assertNotEqual(self.format, bzr_format)