/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 tests/test_blackbox.py

Implement _bisect_recursive, which uses multiple bisect calls to
handle renames and finding entries in subdirs.
As is, this could be hooked into paths2ids() if the dirstate has not been loaded yet.
However, it doesn't quite provide enough, since the parsed entries would probably not
be saved. Further, the multiple bisect calls are less efficient then they could be,
because they do not remember the last bisect call.
We should explore switching to a caching structure, which maintains all records that
have been processed, in a structure that can be in-memory searched before going back
to disk.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2007 David Allouche <ddaa@ddaa.net>
2
 
#
3
 
# This program is free software; you can redistribute it and/or modify
4
 
# it under the terms of the GNU General Public License as published by
5
 
# the Free Software Foundation; either version 2 of the License, or
6
 
# (at your option) any later version.
7
 
#
8
 
# This program is distributed in the hope that it will be useful,
9
 
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
 
# GNU General Public License for more details.
12
 
#
13
 
# You should have received a copy of the GNU General Public License
14
 
# 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
 
 
17
 
"""Black-box tests for bzr-git."""
18
 
 
19
 
from dulwich.repo import (
20
 
    Repo as GitRepo,
21
 
    )
22
 
 
23
 
import os
24
 
 
25
 
from bzrlib.bzrdir import (
26
 
    BzrDir,
27
 
    )
28
 
 
29
 
from bzrlib.tests.blackbox import ExternalBase
30
 
 
31
 
from bzrlib.plugins.git import (
32
 
    tests,
33
 
    )
34
 
 
35
 
 
36
 
class TestGitBlackBox(ExternalBase):
37
 
 
38
 
    def simple_commit(self):
39
 
        # Create a git repository with a revision.
40
 
        repo = GitRepo.init(self.test_dir)
41
 
        builder = tests.GitBranchBuilder()
42
 
        builder.set_file('a', 'text for a\n', False)
43
 
        r1 = builder.commit('Joe Foo <joe@foo.com>', u'<The commit message>')
44
 
        return repo, builder.finish()[r1]
45
 
 
46
 
    def test_nick(self):
47
 
        GitRepo.init(self.test_dir)
48
 
        dir = BzrDir.open(self.test_dir)
49
 
        dir.create_branch()
50
 
        output, error = self.run_bzr(['nick'])
51
 
        self.assertEquals("HEAD\n", output)
52
 
 
53
 
    def test_info(self):
54
 
        self.simple_commit()
55
 
        output, error = self.run_bzr(['info'])
56
 
        self.assertEqual(error, '')
57
 
        self.assertTrue("Standalone tree (format: git)" in output)
58
 
 
59
 
    def test_branch(self):
60
 
        os.mkdir("gitbranch")
61
 
        GitRepo.init(os.path.join(self.test_dir, "gitbranch"))
62
 
        os.chdir('gitbranch')
63
 
        builder = tests.GitBranchBuilder()
64
 
        builder.set_file('a', 'text for a\n', False)
65
 
        builder.commit('Joe Foo <joe@foo.com>', u'<The commit message>')
66
 
        builder.finish()
67
 
        os.chdir('..')
68
 
 
69
 
        output, error = self.run_bzr(['branch', 'gitbranch', 'bzrbranch'])
70
 
        self.assertEqual(error, 'Branched 1 revision(s).\n')
71
 
 
72
 
    def test_branch_ls(self):
73
 
        self.simple_commit()
74
 
        output, error = self.run_bzr(['ls', '-r-1'])
75
 
        self.assertEqual(error, '')
76
 
        self.assertEqual(output, "a\n")
77
 
 
78
 
    def test_init(self):
79
 
        self.run_bzr("init-repo --git repo") 
80
 
 
81
 
    def test_info_verbose(self):
82
 
        self.simple_commit()
83
 
 
84
 
        output, error = self.run_bzr(['info', '-v'])
85
 
        self.assertEqual(error, '')
86
 
        self.assertTrue("Standalone tree (format: git)" in output)
87
 
        self.assertTrue("control: Local Git Repository" in output)
88
 
        self.assertTrue("branch: Git Branch" in output)
89
 
        self.assertTrue("repository: Git Repository" in output)
90
 
 
91
 
    def test_push(self):
92
 
        os.mkdir("bla")
93
 
        GitRepo.init(os.path.join(self.test_dir, "bla"))
94
 
        self.run_bzr(['init', 'foo'])
95
 
        self.run_bzr(['commit', '--unchanged', '-m', 'bla', 'foo'])
96
 
        output, error = self.run_bzr(['push', '-d', 'foo', 'bla'])
97
 
        self.assertEquals("", output)
98
 
        self.assertTrue(error.endswith("Created new branch.\n"))
99
 
 
100
 
    def test_log(self):
101
 
        # Smoke test for "bzr log" in a git repository.
102
 
        self.simple_commit()
103
 
 
104
 
        # Check that bzr log does not fail and includes the revision.
105
 
        output, error = self.run_bzr(['log'])
106
 
        self.assertEqual(error, '')
107
 
        self.assertTrue(
108
 
            '<The commit message>' in output,
109
 
            "Commit message was not found in output:\n%s" % (output,))
110
 
 
111
 
    def test_log_verbose(self):
112
 
        # Smoke test for "bzr log -v" in a git repository.
113
 
        self.simple_commit()
114
 
 
115
 
        # Check that bzr log does not fail and includes the revision.
116
 
        output, error = self.run_bzr(['log', '-v'])
117
 
 
118
 
    def test_tags(self):
119
 
        git_repo, commit_sha1 = self.simple_commit()
120
 
        git_repo.refs["refs/tags/foo"] = commit_sha1
121
 
 
122
 
        output, error = self.run_bzr(['tags'])
123
 
        self.assertEquals(error, '')
124
 
        self.assertEquals(output, "foo                  1\n")
125
 
 
126
 
    def test_tag(self):
127
 
        self.simple_commit()
128
 
 
129
 
        output, error = self.run_bzr(["tag", "bar"])
130
 
 
131
 
        self.assertEquals(error, '')
132
 
        self.assertEquals(output, 'Created tag bar.\n')
133
 
 
134
 
    def test_init_repo(self):
135
 
        output, error = self.run_bzr(["init-repo", "--git", "bla.git"])
136
 
        self.assertEquals(error, '')
137
 
        self.assertEquals(output, 'Unshared repository with trees (format: git)\nLocation:\n  repository: bla.git\n')
138