~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/selftest/teststatus.py

  • Committer: Martin Pool
  • Date: 2005-09-06 07:26:13 UTC
  • Revision ID: mbp@sourcefrog.net-20050906072613-1a4a18769aaaa3eb
- add xml round-trip test for revisions

- fix up __eq__ method for Revision

Show diffs side-by-side

added added

removed removed

Lines of Context:
21
21
"""
22
22
 
23
23
 
24
 
from cStringIO import StringIO
25
 
from os import mkdir
26
 
from tempfile import TemporaryFile
27
 
import codecs
28
 
 
29
 
from bzrlib.tests import TestCaseInTempDir
30
 
from bzrlib.revisionspec import RevisionSpec
31
 
from bzrlib.merge import merge
32
 
from bzrlib.status import show_status
33
 
from bzrlib.branch import Branch
34
 
from bzrlib.clone import copy_branch
 
24
from bzrlib.selftest import TestCaseInTempDir
35
25
 
36
26
class BranchStatus(TestCaseInTempDir):
37
27
    
38
28
    def test_branch_status(self): 
39
 
        """Test basic branch status"""
 
29
        """Basic 'bzr mkdir' operation"""
 
30
        from cStringIO import StringIO
40
31
        from bzrlib.status import show_status
41
32
        from bzrlib.branch import Branch
42
33
        
43
 
        b = Branch.initialize(u'.')
 
34
        b = Branch('.', init=True)
44
35
 
45
36
        # status with nothing
46
37
        tof = StringIO()
49
40
 
50
41
        tof = StringIO()
51
42
        self.build_tree(['hello.c', 'bye.c'])
52
 
        b.working_tree().add_pending_merge('pending@pending-0-0')
 
43
        b.add_pending_merge('pending@pending-0-0')
53
44
        show_status(b, to_file=tof)
54
45
        tof.seek(0)
55
46
        self.assertEquals(tof.readlines(),
60
51
                           '  pending@pending-0-0\n'
61
52
                           ])
62
53
 
63
 
    def test_branch_status_revisions(self):
64
 
        """Tests branch status with revisions"""
65
 
        
66
 
        b = Branch.initialize(u'.')
67
 
 
68
 
        tof = StringIO()
69
 
        self.build_tree(['hello.c', 'bye.c'])
70
 
        b.working_tree().add('hello.c')
71
 
        b.working_tree().add('bye.c')
72
 
        b.working_tree().commit('Test message')
73
 
 
74
 
        tof = StringIO()
75
 
        revs =[]
76
 
        revs.append(RevisionSpec(0))
77
 
        
78
 
        show_status(b, to_file=tof, revision=revs)
79
 
        
80
 
        tof.seek(0)
81
 
        self.assertEquals(tof.readlines(),
82
 
                          ['added:\n',
83
 
                           '  bye.c\n',
84
 
                           '  hello.c\n'])
85
 
 
86
 
        self.build_tree(['more.c'])
87
 
        b.working_tree().add('more.c')
88
 
        b.working_tree().commit('Another test message')
89
 
        
90
 
        tof = StringIO()
91
 
        revs.append(RevisionSpec(1))
92
 
        
93
 
        show_status(b, to_file=tof, revision=revs)
94
 
        
95
 
        tof.seek(0)
96
 
        self.assertEquals(tof.readlines(),
97
 
                          ['added:\n',
98
 
                           '  bye.c\n',
99
 
                           '  hello.c\n'])
100
 
 
101
 
    def status_string(self, branch):
102
 
        # use a real file rather than StringIO because it doesn't handle
103
 
        # Unicode very well.
104
 
        tof = codecs.getwriter('utf-8')(TemporaryFile())
105
 
        show_status(branch, to_file=tof)
106
 
        tof.seek(0)
107
 
        return tof.read().decode('utf-8')
108
 
 
109
 
    def test_pending(self):
110
 
        """Pending merges display works, including Unicode"""
111
 
        mkdir("./branch")
112
 
        b = Branch.initialize('./branch')
113
 
        b.working_tree().commit("Empty commit 1")
114
 
        b_2 = copy_branch(b, './copy')
115
 
        b.working_tree().commit(u"\N{TIBETAN DIGIT TWO} Empty commit 2")
116
 
        merge(["./branch", -1], [None, None], this_dir = './copy')
117
 
        message = self.status_string(b_2)
118
 
        self.assert_(message.startswith("pending merges:\n"))
119
 
        self.assert_(message.endswith("Empty commit 2\n")) 
120
 
        b_2.working_tree().commit("merged")
121
 
        # must be long to make sure we see elipsis at the end
122
 
        b.working_tree().commit("Empty commit 3 " + 
123
 
                                "blah blah blah blah " * 10)
124
 
        merge(["./branch", -1], [None, None], this_dir = './copy')
125
 
        message = self.status_string(b_2)
126
 
        self.assert_(message.startswith("pending merges:\n"))
127
 
        self.assert_("Empty commit 3" in message)
128
 
        self.assert_(message.endswith("...\n")) 
129
 
 
130
 
    def test_branch_status_specific_files(self): 
131
 
        """Tests branch status with given specific files"""
132
 
        from cStringIO import StringIO
133
 
        from bzrlib.status import show_status
134
 
        from bzrlib.branch import Branch
135
 
        
136
 
        b = Branch.initialize(u'.')
137
 
 
138
 
        self.build_tree(['directory/','directory/hello.c', 'bye.c','test.c','dir2/'])
139
 
        b.working_tree().add('directory')
140
 
        b.working_tree().add('test.c')
141
 
        b.working_tree().commit('testing')
142
 
        
143
 
        tof = StringIO()
144
 
        show_status(b, to_file=tof)
145
 
        tof.seek(0)
146
 
        self.assertEquals(tof.readlines(),
147
 
                          ['unknown:\n',
148
 
                           '  bye.c\n',
149
 
                           '  dir2\n',
150
 
                           '  directory/hello.c\n'
151
 
                           ])
152
 
 
153
 
        tof = StringIO()
154
 
        show_status(b, specific_files=['bye.c','test.c','absent.c'], to_file=tof)
155
 
        tof.seek(0)
156
 
        self.assertEquals(tof.readlines(),
157
 
                          ['unknown:\n',
158
 
                           '  bye.c\n'
159
 
                           ])
160
 
        
161
 
        tof = StringIO()
162
 
        show_status(b, specific_files=['directory'], to_file=tof)
163
 
        tof.seek(0)
164
 
        self.assertEquals(tof.readlines(),
165
 
                          ['unknown:\n',
166
 
                           '  directory/hello.c\n'
167
 
                           ])
168
 
        tof = StringIO()
169
 
        show_status(b, specific_files=['dir2'], to_file=tof)
170
 
        tof.seek(0)
171
 
        self.assertEquals(tof.readlines(),
172
 
                          ['unknown:\n',
173
 
                           '  dir2\n'
174
 
                           ])