33
32
class TestParseIgnoreFile(TestCase):
35
34
def test_parse_fancy(self):
36
ignored = ignores.parse_ignore_file(BytesIO(
40
b'unicode\xc2\xb5\n' # u'\xb5'.encode('utf8')
44
b' xx \n' # whitespace
35
ignored = ignores.parse_ignore_file(StringIO(
39
'unicode\xc2\xb5\n' # u'\xb5'.encode('utf8')
48
self.assertEqual({u'./rootdir',
47
self.assertEqual(set(['./rootdir',
58
57
def test_parse_empty(self):
59
ignored = ignores.parse_ignore_file(BytesIO(b''))
58
ignored = ignores.parse_ignore_file(StringIO(''))
60
59
self.assertEqual(set([]), ignored)
62
61
def test_parse_non_utf8(self):
63
62
"""Lines with non utf 8 characters should be discarded."""
64
ignored = ignores.parse_ignore_file(BytesIO(
63
ignored = ignores.parse_ignore_file(StringIO(
68
self.assertEqual(set([
75
74
class TestUserIgnores(TestCaseInTempDir):
82
81
self.assertEqual(set(ignores.USER_DEFAULTS), user_ignores)
84
83
self.assertPathExists(ignore_path)
85
with open(ignore_path, 'rb') as f:
84
f = open(ignore_path, 'rb')
86
86
entries = ignores.parse_ignore_file(f)
87
89
self.assertEqual(set(ignores.USER_DEFAULTS), entries)
89
91
def test_use_existing(self):
90
patterns = [u'*.o', u'*.py[co]', u'\xe5*']
92
patterns = ['*.o', '*.py[co]', u'\xe5*']
91
93
ignores._set_user_ignores(patterns)
93
95
user_ignores = ignores.get_user_ignores()
139
141
added = ignores.add_unique_user_ignores(
140
142
['xxx', './bar', 'xxx', 'dir1/', 'dir2/', 'dir3\\'])
141
143
self.assertEqual(['xxx', 'dir2'], added)
142
self.assertEqual({'foo', './bar', u'b\xe5z',
143
'xxx', 'dir1', 'dir2', 'dir3'},
144
self.assertEqual(set(['foo', './bar', u'b\xe5z',
145
'xxx', 'dir1', 'dir2', 'dir3']),
144
146
ignores.get_user_ignores())
158
160
self.assertEqual(set(), ignores.get_runtime_ignores())
160
162
ignores.add_runtime_ignores(['foo'])
161
self.assertEqual({'foo'}, ignores.get_runtime_ignores())
163
self.assertEqual(set(['foo']), ignores.get_runtime_ignores())
163
165
def test_add_duplicate(self):
164
166
"""Adding the same ignore twice shouldn't add a new entry."""
165
167
ignores.add_runtime_ignores(['foo', 'bar'])
166
self.assertEqual({'foo', 'bar'}, ignores.get_runtime_ignores())
168
self.assertEqual(set(['foo', 'bar']), ignores.get_runtime_ignores())
168
170
ignores.add_runtime_ignores(['bar'])
169
self.assertEqual({'foo', 'bar'}, ignores.get_runtime_ignores())
171
self.assertEqual(set(['foo', 'bar']), ignores.get_runtime_ignores())
172
174
class TestTreeIgnores(TestCaseWithTransport):
174
176
def assertPatternsEquals(self, patterns):
175
with open(".bzrignore", "rb") as f:
176
contents = f.read().decode("utf-8").splitlines()
177
self.assertEqual(sorted(patterns), sorted(contents))
177
contents = open(".bzrignore", 'rU').read().strip().split('\n')
178
self.assertEquals(sorted(patterns), sorted(contents))
179
180
def test_new_file(self):
180
181
tree = self.make_branch_and_tree(".")
181
ignores.tree_ignores_add_patterns(tree, [u"myentry"])
182
ignores.tree_ignores_add_patterns(tree, ["myentry"])
182
183
self.assertTrue(tree.has_filename(".bzrignore"))
183
184
self.assertPatternsEquals(["myentry"])
185
186
def test_add_to_existing(self):
186
187
tree = self.make_branch_and_tree(".")
187
self.build_tree_contents([('.bzrignore', b"myentry1\n")])
188
self.build_tree_contents([('.bzrignore', "myentry1\n")])
188
189
tree.add([".bzrignore"])
189
ignores.tree_ignores_add_patterns(tree, [u"myentry2", u"foo"])
190
ignores.tree_ignores_add_patterns(tree, ["myentry2", "foo"])
190
191
self.assertPatternsEquals(["myentry1", "myentry2", "foo"])
192
193
def test_adds_ending_newline(self):
193
194
tree = self.make_branch_and_tree(".")
194
self.build_tree_contents([('.bzrignore', b"myentry1")])
195
self.build_tree_contents([('.bzrignore', "myentry1")])
195
196
tree.add([".bzrignore"])
196
ignores.tree_ignores_add_patterns(tree, [u"myentry2"])
197
ignores.tree_ignores_add_patterns(tree, ["myentry2"])
197
198
self.assertPatternsEquals(["myentry1", "myentry2"])
198
with open(".bzrignore") as f:
200
self.assertTrue(text.endswith(('\r\n', '\n', '\r')))
199
text = open(".bzrignore", 'r').read()
200
self.assertTrue(text.endswith('\r\n') or
201
text.endswith('\n') or
202
204
def test_does_not_add_dupe(self):
203
205
tree = self.make_branch_and_tree(".")
204
self.build_tree_contents([('.bzrignore', b"myentry\n")])
206
self.build_tree_contents([('.bzrignore', "myentry\n")])
205
207
tree.add([".bzrignore"])
206
ignores.tree_ignores_add_patterns(tree, [u"myentry"])
208
ignores.tree_ignores_add_patterns(tree, ["myentry"])
207
209
self.assertPatternsEquals(["myentry"])
209
211
def test_non_ascii(self):
212
214
u"myentry\u1234\n".encode('utf-8'))])
213
215
tree.add([".bzrignore"])
214
216
ignores.tree_ignores_add_patterns(tree, [u"myentry\u5678"])
215
self.assertPatternsEquals([u"myentry\u1234", u"myentry\u5678"])
217
self.assertPatternsEquals([u"myentry\u1234".encode('utf-8'),
218
u"myentry\u5678".encode('utf-8')])
217
220
def test_crlf(self):
218
221
tree = self.make_branch_and_tree(".")
219
self.build_tree_contents([('.bzrignore', b"myentry1\r\n")])
222
self.build_tree_contents([('.bzrignore', "myentry1\r\n")])
220
223
tree.add([".bzrignore"])
221
224
ignores.tree_ignores_add_patterns(tree, ["myentry2", "foo"])
222
with open('.bzrignore') as f:
223
self.assertEqual(f.read(), 'myentry1\r\nmyentry2\r\nfoo\r\n')
225
self.assertEquals(open('.bzrignore', 'rb').read(), 'myentry1\r\nmyentry2\r\nfoo\r\n')
224
226
self.assertPatternsEquals(["myentry1", "myentry2", "foo"])