~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_win32utils.py

  • Committer: Vincent Ladeuil
  • Date: 2008-01-29 15:16:31 UTC
  • mto: (3206.1.1 trunk)
  • mto: This revision was merged to the branch mainline in revision 3207.
  • Revision ID: v.ladeuil+lp@free.fr-20080129151631-vqjd13tb405mobx6
Fix two more leaking tmp dirs, by reworking TransformPreview lock handling.

* bzrlib/tests/test_transform.py:
(TestTransformMerge): Revert previous patch and cleanly call
preview.finalize now that we can.

* bzrlib/tests/test_merge.py:
(TestMerge.test_make_preview_transform): Catch TransformPreview
leak.

* bzrlib/builtins.py:
(cmd_merge._do_preview): Finalize the TransformPreview or the
limbodir will stay in /tmp.

* bzrlib/transform.py:
(TreeTransformBase.__init__): Create the _deletiondir since it's
reffered to by finalize.
(TreeTransformBase.finalize): Delete the dir only if _deletiondir
is set.
(TreeTransform.__init__): Use a temp var for deletiondir and set
the attribute after the base class __init__ has been called.
(TransformPreview.__init__): Read locks the tree since finalize
wants to unlock it (as suggested by Aaron).

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2007 Canonical Ltd
 
2
#
 
3
# This program is free software; you can redistribute it and/or modify
 
4
# it under the terms of the GNU General Public License as published by
 
5
# the Free Software Foundation; either version 2 of the License, or
 
6
# (at your option) any later version.
 
7
#
 
8
# This program is distributed in the hope that it will be useful,
 
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
11
# GNU General Public License for more details.
 
12
#
 
13
# You should have received a copy of the GNU General Public License
 
14
# along with this program; if not, write to the Free Software
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
 
 
17
import os
 
18
import sys
 
19
 
 
20
from bzrlib import osutils
 
21
from bzrlib.tests import TestCase, TestCaseInTempDir, Feature
 
22
from bzrlib.win32utils import glob_expand, get_app_path
 
23
 
 
24
 
 
25
# Features
 
26
# --------
 
27
 
 
28
class _NeedsGlobExpansionFeature(Feature):
 
29
 
 
30
    def _probe(self):
 
31
        return sys.platform == 'win32'
 
32
 
 
33
    def feature_name(self):
 
34
        return 'Internally performed glob expansion'
 
35
 
 
36
NeedsGlobExpansionFeature = _NeedsGlobExpansionFeature()
 
37
 
 
38
 
 
39
class _Win32RegistryFeature(Feature):
 
40
 
 
41
    def _probe(self):
 
42
        try:
 
43
            import _winreg
 
44
            return True
 
45
        except ImportError:
 
46
            return False
 
47
 
 
48
    def feature_name(self):
 
49
        return '_winreg'
 
50
 
 
51
Win32RegistryFeature = _Win32RegistryFeature()
 
52
 
 
53
 
 
54
# Tests
 
55
# -----
 
56
 
 
57
class TestNeedsGlobExpansionFeature(TestCase):
 
58
    
 
59
    def test_available(self):
 
60
        self.assertEqual(sys.platform == 'win32', 
 
61
                         NeedsGlobExpansionFeature.available())
 
62
        
 
63
    def test_str(self):
 
64
        self.assertTrue("performed" in str(NeedsGlobExpansionFeature))
 
65
 
 
66
 
 
67
class TestWin32UtilsGlobExpand(TestCaseInTempDir):
 
68
 
 
69
    _test_needs_features = [NeedsGlobExpansionFeature]
 
70
   
 
71
    def test_empty_tree(self):
 
72
        self.build_tree([])
 
73
        self._run_testset([
 
74
            [['a'], ['a']],
 
75
            [['?'], ['?']],
 
76
            [['*'], ['*']],
 
77
            [['a', 'a'], ['a', 'a']]])
 
78
        
 
79
    def test_tree_ascii(self):
 
80
        """Checks the glob expansion and path separation char
 
81
        normalization"""
 
82
        self.build_tree(['a', 'a1', 'a2', 'a11', 'a.1',
 
83
                         'b', 'b1', 'b2', 'b3',
 
84
                         'c/', 'c/c1', 'c/c2', 
 
85
                         'd/', 'd/d1', 'd/d2', 'd/e/', 'd/e/e1'])
 
