Changeset 391 for python/trunk/Lib/test/test_glob.py
- Timestamp:
- Mar 19, 2014, 11:31:01 PM (11 years ago)
- Location:
- python/trunk
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
python/trunk
-
Property svn:mergeinfo
set to
/python/vendor/Python-2.7.6 merged eligible /python/vendor/current merged eligible
-
Property svn:mergeinfo
set to
-
python/trunk/Lib/test/test_glob.py
r2 r391 1 import unittest2 from test.test_support import run_unittest, TESTFN3 1 import glob 4 2 import os 5 3 import shutil 4 import sys 5 import unittest 6 7 from test.test_support import run_unittest, TESTFN 8 9 10 def fsdecode(s): 11 return unicode(s, sys.getfilesystemencoding()) 12 6 13 7 14 class GlobTests(unittest.TestCase): … … 19 26 20 27 def setUp(self): 21 self.tempdir = TESTFN +"_dir"28 self.tempdir = TESTFN + "_dir" 22 29 self.mktemp('a', 'D') 23 30 self.mktemp('aab', 'F') 31 self.mktemp('.aa', 'G') 32 self.mktemp('.bb', 'H') 24 33 self.mktemp('aaa', 'zzzF') 25 34 self.mktemp('ZZZ') … … 28 37 if hasattr(os, 'symlink'): 29 38 os.symlink(self.norm('broken'), self.norm('sym1')) 30 os.symlink(self.norm('broken'), self.norm('sym2')) 39 os.symlink('broken', self.norm('sym2')) 40 os.symlink(os.path.join('a', 'bcd'), self.norm('sym3')) 31 41 32 42 def tearDown(self): … … 41 51 res = glob.glob(p) 42 52 self.assertEqual(list(glob.iglob(p)), res) 53 ures = [fsdecode(x) for x in res] 54 self.assertEqual(glob.glob(fsdecode(p)), ures) 55 self.assertEqual(list(glob.iglob(fsdecode(p))), ures) 43 56 return res 44 57 45 58 def assertSequencesEqual_noorder(self, l1, l2): 59 l1 = list(l1) 60 l2 = list(l2) 46 61 self.assertEqual(set(l1), set(l2)) 62 self.assertEqual(sorted(l1), sorted(l2)) 47 63 48 64 def test_glob_literal(self): … … 53 69 eq(self.glob('zymurgy'), []) 54 70 71 res = glob.glob('*') 72 self.assertEqual({type(r) for r in res}, {str}) 73 res = glob.glob(os.path.join(os.curdir, '*')) 74 self.assertEqual({type(r) for r in res}, {str}) 75 55 76 # test return types are unicode, but only if os.listdir 56 77 # returns unicode filenames 57 uniset = set([unicode]) 58 tmp = os.listdir(u'.') 59 if set(type(x) for x in tmp) == uniset: 60 u1 = glob.glob(u'*') 61 u2 = glob.glob(u'./*') 62 self.assertEquals(set(type(r) for r in u1), uniset) 63 self.assertEquals(set(type(r) for r in u2), uniset) 78 tmp = os.listdir(fsdecode(os.curdir)) 79 if {type(x) for x in tmp} == {unicode}: 80 res = glob.glob(u'*') 81 self.assertEqual({type(r) for r in res}, {unicode}) 82 res = glob.glob(os.path.join(fsdecode(os.curdir), u'*')) 83 self.assertEqual({type(r) for r in res}, {unicode}) 64 84 65 85 def test_glob_one_directory(self): … … 67 87 eq(self.glob('a*'), map(self.norm, ['a', 'aab', 'aaa'])) 68 88 eq(self.glob('*a'), map(self.norm, ['a', 'aaa'])) 89 eq(self.glob('.*'), map(self.norm, ['.aa', '.bb'])) 90 eq(self.glob('?aa'), map(self.norm, ['aaa'])) 69 91 eq(self.glob('aa?'), map(self.norm, ['aaa', 'aab'])) 70 92 eq(self.glob('aa[ab]'), map(self.norm, ['aaa', 'aab'])) … … 88 110 eq(self.glob('a', '*', '*', '*a'), 89 111 [self.norm('a', 'bcd', 'efg', 'ha')]) 90 eq(self.glob('?a?', '*F'), map(self.norm, [os.path.join('aaa', 'zzzF'),91 os.path.join('aab', 'F')]))112 eq(self.glob('?a?', '*F'), [self.norm('aaa', 'zzzF'), 113 self.norm('aab', 'F')]) 92 114 93 115 def test_glob_directory_with_trailing_slash(self): 94 # We are verifying that when there is wildcard pattern which 95 # ends with os.sep doesn't blow up. 96 res = glob.glob(self.tempdir + '*' + os.sep) 97 self.assertEqual(len(res), 1) 98 # either of these results are reasonable 99 self.assertTrue(res[0] in [self.tempdir, self.tempdir + os.sep]) 116 # Patterns ending with a slash shouldn't match non-dirs 117 res = glob.glob(self.norm('Z*Z') + os.sep) 118 self.assertEqual(res, []) 119 res = glob.glob(self.norm('ZZZ') + os.sep) 120 self.assertEqual(res, []) 121 # When there is a wildcard pattern which ends with os.sep, glob() 122 # doesn't blow up. 123 res = glob.glob(self.norm('aa*') + os.sep) 124 self.assertEqual(len(res), 2) 125 # either of these results is reasonable 126 self.assertIn(set(res), [ 127 {self.norm('aaa'), self.norm('aab')}, 128 {self.norm('aaa') + os.sep, self.norm('aab') + os.sep}, 129 ]) 100 130 131 def test_glob_unicode_directory_with_trailing_slash(self): 132 # Same as test_glob_directory_with_trailing_slash, but with an 133 # unicode argument. 134 res = glob.glob(fsdecode(self.norm('Z*Z') + os.sep)) 135 self.assertEqual(res, []) 136 res = glob.glob(fsdecode(self.norm('ZZZ') + os.sep)) 137 self.assertEqual(res, []) 138 res = glob.glob(fsdecode(self.norm('aa*') + os.sep)) 139 self.assertEqual(len(res), 2) 140 # either of these results is reasonable 141 self.assertIn(set(res), [ 142 {fsdecode(self.norm('aaa')), fsdecode(self.norm('aab'))}, 143 {fsdecode(self.norm('aaa') + os.sep), 144 fsdecode(self.norm('aab') + os.sep)}, 145 ]) 146 147 @unittest.skipUnless(hasattr(os, 'symlink'), "Requires symlink support") 148 def test_glob_symlinks(self): 149 eq = self.assertSequencesEqual_noorder 150 eq(self.glob('sym3'), [self.norm('sym3')]) 151 eq(self.glob('sym3', '*'), [self.norm('sym3', 'EF'), 152 self.norm('sym3', 'efg')]) 153 self.assertIn(self.glob('sym3' + os.sep), 154 [[self.norm('sym3')], [self.norm('sym3') + os.sep]]) 155 eq(self.glob('*', '*F'), 156 [self.norm('aaa', 'zzzF'), self.norm('aab', 'F'), 157 self.norm('sym3', 'EF')]) 158 159 @unittest.skipUnless(hasattr(os, 'symlink'), "Requires symlink support") 101 160 def test_glob_broken_symlinks(self): 102 if hasattr(os, 'symlink'): 103 eq = self.assertSequencesEqual_noorder 104 eq(self.glob('sym*'), [self.norm('sym1'), self.norm('sym2')]) 105 eq(self.glob('sym1'), [self.norm('sym1')]) 106 eq(self.glob('sym2'), [self.norm('sym2')]) 161 eq = self.assertSequencesEqual_noorder 162 eq(self.glob('sym*'), [self.norm('sym1'), self.norm('sym2'), 163 self.norm('sym3')]) 164 eq(self.glob('sym1'), [self.norm('sym1')]) 165 eq(self.glob('sym2'), [self.norm('sym2')]) 166 167 @unittest.skipUnless(sys.platform == "win32", "Win32 specific test") 168 def test_glob_magic_in_drive(self): 169 eq = self.assertSequencesEqual_noorder 170 eq(glob.glob('*:'), []) 171 eq(glob.glob(u'*:'), []) 172 eq(glob.glob('?:'), []) 173 eq(glob.glob(u'?:'), []) 107 174 108 175
Note:
See TracChangeset
for help on using the changeset viewer.