/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_ignores.py

  • Committer: Vincent Ladeuil
  • Date: 2012-01-18 14:09:19 UTC
  • mto: This revision was merged to the branch mainline in revision 6468.
  • Revision ID: v.ladeuil+lp@free.fr-20120118140919-rlvdrhpc0nq1lbwi
Change set/remove to require a lock for the branch config files.

This means that tests (or any plugin for that matter) do not requires an
explicit lock on the branch anymore to change a single option. This also
means the optimisation becomes "opt-in" and as such won't be as
spectacular as it may be and/or harder to get right (nothing fails
anymore).

This reduces the diff by ~300 lines.

Code/tests that were updating more than one config option is still taking
a lock to at least avoid some IOs and demonstrate the benefits through
the decreased number of hpss calls.

The duplication between BranchStack and BranchOnlyStack will be removed
once the same sharing is in place for local config files, at which point
the Stack class itself may be able to host the changes.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2006-2011 Canonical Ltd
 
2
#
 
3
# This program is free software; you can redistribute it and/or modify
 
4
# it under the terms of the GNU General Public License as published by
 
5
# the Free Software Foundation; either version 2 of the License, or
 
6
# (at your option) any later version.
 
7
#
 
8
# This program is distributed in the hope that it will be useful,
 
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
11
# GNU General Public License for more details.
 
12
#
 
13
# You should have received a copy of the GNU General Public License
 
14
# along with this program; if not, write to the Free Software
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
16
 
 
17
"""Tests for handling of ignore files"""
 
18
 
 
19
from cStringIO import StringIO
 
20
 
 
21
from bzrlib import (
 
22
    config,
 
23
    ignores,
 
24
    )
 
25
from bzrlib.tests import (
 
26
    TestCase,
 
27
    TestCaseInTempDir,
 
28
    TestCaseWithTransport,
 
29
    )
 
30
 
 
31
 
 
32
class TestParseIgnoreFile(TestCase):
 
33
 
 
34
    def test_parse_fancy(self):
 
35
        ignored = ignores.parse_ignore_file(StringIO(
 
36
                './rootdir\n'
 
37
                'randomfile*\n'
 
38
                'path/from/ro?t\n'
 
39
                'unicode\xc2\xb5\n' # u'\xb5'.encode('utf8')
 
40
                'dos\r\n'
 
41
                '\n' # empty line
 
42
                '#comment\n'
 
43
                ' xx \n' # whitespace
 
44
                '!RE:^\.z.*\n'
 
45
                '!!./.zcompdump\n'
 
46
                ))
 
47
        self.assertEqual(set(['./rootdir',
 
48
                          'randomfile*',
 
49
                          'path/from/ro?t',
 
50
                          u'unicode\xb5',
 
51
                          'dos',
 
52
                          ' xx ',
 
53
                          '!RE:^\.z.*',
 
54
                          '!!./.zcompdump',
 
55
                         ]), ignored)
 
56
 
 
57
    def test_parse_empty(self):
 
58
        ignored = ignores.parse_ignore_file(StringIO(''))
 
59
        self.assertEqual(set([]), ignored)
 
60
        
 
61
    def test_parse_non_utf8(self):
 
62
        """Lines with non utf 8 characters should be discarded."""
 
63
        ignored = ignores.parse_ignore_file(StringIO(
 
64
                'utf8filename_a\n'
 
65
                'invalid utf8\x80\n'
 
66
                'utf8filename_b\n'
 
67
                ))
 
68
        self.assertEqual(set([
 
69
                        'utf8filename_a',
 
70
                        'utf8filename_b',
 
71
                       ]), ignored)
 
72
 
 
73
 
 
74
class TestUserIgnores(TestCaseInTempDir):
 
75
 
 
76
    def test_create_if_missing(self):
 
77
        # $HOME should be set to '.'
 
78
        ignore_path = config.user_ignore_config_filename()
 
79
        self.assertPathDoesNotExist(ignore_path)
 
80
        user_ignores = ignores.get_user_ignores()
 
81
        self.assertEqual(set(ignores.USER_DEFAULTS), user_ignores)
 
82
 
 
83
        self.assertPathExists(ignore_path)
 
84
        f = open(ignore_path, 'rb')
 
85
        try:
 
86
            entries = ignores.parse_ignore_file(f)
 
87
        finally:
 
88
            f.close()
 
89
        self.assertEqual(set(ignores.USER_DEFAULTS), entries)
 
90
 
 
91
    def test_use_existing(self):
 
92
        patterns = ['*.o', '*.py[co]', u'\xe5*']
 
93
        ignores._set_user_ignores(patterns)
 
94
 
 
95
        user_ignores = ignores.get_user_ignores()
 
96
        self.assertEqual(set(patterns), user_ignores)
 
97
 
 
98
    def test_use_empty(self):
 
99
        ignores._set_user_ignores([])
 
100
        ignore_path = config.user_ignore_config_filename()
 
101
        self.check_file_contents(ignore_path, '')
 
