76
53
def test_create_if_missing(self):
77
54
# $HOME should be set to '.'
78
55
ignore_path = config.user_ignore_config_filename()
79
self.assertPathDoesNotExist(ignore_path)
56
self.failIfExists(ignore_path)
80
57
user_ignores = ignores.get_user_ignores()
81
58
self.assertEqual(set(ignores.USER_DEFAULTS), user_ignores)
83
self.assertPathExists(ignore_path)
60
self.failUnlessExists(ignore_path)
84
61
f = open(ignore_path, 'rb')
86
63
entries = ignores.parse_ignore_file(f)
174
155
class TestTreeIgnores(TestCaseWithTransport):
176
def assertPatternsEquals(self, patterns):
177
contents = open(".bzrignore", 'rU').read().strip().split('\n')
178
self.assertEquals(sorted(patterns), sorted(contents))
180
157
def test_new_file(self):
181
158
tree = self.make_branch_and_tree(".")
182
159
ignores.tree_ignores_add_patterns(tree, ["myentry"])
183
160
self.assertTrue(tree.has_filename(".bzrignore"))
184
self.assertPatternsEquals(["myentry"])
161
self.assertEquals("myentry\n",
162
open(".bzrignore", 'r').read())
186
164
def test_add_to_existing(self):
187
165
tree = self.make_branch_and_tree(".")
188
166
self.build_tree_contents([('.bzrignore', "myentry1\n")])
189
167
tree.add([".bzrignore"])
190
168
ignores.tree_ignores_add_patterns(tree, ["myentry2", "foo"])
191
self.assertPatternsEquals(["myentry1", "myentry2", "foo"])
169
self.assertEquals("myentry1\nmyentry2\nfoo\n",
170
open(".bzrignore", 'r').read())
193
172
def test_adds_ending_newline(self):
194
173
tree = self.make_branch_and_tree(".")
195
174
self.build_tree_contents([('.bzrignore', "myentry1")])
196
175
tree.add([".bzrignore"])
197
176
ignores.tree_ignores_add_patterns(tree, ["myentry2"])
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.assertEquals(open('.bzrignore', 'rb').read(), 'myentry1\r\nmyentry2\r\nfoo\r\n')
226
self.assertPatternsEquals(["myentry1", "myentry2", "foo"])
177
self.assertEquals("myentry1\nmyentry2\n",
178
open(".bzrignore", 'r').read())