1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
| """Test cases for the fnmatch module."""
|
| from test import test_support
| import unittest
|
| from fnmatch import fnmatch, fnmatchcase, _MAXCACHE, _cache
| from fnmatch import fnmatch, fnmatchcase, _MAXCACHE, _cache, _purge
|
|
| class FnmatchTestCase(unittest.TestCase):
|
| def tearDown(self):
| _purge()
|
| def check_match(self, filename, pattern, should_match=1, fn=fnmatch):
| if should_match:
| self.assertTrue(fn(filename, pattern),
| "expected %r to match pattern %r"
| % (filename, pattern))
| else:
| self.assertTrue(not fn(filename, pattern),
| "expected %r not to match pattern %r"
| % (filename, pattern))
|
| def test_fnmatch(self):
| check = self.check_match
| check('abc', 'abc')
| check('abc', '?*?')
| check('abc', '???*')
| check('abc', '*???')
| check('abc', '???')
| check('abc', '*')
| check('abc', 'ab[cd]')
| check('abc', 'ab[!de]')
| check('abc', 'ab[de]', 0)
| check('a', '??', 0)
| check('a', 'b', 0)
|
| # these test that '\' is handled correctly in character sets;
| # see SF bug #409651
| check('\\', r'[\]')
| check('a', r'[!\]')
| check('\\', r'[!\]', 0)
|
| # test that filenames with newlines in them are handled correctly.
| # http://bugs.python.org/issue6665
| check('foo\nbar', 'foo*')
| check('foo\nbar\n', 'foo*')
| check('\nfoo', 'foo*', False)
| check('\n', '*')
|
| def test_fnmatchcase(self):
| check = self.check_match
| check('AbC', 'abc', 0, fnmatchcase)
| check('abc', 'AbC', 0, fnmatchcase)
|
| def test_cache_clearing(self):
| # check that caches do not grow too large
| # http://bugs.python.org/issue7846
|
| # string pattern cache
| for i in range(_MAXCACHE + 1):
| fnmatch('foo', '?' * i)
|
| self.assertLessEqual(len(_cache), _MAXCACHE)
|
| def test_main():
| test_support.run_unittest(FnmatchTestCase)
|
|
| if __name__ == "__main__":
| test_main()
|
|