/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

  • Committer: Vincent Ladeuil
  • Date: 2010-01-25 15:55:48 UTC
  • mto: (4985.1.4 add-attr-cleanup)
  • mto: This revision was merged to the branch mainline in revision 4988.
  • Revision ID: v.ladeuil+lp@free.fr-20100125155548-0l352pujvt5bzl5e
Deploy addAttrCleanup on the whole test suite.

Several use case worth mentioning:

- setting a module or any other object attribute is the majority
by far. In some cases the setting itself is deferred but most of
the time we want to set at the same time we add the cleanup.

- there multiple occurrences of protecting hooks or ui factory
which are now useless (the test framework takes care of that now),

- there was some lambda uses that can now be avoided.

That first cleanup already simplifies things a lot.

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