3
from test_utils import CharmTestCase
5
sys.modules['MySQLdb'] = mock.Mock()
6
import percona_hooks as hooks
8
TO_PATCH = ['log', 'config',
14
class TestHaRelation(CharmTestCase):
16
CharmTestCase.setUp(self, hooks, TO_PATCH)
18
@mock.patch('sys.exit')
19
def test_relation_not_configured(self, exit_):
20
self.config.return_value = None
22
class MyError(Exception):
28
self.assertRaises(MyError, hooks.ha_relation_joined)
30
def test_resources(self):
31
self.relation_ids.return_value = ['ha:1']
34
attrs = {'get_mysql_password.return_value': password}
35
helper.configure_mock(**attrs)
36
self.get_db_helper.return_value = helper
37
self.test_config.set('vip', '10.0.3.3')
38
self.test_config.set('sst-password', password)
40
return self.test_config.get(k)
42
self.config.side_effect = f
43
hooks.ha_relation_joined()
45
resources = {'res_mysql_vip': 'ocf:heartbeat:IPaddr2',
46
'res_mysql_monitor': 'ocf:percona:mysql_monitor'}
47
resource_params = {'res_mysql_vip': ('params ip="10.0.3.3" '
51
hooks.RES_MONITOR_PARAMS % {'sstpass': 'ubuntu'}}
52
groups = {'grp_percona_cluster': 'res_mysql_vip'}
54
clones = {'cl_mysql_monitor': 'res_mysql_monitor meta interleave=true'}
56
colocations = {'vip_mysqld': 'inf: grp_percona_cluster cl_mysql_monitor'}
58
locations = {'loc_percona_cluster':
59
'grp_percona_cluster rule inf: writable eq 1'}
61
self.relation_set.assert_called_with(
62
relation_id='ha:1', corosync_bindiface=f('ha-bindiface'),
63
corosync_mcastport=f('ha-mcastport'), resources=resources,
64
resource_params=resource_params, groups=groups,
65
clones=clones, colocations=colocations, locations=locations)