The silencing of DeprecationWarning was not taking -3 into consideration. Since
[python.git] / Lib / test / test_fnmatch.py
blobfbcbe70b82847c999a6ce8838d2d5cf42376b59e
1 """Test cases for the fnmatch module."""
3 from test import test_support
4 import unittest
6 from fnmatch import fnmatch, fnmatchcase
9 class FnmatchTestCase(unittest.TestCase):
10 def check_match(self, filename, pattern, should_match=1):
11 if should_match:
12 self.assertTrue(fnmatch(filename, pattern),
13 "expected %r to match pattern %r"
14 % (filename, pattern))
15 else:
16 self.assertTrue(not fnmatch(filename, pattern),
17 "expected %r not to match pattern %r"
18 % (filename, pattern))
20 def test_fnmatch(self):
21 check = self.check_match
22 check('abc', 'abc')
23 check('abc', '?*?')
24 check('abc', '???*')
25 check('abc', '*???')
26 check('abc', '???')
27 check('abc', '*')
28 check('abc', 'ab[cd]')
29 check('abc', 'ab[!de]')
30 check('abc', 'ab[de]', 0)
31 check('a', '??', 0)
32 check('a', 'b', 0)
34 # these test that '\' is handled correctly in character sets;
35 # see SF bug #409651
36 check('\\', r'[\]')
37 check('a', r'[!\]')
38 check('\\', r'[!\]', 0)
40 # test that filenames with newlines in them are handled correctly.
41 # http://bugs.python.org/issue6665
42 check('foo\nbar', 'foo*')
43 check('foo\nbar\n', 'foo*')
44 check('\nfoo', 'foo*', False)
45 check('\n', '*')
48 def test_main():
49 test_support.run_unittest(FnmatchTestCase)
52 if __name__ == "__main__":
53 test_main()