blob: 072247e8ef7110800595513a7ba260ad383f61c7 [file] [log] [blame]
Fred Drake99e87f92001-07-23 16:08:36 +00001import unittest
Victor Stinnerbf816222011-06-30 23:25:47 +02002from test.support import (run_unittest, TESTFN, skip_unless_symlink,
3 can_symlink, create_empty_file)
Fred Drake99e87f92001-07-23 16:08:36 +00004import glob
5import os
Johannes Gijsbersa3beee12005-01-08 13:28:54 +00006import shutil
Fred Drake99e87f92001-07-23 16:08:36 +00007
Tim Golden8f323d92012-11-06 13:50:42 +00008class GlobTestsBase(unittest.TestCase):
Fred Drake99e87f92001-07-23 16:08:36 +00009
10 def norm(self, *parts):
11 return os.path.normpath(os.path.join(self.tempdir, *parts))
12
13 def mktemp(self, *parts):
Johannes Gijsbersa3beee12005-01-08 13:28:54 +000014 filename = self.norm(*parts)
15 base, file = os.path.split(filename)
16 if not os.path.exists(base):
17 os.makedirs(base)
Victor Stinnerbf816222011-06-30 23:25:47 +020018 create_empty_file(filename)
Fred Drake99e87f92001-07-23 16:08:36 +000019
20 def setUp(self):
21 self.tempdir = TESTFN+"_dir"
22 self.mktemp('a', 'D')
23 self.mktemp('aab', 'F')
24 self.mktemp('aaa', 'zzzF')
25 self.mktemp('ZZZ')
26 self.mktemp('a', 'bcd', 'EF')
27 self.mktemp('a', 'bcd', 'efg', 'ha')
Brian Curtin3b4499c2010-12-28 14:31:47 +000028 if can_symlink():
Johannes Gijsbersae882f72004-08-30 10:19:56 +000029 os.symlink(self.norm('broken'), self.norm('sym1'))
30 os.symlink(self.norm('broken'), self.norm('sym2'))
Fred Drake99e87f92001-07-23 16:08:36 +000031
32 def tearDown(self):
Johannes Gijsbersa3beee12005-01-08 13:28:54 +000033 shutil.rmtree(self.tempdir)
Fred Drake99e87f92001-07-23 16:08:36 +000034
35 def glob(self, *parts):
36 if len(parts) == 1:
37 pattern = parts[0]
38 else:
39 pattern = os.path.join(*parts)
40 p = os.path.join(self.tempdir, pattern)
Johannes Gijsbers836f5432005-01-08 13:13:19 +000041 res = glob.glob(p)
42 self.assertEqual(list(glob.iglob(p)), res)
43 return res
Fred Drake99e87f92001-07-23 16:08:36 +000044
45 def assertSequencesEqual_noorder(self, l1, l2):
Raymond Hettingera690a992003-11-16 16:17:49 +000046 self.assertEqual(set(l1), set(l2))
Fred Drake99e87f92001-07-23 16:08:36 +000047
Tim Golden8f323d92012-11-06 13:50:42 +000048class GlobTests(GlobTestsBase):
49
Fred Drake99e87f92001-07-23 16:08:36 +000050 def test_glob_literal(self):
51 eq = self.assertSequencesEqual_noorder
Fred Drake99e87f92001-07-23 16:08:36 +000052 eq(self.glob('a'), [self.norm('a')])
53 eq(self.glob('a', 'D'), [self.norm('a', 'D')])
54 eq(self.glob('aab'), [self.norm('aab')])
55 eq(self.glob('zymurgy'), [])
56
Guido van Rossumd8faa362007-04-27 19:54:29 +000057 # test return types are unicode, but only if os.listdir
58 # returns unicode filenames
Guido van Rossumef87d6e2007-05-02 19:09:54 +000059 uniset = set([str])
60 tmp = os.listdir('.')
Guido van Rossumd8faa362007-04-27 19:54:29 +000061 if set(type(x) for x in tmp) == uniset:
Guido van Rossumef87d6e2007-05-02 19:09:54 +000062 u1 = glob.glob('*')
63 u2 = glob.glob('./*')
Ezio Melottib3aedd42010-11-20 19:04:17 +000064 self.assertEqual(set(type(r) for r in u1), uniset)
65 self.assertEqual(set(type(r) for r in u2), uniset)
Guido van Rossumd8faa362007-04-27 19:54:29 +000066
Fred Drake99e87f92001-07-23 16:08:36 +000067 def test_glob_one_directory(self):
68 eq = self.assertSequencesEqual_noorder
Fred Drake99e87f92001-07-23 16:08:36 +000069 eq(self.glob('a*'), map(self.norm, ['a', 'aab', 'aaa']))
70 eq(self.glob('*a'), map(self.norm, ['a', 'aaa']))
71 eq(self.glob('aa?'), map(self.norm, ['aaa', 'aab']))
72 eq(self.glob('aa[ab]'), map(self.norm, ['aaa', 'aab']))
73 eq(self.glob('*q'), [])
74
75 def test_glob_nested_directory(self):
76 eq = self.assertSequencesEqual_noorder
Fred Drake99e87f92001-07-23 16:08:36 +000077 if os.path.normcase("abCD") == "abCD":
78 # case-sensitive filesystem
79 eq(self.glob('a', 'bcd', 'E*'), [self.norm('a', 'bcd', 'EF')])
80 else:
81 # case insensitive filesystem
82 eq(self.glob('a', 'bcd', 'E*'), [self.norm('a', 'bcd', 'EF'),
83 self.norm('a', 'bcd', 'efg')])
84 eq(self.glob('a', 'bcd', '*g'), [self.norm('a', 'bcd', 'efg')])
85
86 def test_glob_directory_names(self):
87 eq = self.assertSequencesEqual_noorder
Fred Drake99e87f92001-07-23 16:08:36 +000088 eq(self.glob('*', 'D'), [self.norm('a', 'D')])
89 eq(self.glob('*', '*a'), [])
90 eq(self.glob('a', '*', '*', '*a'),
91 [self.norm('a', 'bcd', 'efg', 'ha')])
92 eq(self.glob('?a?', '*F'), map(self.norm, [os.path.join('aaa', 'zzzF'),
93 os.path.join('aab', 'F')]))
94
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000095 def test_glob_directory_with_trailing_slash(self):
96 # We are verifying that when there is wildcard pattern which
97 # ends with os.sep doesn't blow up.
98 res = glob.glob(self.tempdir + '*' + os.sep)
99 self.assertEqual(len(res), 1)
100 # either of these results are reasonable
Benjamin Peterson577473f2010-01-19 00:09:57 +0000101 self.assertIn(res[0], [self.tempdir, self.tempdir + os.sep])
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000102
Brian Curtin3b4499c2010-12-28 14:31:47 +0000103 @skip_unless_symlink
Johannes Gijsbersae882f72004-08-30 10:19:56 +0000104 def test_glob_broken_symlinks(self):
Brian Curtind40e6f72010-07-08 21:39:08 +0000105 eq = self.assertSequencesEqual_noorder
106 eq(self.glob('sym*'), [self.norm('sym1'), self.norm('sym2')])
107 eq(self.glob('sym1'), [self.norm('sym1')])
108 eq(self.glob('sym2'), [self.norm('sym2')])
Johannes Gijsbersae882f72004-08-30 10:19:56 +0000109
Tim Golden8f323d92012-11-06 13:50:42 +0000110class GlobBracesTests(GlobTestsBase):
111
112 def setUp(self):
113 super(GlobBracesTests, self).setUp()
114 self.mktemp('c{}d')
115 self.mktemp('c{deg')
116 self.mktemp('c{dfg')
117 self.mktemp('cd{f}g')
118 self.mktemp('ce{f}g')
119 self.mktemp('cdf}g')
120 self.mktemp('cef}g')
121
122 def match_pattern_with_results(self, patterns, paths):
123 expected = [self.norm(path) for path in [os.path.join(*parts) for parts in paths]]
124 actual = [os.path.normpath(g) for g in self.glob(*patterns)]
125 self.assertSequencesEqual_noorder(actual, expected)
126
127 def test_two_terms(self):
128 self.match_pattern_with_results(['a{aa,ab}'], [["aaa"], ["aab"]])
129
130 def test_missing_first_plus_nested(self):
131 self.match_pattern_with_results(['a{,a{a,b}}'], [['a'], ['aaa'], ['aab']])
132
133 def test_one_subpath_with_two_file_terms(self):
134 self.match_pattern_with_results(['a', '{D,bcd}'], [['a', 'D'], ['a', 'bcd']])
135
136 def test_two_subpath_terms_with_two_file_terms(self):
137 self.match_pattern_with_results(['{aaa,aab}', '{F,zzzF}'], [('aaa', 'zzzF'), ('aab', 'F')])
138
139 def test_two_subpath_terms_with_wildcard_file_term(self):
140 self.match_pattern_with_results(['aa{a,b}', '*F'], [('aaa', 'zzzF'), ('aab', 'F')])
141
142 def test_wildcard_subpath_with_file_missing_first_term(self):
143 self.match_pattern_with_results(['aa?', '{,zzz}F'], [('aaa', 'zzzF'), ('aab', 'F')])
144
145 #
146 # Edge cases where braces should not be expanded
147 #
148 def test_empty_braces(self):
149 self.assertSequencesEqual_noorder(self.glob('c{}d'), [self.norm('c{}d')])
150
151 def test_missing_end_brace(self):
152 self.assertSequencesEqual_noorder(self.glob('c{d{e,f}g'), map(self.norm, ['c{deg', 'c{dfg']))
153
154 def test_second_brace_one_term(self):
155 self.assertSequencesEqual_noorder(self.glob('c{d,e}{f}g'), map(self.norm, ['cd{f}g', 'ce{f}g']))
156
157 def test_outer_term_missing_first_brace(self):
158 self.assertSequencesEqual_noorder(self.glob('c{d,e}f}g'), map(self.norm, ['cdf}g', 'cef}g']))
159
160 #
161 # Braces containing folder separators
162 #
163 def test_embedded_separator1(self):
164 self.match_pattern_with_results(['a/{D,bcd/{EF,efg}}'], [('a', 'D'), ('a', 'bcd', 'EF'), ('a', 'bcd', 'efg')])
165
166 def test_embedded_separator2(self):
167 self.match_pattern_with_results(['aa{a/zzz,b/}F'], [('aaa', 'zzzF'), ('aab', 'F')])
Fred Drake2e2be372001-09-20 21:33:42 +0000168
169def test_main():
Tim Golden8f323d92012-11-06 13:50:42 +0000170 run_unittest(GlobTests, GlobBracesTests)
Fred Drake2e2be372001-09-20 21:33:42 +0000171
172
173if __name__ == "__main__":
174 test_main()