~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_globbing.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2010-09-01 08:02:42 UTC
  • mfrom: (5390.3.3 faster-revert-593560)
  • Revision ID: pqm@pqm.ubuntu.com-20100901080242-esg62ody4frwmy66
(spiv) Avoid repeatedly calling self.target.all_file_ids() in
 InterTree.iter_changes. (Andrew Bennetts)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 Canonical Ltd
 
1
# Copyright (C) 2006-2010 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
import re
 
19
 
 
20
from bzrlib import errors
18
21
from bzrlib.globbing import (
19
22
    Globster,
 
23
    ExceptionGlobster,
20
24
    _OrderedGlobster,
 
25
    normalize_pattern
21
26
    )
22
27
from bzrlib.tests import (
23
28
    TestCase,
50
55
    def test_char_group_digit(self):
51
56
        self.assertMatchBasenameAndFullpath([
52
57
            # The definition of digit this uses includes arabic digits from
53
 
            # non-latin scripts (arabic, indic, etc.) and subscript/superscript
54
 
            # digits, but neither roman numerals nor vulgar fractions.
 
58
            # non-latin scripts (arabic, indic, etc.) but neither roman
 
59
            # numerals nor vulgar fractions. Some characters such as
 
60
            # subscript/superscript digits may or may not match depending on
 
61
            # the Python version used, see: <http://bugs.python.org/issue6561>
55
62
            (u'[[:digit:]]',
56
 
             [u'0', u'5', u'\u0663', u'\u06f9', u'\u0f21', u'\xb9'],
 
63
             [u'0', u'5', u'\u0663', u'\u06f9', u'\u0f21'],
57
64
             [u'T', u'q', u' ', u'\u8336', u'.']),
58
65
            (u'[^[:digit:]]',
59
66
             [u'T', u'q', u' ', u'\u8336', u'.'],
60
 
             [u'0', u'5', u'\u0663', u'\u06f9', u'\u0f21', u'\xb9']),
 
67
             [u'0', u'5', u'\u0663', u'\u06f9', u'\u0f21']),
61
68
            ])
62
69
 
63
70
    def test_char_group_space(self):
306
313
            self.assertEqual(patterns[x],globster.match(filename))
307
314
        self.assertEqual(None,globster.match('foobar.300'))
308
315
 
 
316
    def test_bad_pattern(self):
 
317
        """Ensure that globster handles bad patterns cleanly."""
 
318
        patterns = [u'RE:[', u'/home/foo', u'RE:*.cpp']
 
319
        g = Globster(patterns)
 
320
        e = self.assertRaises(errors.InvalidPattern, g.match, 'filename')
 
321
        self.assertContainsRe(e.msg,
 
322
            "File.*ignore.*contains error.*RE:\[.*RE:\*\.cpp", flags=re.DOTALL)
 
323
 
 
324
 
 
325
class TestExceptionGlobster(TestCase):
 
326
 
 
327
    def test_exclusion_patterns(self):
 
328
        """test that exception patterns are not matched"""
 
329
        patterns = [ u'*', u'!./local', u'!./local/**/*', u'!RE:\.z.*',u'!!./.zcompdump' ]
 
330
        globster = ExceptionGlobster(patterns)
 
331
        self.assertEqual(u'*', globster.match('tmp/foo.txt'))
 
332
        self.assertEqual(None, globster.match('local'))
 
333
        self.assertEqual(None, globster.match('local/bin/wombat'))
 
334
        self.assertEqual(None, globster.match('.zshrc'))
 
335
        self.assertEqual(None, globster.match('.zfunctions/fiddle/flam'))
 
336
        self.assertEqual(u'!!./.zcompdump', globster.match('.zcompdump'))
 
337
 
 
338
    def test_exclusion_order(self):
 
339
        """test that ordering of exclusion patterns does not matter"""
 
340
        patterns = [ u'static/**/*.html', u'!static/**/versionable.html']
 
341
        globster = ExceptionGlobster(patterns)
 
342
        self.assertEqual(u'static/**/*.html', globster.match('static/foo.html'))
 
343
        self.assertEqual(None, globster.match('static/versionable.html'))
 
344
        self.assertEqual(None, globster.match('static/bar/versionable.html'))
 
345
        globster = ExceptionGlobster(reversed(patterns))
 
346
        self.assertEqual(u'static/**/*.html', globster.match('static/foo.html'))
 
347
        self.assertEqual(None, globster.match('static/versionable.html'))
 
348
        self.assertEqual(None, globster.match('static/bar/versionable.html'))
309
349
 
310
350
class TestOrderedGlobster(TestCase):
311
351
 
318
358
        globster = _OrderedGlobster(reversed(patterns))
319
359
        self.assertEqual(u'bar.*', globster.match('bar.foo'))
320
360
        self.assertEqual(None, globster.match('foo.bar'))
 
361
 
 
362
 
 
363
class TestNormalizePattern(TestCase):
 
364
 
 
365
    def test_backslashes(self):
 
366
        """tests that backslashes are converted to forward slashes, multiple
 
367
        backslashes are collapsed to single forward slashes and trailing
 
368
        backslashes are removed"""
 
369
        self.assertEqual(u'/', normalize_pattern(u'\\'))
 
370
        self.assertEqual(u'/', normalize_pattern(u'\\\\'))
 
371
        self.assertEqual(u'/foo/bar', normalize_pattern(u'\\foo\\bar'))
 
372
        self.assertEqual(u'foo/bar', normalize_pattern(u'foo\\bar\\'))
 
373
        self.assertEqual(u'/foo/bar', normalize_pattern(u'\\\\foo\\\\bar\\\\'))
 
374
 
 
375
    def test_forward_slashes(self):
 
376
        """tests that multiple foward slashes are collapsed to single forward
 
377
        slashes and trailing forward slashes are removed"""
 
378
        self.assertEqual(u'/', normalize_pattern(u'/'))
 
379
        self.assertEqual(u'/', normalize_pattern(u'//'))
 
380
        self.assertEqual(u'/foo/bar', normalize_pattern(u'/foo/bar'))
 
381
        self.assertEqual(u'foo/bar', normalize_pattern(u'foo/bar/'))
 
382
        self.assertEqual(u'/foo/bar', normalize_pattern(u'//foo//bar//'))
 
383
 
 
384
    def test_mixed_slashes(self):
 
385
        """tests that multiple mixed slashes are collapsed to single forward
 
386
        slashes and trailing mixed slashes are removed"""
 
387
        self.assertEqual(u'/foo/bar', normalize_pattern(u'\\/\\foo//\\///bar/\\\\/'))