57
76
def test_create_if_missing(self):
58
77
# $HOME should be set to '.'
59
78
ignore_path = config.user_ignore_config_filename()
60
self.failIfExists(ignore_path)
79
self.assertPathDoesNotExist(ignore_path)
61
80
user_ignores = ignores.get_user_ignores()
62
81
self.assertEqual(set(ignores.USER_DEFAULTS), user_ignores)
64
self.failUnlessExists(ignore_path)
83
self.assertPathExists(ignore_path)
65
84
f = open(ignore_path, 'rb')
67
86
entries = ignores.parse_ignore_file(f)
155
174
class TestTreeIgnores(TestCaseWithTransport):
176
def assertPatternsEquals(self, patterns):
177
contents = open(".bzrignore", 'rU').read().strip().split('\n')
178
self.assertEqual(sorted(patterns), sorted(contents))
157
180
def test_new_file(self):
158
181
tree = self.make_branch_and_tree(".")
159
182
ignores.tree_ignores_add_patterns(tree, ["myentry"])
160
183
self.assertTrue(tree.has_filename(".bzrignore"))
161
self.assertEquals("myentry\n",
162
open(".bzrignore", 'r').read())
184
self.assertPatternsEquals(["myentry"])
164
186
def test_add_to_existing(self):
165
187
tree = self.make_branch_and_tree(".")
166
188
self.build_tree_contents([('.bzrignore', "myentry1\n")])
167
189
tree.add([".bzrignore"])
168
190
ignores.tree_ignores_add_patterns(tree, ["myentry2", "foo"])
169
self.assertEquals("myentry1\nmyentry2\nfoo\n",
170
open(".bzrignore", 'r').read())
191
self.assertPatternsEquals(["myentry1", "myentry2", "foo"])
172
193
def test_adds_ending_newline(self):
173
194
tree = self.make_branch_and_tree(".")
174
195
self.build_tree_contents([('.bzrignore', "myentry1")])
175
196
tree.add([".bzrignore"])
176
197
ignores.tree_ignores_add_patterns(tree, ["myentry2"])
177
self.assertEquals("myentry1\nmyentry2\n",
178
open(".bzrignore", 'r').read())
198
self.assertPatternsEquals(["myentry1", "myentry2"])
199
text = open(".bzrignore", 'r').read()
200
self.assertTrue(text.endswith('\r\n') or
201
text.endswith('\n') or
204
def test_does_not_add_dupe(self):
205
tree = self.make_branch_and_tree(".")
206
self.build_tree_contents([('.bzrignore', "myentry\n")])
207
tree.add([".bzrignore"])
208
ignores.tree_ignores_add_patterns(tree, ["myentry"])
209
self.assertPatternsEquals(["myentry"])
211
def test_non_ascii(self):
212
tree = self.make_branch_and_tree(".")
213
self.build_tree_contents([('.bzrignore',
214
u"myentry\u1234\n".encode('utf-8'))])
215
tree.add([".bzrignore"])
216
ignores.tree_ignores_add_patterns(tree, [u"myentry\u5678"])
217
self.assertPatternsEquals([u"myentry\u1234".encode('utf-8'),
218
u"myentry\u5678".encode('utf-8')])
221
tree = self.make_branch_and_tree(".")
222
self.build_tree_contents([('.bzrignore', "myentry1\r\n")])
223
tree.add([".bzrignore"])
224
ignores.tree_ignores_add_patterns(tree, ["myentry2", "foo"])
225
self.assertEqual(open('.bzrignore', 'rb').read(), 'myentry1\r\nmyentry2\r\nfoo\r\n')
226
self.assertPatternsEquals(["myentry1", "myentry2", "foo"])