17
17
from StringIO import StringIO
20
19
from bzrlib.branch import Branch
21
import bzrlib.errors as errors
22
20
from bzrlib.errors import BzrBadParameterNotString, NoSuchFile, ReadOnlyError
23
from bzrlib.lockable_files import LockableFiles, TransportLock
24
from bzrlib.lockdir import LockDir
21
from bzrlib.lockable_files import LockableFiles
25
22
from bzrlib.tests import TestCaseInTempDir
26
from bzrlib.tests.test_transactions import DummyWeave
27
from bzrlib.transactions import (PassThroughTransaction,
23
from bzrlib.transactions import PassThroughTransaction, ReadOnlyTransaction
31
24
from bzrlib.transport import get_transport
26
class TestLockableFiles(TestCaseInTempDir):
34
# these tests are applied in each parameterized suite for LockableFiles
35
class _TestLockableFiles_mixin(object):
29
super(TestLockableFiles, self).setUp()
30
transport = get_transport('.')
31
transport.mkdir('.bzr')
32
transport.put('.bzr/my-lock', StringIO(''))
33
self.lockable = LockableFiles(transport.clone('.bzr'), 'my-lock')
37
35
def test_read_write(self):
38
36
self.assertRaises(NoSuchFile, self.lockable.get, 'foo')
97
91
def test__escape_empty(self):
98
92
self.assertEqual('', self.lockable._escape(''))
100
def test_break_lock(self):
101
# some locks are not breakable
102
self.lockable.lock_write()
104
self.assertRaises(AssertionError, self.lockable.break_lock)
105
except NotImplementedError:
106
# this lock cannot be broken
107
self.lockable.unlock()
109
l2 = self.get_lockable()
110
orig_factory = bzrlib.ui.ui_factory
111
# silent ui - no need for stdout
112
bzrlib.ui.ui_factory = bzrlib.ui.SilentUIFactory()
113
bzrlib.ui.ui_factory.stdin = StringIO("y\n")
117
bzrlib.ui.ui_factory = orig_factory
122
self.assertRaises(errors.LockBroken, self.lockable.unlock)
123
self.assertFalse(self.lockable.is_locked())
126
# This method of adapting tests to parameters is different to
127
# the TestProviderAdapters used elsewhere, but seems simpler for this
129
class TestLockableFiles_TransportLock(TestCaseInTempDir,
130
_TestLockableFiles_mixin):
133
super(TestLockableFiles_TransportLock, self).setUp()
134
transport = get_transport('.')
135
transport.mkdir('.bzr')
136
self.sub_transport = transport.clone('.bzr')
137
self.lockable = self.get_lockable()
138
self.lockable.create_lock()
141
super(TestLockableFiles_TransportLock, self).tearDown()
142
# free the subtransport so that we do not get a 5 second
143
# timeout due to the SFTP connection cache.
144
del self.sub_transport
146
def get_lockable(self):
147
return LockableFiles(self.sub_transport, 'my-lock', TransportLock)
150
class TestLockableFiles_LockDir(TestCaseInTempDir,
151
_TestLockableFiles_mixin):
152
"""LockableFile tests run with LockDir underneath"""
155
super(TestLockableFiles_LockDir, self).setUp()
156
self.transport = get_transport('.')
157
self.lockable = self.get_lockable()
158
# the lock creation here sets mode - test_permissions on branch
159
# tests that implicitly, but it might be a good idea to factor
160
# out the mode checking logic and have it applied to loackable files
161
# directly. RBC 20060418
162
self.lockable.create_lock()
164
def get_lockable(self):
165
return LockableFiles(self.transport, 'my-lock', LockDir)
167
def test_lock_created(self):
168
self.assertTrue(self.transport.has('my-lock'))
169
self.lockable.lock_write()
170
self.assertTrue(self.transport.has('my-lock/held/info'))
171
self.lockable.unlock()
172
self.assertFalse(self.transport.has('my-lock/held/info'))
173
self.assertTrue(self.transport.has('my-lock'))
176
# TODO: Test the lockdir inherits the right file and directory permissions
177
# from the LockableFiles.