2013-07-19 14:33:41 -07:00
|
|
|
from mock import MagicMock
|
2013-09-27 17:33:06 +01:00
|
|
|
from test_utils import CharmTestCase, patch_open
|
2013-07-19 13:44:37 -07:00
|
|
|
|
2013-09-27 17:33:06 +01:00
|
|
|
import swift_storage_context as swift_context
|
2013-07-19 13:44:37 -07:00
|
|
|
|
|
|
|
|
|
|
|
TO_PATCH = [
|
|
|
|
'config',
|
|
|
|
'log',
|
|
|
|
'related_units',
|
|
|
|
'relation_get',
|
|
|
|
'relation_ids',
|
2013-08-16 13:38:32 -07:00
|
|
|
'unit_private_ip',
|
2013-07-19 13:44:37 -07:00
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
class SwiftStorageContextTests(CharmTestCase):
|
2014-06-19 09:40:58 +01:00
|
|
|
|
2013-07-19 13:44:37 -07:00
|
|
|
def setUp(self):
|
|
|
|
super(SwiftStorageContextTests, self).setUp(swift_context, TO_PATCH)
|
|
|
|
self.config.side_effect = self.test_config.get
|
|
|
|
|
|
|
|
def test_swift_storage_context_missing_data(self):
|
|
|
|
self.relation_ids.return_value = []
|
|
|
|
ctxt = swift_context.SwiftStorageContext()
|
|
|
|
self.assertEquals(ctxt(), {})
|
|
|
|
self.relation_ids.return_value = ['swift-proxy:0']
|
|
|
|
self.related_units.return_value = ['swift-proxy/0']
|
|
|
|
self.relation_get.return_value = ''
|
|
|
|
self.assertEquals(ctxt(), {})
|
|
|
|
|
|
|
|
def test_swift_storage_context_with_data(self):
|
|
|
|
self.relation_ids.return_value = []
|
|
|
|
ctxt = swift_context.SwiftStorageContext()
|
|
|
|
self.assertEquals(ctxt(), {})
|
|
|
|
self.relation_ids.return_value = ['swift-proxy:0']
|
|
|
|
self.related_units.return_value = ['swift-proxy/0']
|
|
|
|
self.relation_get.return_value = 'fooooo'
|
|
|
|
self.assertEquals(ctxt(), {'swift_hash': 'fooooo'})
|
|
|
|
|
|
|
|
def test_rsync_context(self):
|
2013-08-16 13:38:32 -07:00
|
|
|
self.unit_private_ip.return_value = '10.0.0.5'
|
2013-07-19 13:44:37 -07:00
|
|
|
ctxt = swift_context.RsyncContext()
|
|
|
|
ctxt.enable_rsyncd = MagicMock()
|
|
|
|
ctxt.enable_rsyncd.return_value = True
|
|
|
|
self.assertEquals({'local_ip': '10.0.0.5'}, ctxt())
|
|
|
|
self.assertTrue(ctxt.enable_rsyncd.called)
|
|
|
|
|
2013-07-25 18:02:52 -07:00
|
|
|
def test_rsync_enable_rsync(self):
|
2013-07-19 13:44:37 -07:00
|
|
|
with patch_open() as (_open, _file):
|
|
|
|
ctxt = swift_context.RsyncContext()
|
|
|
|
_file.read.return_value = 'RSYNC_ENABLE=false'
|
|
|
|
ctxt.enable_rsyncd()
|
|
|
|
_file.write.assert_called_with('RSYNC_ENABLE=true')
|
|
|
|
_file.read.return_value = '#foo'
|
|
|
|
ctxt.enable_rsyncd()
|
|
|
|
_file.write.assert_called_with('RSYNC_ENABLE=true\n')
|
|
|
|
|
|
|
|
def test_swift_storage_server_context(self):
|
2014-06-18 12:34:19 +01:00
|
|
|
import psutil
|
2013-08-16 13:38:32 -07:00
|
|
|
self.unit_private_ip.return_value = '10.0.0.5'
|
2013-07-19 13:44:37 -07:00
|
|
|
self.test_config.set('account-server-port', '500')
|
|
|
|
self.test_config.set('object-server-port', '501')
|
|
|
|
self.test_config.set('container-server-port', '502')
|
2014-06-18 12:34:19 +01:00
|
|
|
self.test_config.set('object-server-threads-per-disk', '3')
|
|
|
|
self.test_config.set('worker-multiplier', '3')
|
2014-06-19 09:40:58 +01:00
|
|
|
num_workers = psutil.NUM_CPUS * 3
|
2013-07-19 13:44:37 -07:00
|
|
|
ctxt = swift_context.SwiftStorageServerContext()
|
|
|
|
result = ctxt()
|
|
|
|
ex = {
|
|
|
|
'container_server_port': '502',
|
|
|
|
'object_server_port': '501',
|
|
|
|
'account_server_port': '500',
|
2014-06-18 12:34:19 +01:00
|
|
|
'local_ip': '10.0.0.5',
|
|
|
|
'object_server_threads_per_disk': '3',
|
|
|
|
'workers': str(num_workers),
|
2013-07-19 13:44:37 -07:00
|
|
|
}
|
|
|
|
self.assertEquals(ex, result)
|