1 """Tests for distutils.dir_util."""
6 from distutils
.dir_util
import (mkpath
, remove_tree
, create_tree
, copy_tree
,
9 from distutils
import log
10 from distutils
.tests
import support
12 class DirUtilTestCase(support
.TempdirManager
, unittest
.TestCase
):
14 def _log(self
, msg
, *args
):
16 self
._logs
.append(msg
% args
)
18 self
._logs
.append(msg
)
21 super(DirUtilTestCase
, self
).setUp()
23 tmp_dir
= self
.mkdtemp()
24 self
.root_target
= os
.path
.join(tmp_dir
, 'deep')
25 self
.target
= os
.path
.join(self
.root_target
, 'here')
26 self
.target2
= os
.path
.join(tmp_dir
, 'deep2')
27 self
.old_log
= log
.info
31 log
.info
= self
.old_log
32 super(DirUtilTestCase
, self
).tearDown()
34 def test_mkpath_remove_tree_verbosity(self
):
36 mkpath(self
.target
, verbose
=0)
38 self
.assertEquals(self
._logs
, wanted
)
39 remove_tree(self
.root_target
, verbose
=0)
41 mkpath(self
.target
, verbose
=1)
42 wanted
= ['creating %s' % self
.root_target
,
43 'creating %s' % self
.target
]
44 self
.assertEquals(self
._logs
, wanted
)
47 remove_tree(self
.root_target
, verbose
=1)
48 wanted
= ["removing '%s' (and everything under it)" % self
.root_target
]
49 self
.assertEquals(self
._logs
, wanted
)
51 def test_create_tree_verbosity(self
):
53 create_tree(self
.root_target
, ['one', 'two', 'three'], verbose
=0)
54 self
.assertEquals(self
._logs
, [])
55 remove_tree(self
.root_target
, verbose
=0)
57 wanted
= ['creating %s' % self
.root_target
]
58 create_tree(self
.root_target
, ['one', 'two', 'three'], verbose
=1)
59 self
.assertEquals(self
._logs
, wanted
)
61 remove_tree(self
.root_target
, verbose
=0)
64 def test_copy_tree_verbosity(self
):
66 mkpath(self
.target
, verbose
=0)
68 copy_tree(self
.target
, self
.target2
, verbose
=0)
69 self
.assertEquals(self
._logs
, [])
71 remove_tree(self
.root_target
, verbose
=0)
73 mkpath(self
.target
, verbose
=0)
74 a_file
= os
.path
.join(self
.target
, 'ok.txt')
76 f
.write('some content')
79 wanted
= ['copying %s -> %s' % (a_file
, self
.target2
)]
80 copy_tree(self
.target
, self
.target2
, verbose
=1)
81 self
.assertEquals(self
._logs
, wanted
)
83 remove_tree(self
.root_target
, verbose
=0)
84 remove_tree(self
.target2
, verbose
=0)
86 def test_ensure_relative(self
):
88 self
.assertEquals(ensure_relative('/home/foo'), 'home/foo')
89 self
.assertEquals(ensure_relative('some/path'), 'some/path')
91 self
.assertEquals(ensure_relative('c:\\home\\foo'), 'c:home\\foo')
92 self
.assertEquals(ensure_relative('home\\foo'), 'home\\foo')
95 return unittest
.makeSuite(DirUtilTestCase
)
97 if __name__
== "__main__":
98 unittest
.main(defaultTest
="test_suite")