/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 breezy/tests/test_globbing.py

  • Committer: Jelmer Vernooij
  • Date: 2018-07-08 10:56:06 UTC
  • mto: This revision was merged to the branch mainline in revision 7030.
  • Revision ID: jelmer@jelmer.uk-20180708105606-d53hkks89qq88twu
Use separate .as_bytes method rather than __bytes__.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006-2010 Canonical Ltd
 
1
# Copyright (C) 2006-2011 Canonical Ltd
2
2
# -*- coding: utf-8 -*-
3
3
#
4
4
# This program is free software; you can redistribute it and/or modify
15
15
# along with this program; if not, write to the Free Software
16
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
17
 
18
 
from bzrlib.globbing import (
 
18
import re
 
19
 
 
20
from .. import errors, lazy_regex
 
21
from ..globbing import (
19
22
    Globster,
20
23
    ExceptionGlobster,
21
24
    _OrderedGlobster,
22
25
    normalize_pattern
23
26
    )
24
 
from bzrlib.tests import (
 
27
from . import (
25
28
    TestCase,
26
 
    TestCaseInTempDir,
27
29
    )
28
30
 
29
31
 
35
37
                glob = glob_prefix + glob
36
38
            globster = Globster([glob])
37
39
            for name in positive:
38
 
                self.failUnless(globster.match(name), repr(
 
40
                self.assertTrue(globster.match(name), repr(
39
41
                    u'name "%s" does not match glob "%s" (re=%s)' %
40
42
                    (name, glob, globster._regex_patterns[0][0].pattern)))
41
43
            for name in negative:
42
 
                self.failIf(globster.match(name), repr(
 
44
                self.assertFalse(globster.match(name), repr(
43
45
                    u'name "%s" does match glob "%s" (re=%s)' %
44
46
                    (name, glob, globster._regex_patterns[0][0].pattern)))
45
47
 
52
54
    def test_char_group_digit(self):
53
55
        self.assertMatchBasenameAndFullpath([
54
56
            # The definition of digit this uses includes arabic digits from
55
 
            # non-latin scripts (arabic, indic, etc.) and subscript/superscript
56
 
            # digits, but neither roman numerals nor vulgar fractions.
 
57
            # non-latin scripts (arabic, indic, etc.) but neither roman
 
58
            # numerals nor vulgar fractions. Some characters such as
 
59
            # subscript/superscript digits may or may not match depending on
 
60
            # the Python version used, see: <http://bugs.python.org/issue6561>
57
61
            (u'[[:digit:]]',
58
 
             [u'0', u'5', u'\u0663', u'\u06f9', u'\u0f21', u'\xb9'],
 
62
             [u'0', u'5', u'\u0663', u'\u06f9', u'\u0f21'],
59
63
             [u'T', u'q', u' ', u'\u8336', u'.']),
60
64
            (u'[^[:digit:]]',
61
65
             [u'T', u'q', u' ', u'\u8336', u'.'],
62
 
             [u'0', u'5', u'\u0663', u'\u06f9', u'\u0f21', u'\xb9']),
 
66
             [u'0', u'5', u'\u0663', u'\u06f9', u'\u0f21']),
63
67
            ])
64
68
 
65
69
    def test_char_group_space(self):
180
184
             [u'foo', u'foo.bar'],
181
185
             [u'.foo', u'foo/bar', u'foo/.bar']),
182
186
            (u'*bar',
183
 
             [u'bar', u'foobar', ur'foo\nbar', u'foo.bar', u'foo/bar',
 
187
             [u'bar', u'foobar', u'foo\\nbar', u'foo.bar', u'foo/bar',
184
188
              u'foo/foobar', u'foo/f.bar', u'.bar', u'foo/.bar'],
185
189
             []),
186
190
            ])
218
222
             [u'foo', u'foo.bar'],
219
223
             [u'.foo', u'foo/bar', u'foo/.bar']),
220
224
            (u'**bar',
221
 
             [u'bar', u'foobar', ur'foo\nbar', u'foo.bar', u'foo/bar',
 
225
             [u'bar', u'foobar', u'foo\\nbar', u'foo.bar', u'foo/bar',
222
226
              u'foo/foobar', u'foo/f.bar', u'.bar', u'foo/.bar'],
223
227
             []),
224
228
            ])
300
304
        This test assumes the globs are broken into regexs containing 99
301
305
        groups.
302
306
        """
303
 
        patterns = [ u'*.%03d' % i for i in xrange(0,300) ]
 
307
        patterns = [u'*.%03d' % i for i in range(300)]
304
308
        globster = Globster(patterns)
305
309
        # test the fence posts
306
 
        for x in (0,98,99,197,198,296,297,299):
 
310
        for x in (0, 98, 99, 197, 198, 296, 297, 299):
307
311
            filename = u'foo.%03d' % x
308
 
            self.assertEqual(patterns[x],globster.match(filename))
309
 
        self.assertEqual(None,globster.match('foobar.300'))
 
312
            self.assertEqual(patterns[x], globster.match(filename))
 
313
        self.assertEqual(None, globster.match('foobar.300'))
 
314
 
 
315
    def test_bad_pattern(self):
 
316
        """Ensure that globster handles bad patterns cleanly."""
 
317
        patterns = [u'RE:[', u'/home/foo', u'RE:*.cpp']
 
318
        g = Globster(patterns)
 
319
        e = self.assertRaises(lazy_regex.InvalidPattern, g.match, 'filename')
 
320
        self.assertContainsRe(e.msg,
 
321
            r"File.*ignore.*contains error.*RE:\[.*RE:\*\.cpp", flags=re.DOTALL)
 
322
 
310
323
 
311
324
class TestExceptionGlobster(TestCase):
312
325
 
313
326
    def test_exclusion_patterns(self):
314
327
        """test that exception patterns are not matched"""
315
 
        patterns = [ u'*', u'!./local', u'!./local/**/*', u'!RE:\.z.*',u'!!./.zcompdump' ]
 
328
        patterns = [ u'*', u'!./local', u'!./local/**/*', u'!RE:\\.z.*', u'!!./.zcompdump' ]
316
329
        globster = ExceptionGlobster(patterns)
317
330
        self.assertEqual(u'*', globster.match('tmp/foo.txt'))
318
331
        self.assertEqual(None, globster.match('local'))