102
 
 
103
        self.assertEqual(set([]), ignores.get_user_ignores())
 
104
 
 
105
    def test_set(self):
 
106
        patterns = ['*.py[co]', '*.py[oc]']
 
107
        ignores._set_user_ignores(patterns)
 
108
 
 
109
        self.assertEqual(set(patterns), ignores.get_user_ignores())
 
110
 
 
111
        patterns = ['vim', '*.swp']
 
112
        ignores._set_user_ignores(patterns)
 
113
        self.assertEqual(set(patterns), ignores.get_user_ignores())
 
114
 
 
115
    def test_add(self):
 
116
        """Test that adding will not duplicate ignores"""
 
117
        # Create an empty file
 
118
        ignores._set_user_ignores([])
 
119
 
 
120
        patterns = ['foo', './bar', u'b\xe5z']
 
121
        added = ignores.add_unique_user_ignores(patterns)
 
122
        self.assertEqual(patterns, added)
 
123
        self.assertEqual(set(patterns), ignores.get_user_ignores())
 
124
 
 
125
    def test_add_directory(self):
 
126
        """Test that adding a directory will strip any trailing slash"""
 
127
        # Create an empty file
 
128
        ignores._set_user_ignores([])
 
129
 
 
130
        in_patterns = ['foo/', 'bar/', 'baz\\']
 
131
        added = ignores.add_unique_user_ignores(in_patterns)
 
132
        out_patterns = [ x.rstrip('/\\') for x in in_patterns ]
 
133
        self.assertEqual(out_patterns, added)
 
134
        self.assertEqual(set(out_patterns), ignores.get_user_ignores())
 
135
 
 
136
    def test_add_unique(self):
 
137
        """Test that adding will not duplicate ignores"""
 
138
        ignores._set_user_ignores(
 
139
            ['foo', './bar', u'b\xe5z', 'dir1/', 'dir3\\'])
 
140
 
 
141
        added = ignores.add_unique_user_ignores(
 
142
            ['xxx', './bar', 'xxx', 'dir1/', 'dir2/', 'dir3\\'])
 
143
        self.assertEqual(['xxx', 'dir2'], added)
 
144
        self.assertEqual(set(['foo', './bar', u'b\xe5z',
 
145
                              'xxx', 'dir1', 'dir2', 'dir3']),
 
146
                         ignores.get_user_ignores())
 
147
 
 
148
 
 
149
class TestRuntimeIgnores(TestCase):
 
150
 
 
151
    def setUp(self):
 
152
        TestCase.setUp(self)
 
153
 
 
154
        # For the purposes of these tests, we must have no
 
155
        # runtime ignores
 
156
        self.overrideAttr(ignores, '_runtime_ignores', set())
 
157
 
 
158
    def test_add(self):
 
159
        """Test that we can add an entry to the list."""
 
160
        self.assertEqual(set(), ignores.get_runtime_ignores())
 
161
 
 
162
        ignores.add_runtime_ignores(['foo'])
 
163
        self.assertEqual(set(['foo']), ignores.get_runtime_ignores())
 
164
 
 
165
    def test_add_duplicate(self):
 
166
        """Adding the same ignore twice shouldn't add a new entry."""
 
167
        ignores.add_runtime_ignores(['foo', 'bar'])
 
168
        self.assertEqual(set(['foo', 'bar']), ignores.get_runtime_ignores())
 
169
 
 
170
        ignores.add_runtime_ignores(['bar'])
 
171
        self.assertEqual(set(['foo', 'bar']), ignores.get_runtime_ignores())
 
172
 
 
173
 
 
174
class TestTreeIgnores(TestCaseWithTransport):
 
175
    
 
176
    def assertPatternsEquals(self, patterns):
 
177
        contents = open(".bzrignore", 'rU').read().strip().split('\n')
 
178
        self.assertEquals(sorted(patterns), sorted(contents))
 
179
 
 
180
    def test_new_file(self):
 
181
        tree = self.make_branch_and_tree(".")
 
182
        ignores.tree_ignores_add_patterns(tree, ["myentry"])
 
183
        self.assertTrue(tree.has_filename(".bzrignore"))
 
184
        self.assertPatternsEquals(["myentry"])
 
185
 
 
186
    def test_add_to_existing(self):
 
187
        tree = self.make_branch_and_tree(".")
 
188
        self.build_tree_contents([('.bzrignore', "myentry1\n")])
 
189
        tree.add([".bzrignore"])
 
190
        ignores.tree_ignores_add_patterns(tree, ["myentry2", "foo"])
 
191
        self.assertPatternsEquals(["myentry1", "myentry2", "foo"])
 
192
 
 
193
    def test_adds_ending_newline(self):
 
194
        tree = self.make_branch_and_tree(".")
 
195
        self.build_tree_contents([('.bzrignore', "myentry1")])
 
196
        tree.add([".bzrignore"])
 
197
        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
 
202
                        text.endswith('\r'))
 
203
 
 
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"])
 
210
 
 
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')])
 
219
 
 
220
    def test_crlf(self):
 
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"])