def test_ha_joined_dns_ha(self): def _fake_update(resources, resource_params, relation_id=None): resources.update({'res_nova_public_hostname': 'ocf:maas:dns'}) resource_params.update({'res_nova_public_hostname': 'params fqdn="nova.maas" ' 'ip_address="10.0.0.1"'}) self.test_config.set('dns-ha', True) self.get_hacluster_config.return_value = { 'vip': None, 'ha-bindiface': 'em0', 'ha-mcastport': '8080', 'os-admin-hostname': None, 'os-internal-hostname': None, 'os-public-hostname': 'nova.maas', } args = { 'relation_id': None, 'corosync_bindiface': 'em0', 'corosync_mcastport': '8080', 'init_services': {'res_nova_haproxy': 'haproxy'}, 'resources': {'res_nova_public_hostname': 'ocf:maas:dns', 'res_nova_haproxy': 'lsb:haproxy'}, 'resource_params': { 'res_nova_public_hostname': 'params fqdn="nova.maas" ' 'ip_address="10.0.0.1"', 'res_nova_haproxy': 'op monitor interval="5s"'}, 'clones': {'cl_nova_haproxy': 'res_nova_haproxy'}, 'colocations': {}, } self.update_dns_ha_resource_params.side_effect = _fake_update hooks.ha_joined() self.assertTrue(self.update_dns_ha_resource_params.called) self.relation_set.assert_called_with(**args)
def test_ha_relation_multi_consoleauth(self, config): self.get_hacluster_config.return_value = { 'ha-bindiface': 'em0', 'ha-mcastport': '8080', 'vip': '10.10.10.10', } self.test_config.set('vip_iface', 'eth120') self.test_config.set('vip_cidr', '21') self.test_config.set('single-nova-consoleauth', False) config.return_value = 'novnc' self.get_iface_for_address.return_value = None self.get_netmask_for_address.return_value = None hooks.ha_joined() args = { 'relation_id': None, 'corosync_bindiface': 'em0', 'corosync_mcastport': '8080', 'init_services': {'res_nova_haproxy': 'haproxy'}, 'resources': {'res_nova_eth120_vip': 'ocf:heartbeat:IPaddr2', 'res_nova_haproxy': 'lsb:haproxy'}, 'resource_params': { 'res_nova_eth120_vip': 'params ip="10.10.10.10"' ' cidr_netmask="21" nic="eth120"', 'res_nova_haproxy': 'op monitor interval="5s"'}, 'colocations': {}, 'clones': {'cl_nova_haproxy': 'res_nova_haproxy'} } self.relation_set.assert_has_calls([ call(groups={'grp_nova_vips': 'res_nova_eth120_vip'}), call(**args), ])
def test_ha_relation_single_consoleauth(self, config): self.get_hacluster_config.return_value = { 'ha-bindiface': 'em0', 'ha-mcastport': '8080', 'vip': '10.10.10.10', } self.test_config.set('vip_iface', 'eth120') self.test_config.set('vip_cidr', '21') config.return_value = 'novnc' self.get_iface_for_address.return_value = None self.get_netmask_for_address.return_value = None hooks.ha_joined() args = { 'corosync_bindiface': 'em0', 'corosync_mcastport': '8080', 'init_services': {'res_nova_haproxy': 'haproxy', 'res_nova_consoleauth': 'nova-consoleauth'}, 'resources': {'res_nova_eth120_vip': 'ocf:heartbeat:IPaddr2', 'res_nova_haproxy': 'lsb:haproxy', 'res_nova_consoleauth': 'ocf:openstack:nova-consoleauth'}, 'resource_params': { 'res_nova_eth120_vip': 'params ip="10.10.10.10"' ' cidr_netmask="21" nic="eth120"', 'res_nova_haproxy': 'op monitor interval="5s"', 'res_nova_consoleauth': 'op monitor interval="5s"'}, 'colocations': { 'vip_consoleauth': 'inf: res_nova_consoleauth grp_nova_vips' }, 'clones': {'cl_nova_haproxy': 'res_nova_haproxy'} } self.relation_set.assert_has_calls([ call(groups={'grp_nova_vips': 'res_nova_eth120_vip'}), call(**args), ])