86
        self._run_testset([
 
87
            # no wildcards
 
88
            [[u'a'], [u'a']],
 
89
            [[u'a', u'a' ], [u'a', u'a']],
 
90
            [[u'A'], [u'A']],
 
91
                
 
92
            [[u'd'], [u'd']],
 
93
            [[u'd/'], [u'd/']],
 
94
            [[u'd\\'], [u'd/']],
 
95
            
 
96
            # wildcards
 
97
            [[u'a*'], [u'a', u'a1', u'a2', u'a11', u'a.1']],
 
98
            [[u'?'], [u'a', u'b', u'c', u'd']],
 
99
            [[u'a?'], [u'a1', u'a2']],
 
100
            [[u'a??'], [u'a11', u'a.1']],
 
101
            [[u'b[1-2]'], [u'b1', u'b2']],
 
102
            [[u'A?'], [u'a1', u'a2']],
 
103
               
 
104
            [[u'd/*'], [u'd/d1', u'd/d2', u'd/e']],
 
105
            [[u'd\\*'], [u'd/d1', u'd/d2', u'd/e']],
 
106
            [[u'?\\*'], [u'c/c1', u'c/c2', u'd/d1', u'd/d2', u'd/e']],
 
107
            [[u'*\\*'], [u'c/c1', u'c/c2', u'd/d1', u'd/d2', u'd/e']],
 
108
            [[u'*/'], [u'c/', u'd/']],
 
109
            [[u'*\\'], [u'c/', u'd/']]])
 
110
        
 
111
    def test_tree_unicode(self):
 
112
        """Checks behaviour with non-ascii filenames"""
 
113
        self.build_tree([u'\u1234', u'\u1234\u1234', u'\u1235/', u'\u1235/\u1235'])
 
114
        self._run_testset([
 
115
            # no wildcards
 
116
            [[u'\u1234'], [u'\u1234']],
 
117
            [[u'\u1235'], [u'\u1235']],
 
118
         
 
119
            [[u'\u1235/'], [u'\u1235/']],
 
120
            [[u'\u1235/\u1235'], [u'\u1235/\u1235']],
 
121
            
 
122
            # wildcards
 
123
            [[u'?'], [u'\u1234', u'\u1235']],
 
124
            [[u'*'], [u'\u1234', u'\u1234\u1234', u'\u1235']],
 
125
            [[u'\u1234*'], [u'\u1234', u'\u1234\u1234']],
 
126
            
 
127
            [[u'\u1235/?'], [u'\u1235/\u1235']],
 
128
            [[u'\u1235/*'], [u'\u1235/\u1235']],
 
129
            [[u'\u1235\\?'], [u'\u1235/\u1235']],
 
130
            [[u'\u1235\\*'], [u'\u1235/\u1235']],
 
131
            [[u'?/'], [u'\u1235/']],
 
132
            [[u'*/'], [u'\u1235/']],
 
133
            [[u'?\\'], [u'\u1235/']],
 
134
            [[u'*\\'], [u'\u1235/']],
 
135
            [[u'?/?'], [u'\u1235/\u1235']],
 
136
            [[u'*/*'], [u'\u1235/\u1235']],
 
137
            [[u'?\\?'], [u'\u1235/\u1235']],
 
138
            [[u'*\\*'], [u'\u1235/\u1235']]])
 
139
 
 
140
    def _run_testset(self, testset):
 
141
        for pattern, expected in testset:
 
142
            result = glob_expand(pattern)
 
143
            expected.sort()
 
144
            result.sort()
 
145
            self.assertEqual(expected, result, 'pattern %s' % pattern)
 
146
 
 
147
 
 
148
class TestAppPaths(TestCase):
 
149
 
 
150
    _test_needs_features = [Win32RegistryFeature]
 
151
 
 
152
    def test_iexplore(self):
 
153
        # typical windows users should have IE installed
 
154
        for a in ('iexplore', 'iexplore.exe'):
 
155
            p = get_app_path(a)
 
156
            d, b = os.path.split(p)
 
157
            self.assertEquals('iexplore.exe', b.lower())
 
158
            self.assertNotEquals('', d)
 
159
 
 
160
    def test_not_existing(self):
 
161
        p = get_app_path('not-existing')
 
162
        self.assertEquals('not-existing', p)