39
def ls_equals(self, value, args=None):
43
out, err = self.run_bzr(command)
39
def ls_equals(self, value, *args):
40
out, err = self.run_bzr('ls', *args)
44
41
self.assertEqual('', err)
45
self.assertEqualDiff(value, out)
42
self.assertEqual(value, out)
47
44
def test_ls_null_verbose(self):
48
45
# Can't supply both
49
46
self.run_bzr_error(['Cannot set both --verbose and --null'],
50
'ls --verbose --null')
47
'ls', '--verbose', '--null')
52
49
def test_ls_basic(self):
53
50
"""Test the abilities of 'bzr ls'"""
54
self.ls_equals('.bzrignore\na\n')
55
self.ls_equals('? .bzrignore\n'
51
self.ls_equals('.bazaar\n.bzrignore\na\n')
52
self.ls_equals('I .bazaar/\n'
58
56
self.ls_equals('.bzrignore\n'
61
self.ls_equals('', '--ignored')
59
self.ls_equals('.bazaar\n', '--ignored')
62
60
self.ls_equals('', '--versioned')
63
self.ls_equals('.bzrignore\n'
61
self.ls_equals('.bazaar\n'
65
'--unknown --ignored --versioned')
66
self.ls_equals('', '--ignored --versioned')
67
self.ls_equals('.bzrignore\0a\0', '--null')
64
'--unknown', '--ignored', '--versioned')
65
self.ls_equals('.bazaar\n', '--ignored', '--versioned')
66
self.ls_equals('.bazaar\0.bzrignore\0a\0', '--null')
69
68
def test_ls_added(self):
71
self.ls_equals('? .bzrignore\n'
70
self.ls_equals('I .bazaar/\n'
74
74
self.wt.commit('add')
76
76
self.build_tree(['subdir/'])
77
self.ls_equals('? .bzrignore\n'
77
self.ls_equals('I .bazaar/\n'
81
82
self.build_tree(['subdir/b'])
82
83
self.wt.add(['subdir/', 'subdir/b', '.bzrignore'])
83
self.ls_equals('V .bzrignore\n'
84
self.ls_equals('I .bazaar/\n'
89
def test_show_ids(self):
90
self.build_tree(['subdir/'])
91
self.wt.add(['a', 'subdir'], ['a-id', 'subdir-id'])
100
'V subdir/ subdir-id\n',
101
'--show-ids --verbose')
102
self.ls_equals('.bzrignore\0\0'
104
'subdir\0subdir-id\0', '--show-ids --null')
106
91
def test_ls_recursive(self):
107
92
self.build_tree(['subdir/', 'subdir/b'])
108
93
self.wt.add(['a', 'subdir/', 'subdir/b', '.bzrignore'])
110
self.ls_equals('.bzrignore\n'
95
self.ls_equals('.bazaar\n'
113
99
, '--non-recursive')
115
self.ls_equals('V .bzrignore\n'
101
self.ls_equals('I .bazaar/\n'
118
, '--verbose --non-recursive')
105
, '--verbose', '--non-recursive')
120
107
# Check what happens in a sub-directory
121
108
os.chdir('subdir')
122
109
self.ls_equals('b\n')
123
110
self.ls_equals('b\0'
125
self.ls_equals('.bzrignore\n'
112
self.ls_equals('.bazaar\n'
130
self.ls_equals('.bzrignore\0'
118
self.ls_equals('.bazaar\0'
134
, '--from-root --null')
135
self.ls_equals('.bzrignore\n'
123
, '--from-root', '--null')
124
self.ls_equals('.bazaar\n'
138
, '--from-root --non-recursive')
140
def test_ls_path(self):
141
"""If a path is specified, files are listed with that prefix"""
142
self.build_tree(['subdir/', 'subdir/b'])
143
self.wt.add(['subdir', 'subdir/b'])
144
self.ls_equals('subdir/b\n' ,
147
self.ls_equals('../.bzrignore\n'
152
self.ls_equals('../.bzrignore\0'
157
self.ls_equals('? ../.bzrignore\n'
162
self.run_bzr_error('cannot specify both --from-root and PATH',
128
, '--from-root', '--non-recursive')
165
130
def test_ls_revision(self):
166
131
self.wt.add(['a'])
169
134
self.build_tree(['subdir/'])
171
136
# Check what happens when we supply a specific revision
172
self.ls_equals('a\n', '--revision 1')
137
self.ls_equals('a\n', '--revision', '1')
173
138
self.ls_equals('V a\n'
174
, '--verbose --revision 1')
139
, '--verbose', '--revision', '1')
176
141
os.chdir('subdir')
177
self.ls_equals('', '--revision 1')
179
def test_ls_branch(self):
180
"""If a branch is specified, files are listed from it"""
181
self.build_tree(['subdir/', 'subdir/b'])
182
self.wt.add(['subdir', 'subdir/b'])
183
self.wt.commit('committing')
184
branch = self.make_branch('branchdir')
185
branch.pull(self.wt.branch)
186
self.ls_equals('branchdir/subdir\n'
187
'branchdir/subdir/b\n',
189
self.ls_equals('branchdir/subdir\n'
190
'branchdir/subdir/b\n',
191
'branchdir --revision 1')
142
self.ls_equals('', '--revision', '1')
193
144
def test_ls_ignored(self):
194
145
# Now try to do ignored files.
195
146
self.wt.add(['a', '.bzrignore'])
197
148
self.build_tree(['blah.py', 'blah.pyo', 'user-ignore'])
198
self.ls_equals('.bzrignore\n'
149
self.ls_equals('.bazaar\n'
204
self.ls_equals('V .bzrignore\n'
156
self.ls_equals('I .bazaar/\n'
208
161
'I user-ignore\n'
210
self.ls_equals('blah.pyo\n'
163
self.ls_equals('.bazaar\n'
213
167
self.ls_equals('blah.py\n'