def test_create_host_fail(self): """Verify create_host produces expected exceptions.""" def _assigned_host_ports(apply_unassigning=False): return None with self.assertRaisesRegexp(AnsibleFailJson, "Failed to create host."): with mock.patch(self.REQ_FUNC, return_value=Exception()): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'windows', 'force_port': True, 'group': 'test_group', 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-storage1:01:b0621126818'}]}) host = Host() host.host_exists = lambda: False host.assigned_host_ports = _assigned_host_ports host.build_success_payload = lambda x: {} host.group_id = lambda: "85000000600A098000A4B9D1003637135D483DEB" host.create_host() with self.assertRaisesRegexp(AnsibleExitJson, "Host already exists."): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'windows', 'force_port': True, 'group': 'test_group', 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-storage1:01:b0621126818'}]}) host = Host() host.host_exists = lambda: True host.assigned_host_ports = _assigned_host_ports host.build_success_payload = lambda x: {} host.group_id = lambda: "85000000600A098000A4B9D1003637135D483DEB" host.create_host()
def test_host_exists_pass(self): """Verify host_exists produces expected results.""" with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'new_host', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'new_host_port_1', 'type': 'fc', 'port': '0x08ef08ef08ef08ef'}]}) host = Host() self.assertFalse(host.host_exists()) self._set_args({'state': 'present', 'name': 'does_not_exist', 'host_type': 'linux dm-mp', 'ports': [{'label': 'beegfs_storage1_iscsi_0', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-storage1:01:b0621126818'}]}) host = Host() self.assertFalse(host.host_exists()) self._set_args({'state': 'present', 'name': 'beegfs_storage1', 'host_type': 'linux dm-mp', 'ports': [{'label': 'beegfs_storage1_iscsi_0', 'type': 'iscsi', 'port': 'iqn.differentiqn.org'}]}) host = Host() self.assertTrue(host.host_exists()) with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': True, 'ports': [{'label': 'beegfs_metadata1_iscsi_0', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-storage1:01:b0621126818'}]}) host = Host() self.assertTrue(host.host_exists())
def test_update_host_pass(self): """Verify update_host produces expected results.""" # Change host type with self.assertRaises(AnsibleExitJson): with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'windows', 'force_port': True, 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-storage1:01:b0621126818'}]}) host = Host() host.build_success_payload = lambda x: {} host.host_exists() self.assertTrue(host.needs_update()) host.update_host() # Change port iqn with self.assertRaises(AnsibleExitJson): with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'iscsi', 'port': 'iqn.not_used'}]}) host = Host() host.build_success_payload = lambda x: {} host.host_exists() self.assertTrue(host.needs_update()) host.update_host() # Change port type to fc with self.assertRaises(AnsibleExitJson): with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'fc', 'port': '0x08ef08ef08ef08ef'}]}) host = Host() host.build_success_payload = lambda x: {} host.host_exists() self.assertTrue(host.needs_update()) host.update_host() # Change port name with self.assertRaises(AnsibleExitJson): with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'windows', 'force_port': True, 'ports': [{'label': 'beegfs_metadata1_iscsi_12', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.build_success_payload = lambda x: {} host.host_exists() self.assertTrue(host.needs_update()) host.update_host() # Change group with self.assertRaises(AnsibleExitJson): with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'windows', 'force_port': False, 'group': 'test_group', 'ports': [{'label': 'beegfs_metadata1_iscsi_0', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.build_success_payload = lambda x: {} host.group_id = lambda: "85000000600A098000A4B9D1003637135D483DEB" host.host_exists() self.assertTrue(host.needs_update()) host.update_host()
def test_host_exists_fail(self): """Verify host_exists produces expected exceptions.""" self._set_args({'state': 'present', 'host_type': 'linux dm-mp', 'ports': [{'label': 'abc', 'type': 'iscsi', 'port': 'iqn:0'}]}) host = Host() with self.assertRaisesRegexp(AnsibleFailJson, "Failed to determine host existence."): with mock.patch(self.REQ_FUNC, return_value=Exception()): host.host_exists()
def test_needs_update_fail(self): """Verify needs_update produces expected exceptions.""" with self.assertRaisesRegexp(AnsibleFailJson, "is associated with a different host."): with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata2_iscsi_0', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.host_exists() host.needs_update()
def test_update_host_fail(self): """Verify update_host produces expected exceptions.""" with self.assertRaisesRegexp(AnsibleFailJson, "Failed to update host."): with mock.patch(self.REQ_FUNC, side_effect=[(200, self.EXISTING_HOSTS), Exception()]): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'windows', 'force_port': False, 'group': 'test_group', 'ports': [{'label': 'beegfs_metadata1_iscsi_0', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.build_success_payload = lambda x: {} host.group_id = lambda: "85000000600A098000A4B9D1003637135D483DEB" host.host_exists() self.assertTrue(host.needs_update()) host.update_host()
def test_assigned_host_ports_pass(self): """Verify assigned_host_ports gives expected results.""" # Add an unused port to host with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'iscsi', 'port': 'iqn.not_used'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) self.assertEqual(host.assigned_host_ports(), {}) # Change port name (force) with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': True, 'ports': [{'label': 'beegfs_metadata1_iscsi_2', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) self.assertEqual(host.assigned_host_ports(), {'84000000600A098000A4B9D10030370B5D430109': ['89000000600A098000A4B28D00303CFC5D4300F7']}) # Change port type with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': True, 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'fc', 'port': '08:ef:7e:24:52:a0'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) self.assertEqual(host.assigned_host_ports(), {}) # take port from another host by force with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': True, 'ports': [{'label': 'beegfs_metadata2_iscsi_0', 'type': 'iscsi', 'port': 'iqn.used_elsewhere'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) self.assertEqual(host.assigned_host_ports(), {'84000000600A098000A4B9D10030370B5D430109': ['89000000600A098000A4B28D00303CFC5D4300F7']}) # take port from another host by force with mock.patch(self.REQ_FUNC, side_effect=[(200, self.EXISTING_HOSTS), (200, {})]): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': True, 'ports': [{'label': 'beegfs_metadata2_iscsi_0', 'type': 'iscsi', 'port': 'iqn.used_elsewhere'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) self.assertEqual(host.assigned_host_ports(apply_unassigning=True), {'84000000600A098000A4B9D10030370B5D430109': ['89000000600A098000A4B28D00303CFC5D4300F7']})
def test_needs_update_pass(self): """Verify needs_update produces expected results.""" # No changes with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'ports': [{'label': 'beegfs_metadata1_iscsi_0', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.host_exists() self.assertFalse(host.needs_update()) # Change host type with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'windows', 'force_port': False, 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'iscsi', 'port': 'iqn.not_used'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) # Add port to host with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata1_iscsi_1', 'type': 'iscsi', 'port': 'iqn.not_used'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) # Change port name with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata1_iscsi_2', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) # take port from another host by force with mock.patch(self.REQ_FUNC, return_value=(200, self.EXISTING_HOSTS)): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': True, 'ports': [{'label': 'beegfs_metadata2_iscsi_0', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update())
def test_assigned_host_ports_fail(self): """Verify assigned_host_ports gives expected exceptions.""" # take port from another with self.assertRaisesRegexp(AnsibleFailJson, "There are no host ports available OR there are not enough unassigned host ports"): with mock.patch(self.REQ_FUNC, side_effect=[(200, self.EXISTING_HOSTS)]): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata1_iscsi_2', 'type': 'iscsi', 'port': 'iqn.1993-08.org.debian.beegfs-metadata:01:69e4efdf30b8'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) host.assigned_host_ports(apply_unassigning=True) # take port from another host and fail because force == False with self.assertRaisesRegexp(AnsibleFailJson, "There are no host ports available OR there are not enough unassigned host ports"): with mock.patch(self.REQ_FUNC, side_effect=[(200, self.EXISTING_HOSTS)]): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata2_iscsi_0', 'type': 'iscsi', 'port': 'iqn.used_elsewhere'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) host.assigned_host_ports(apply_unassigning=True) # take port from another host and fail because force == False with self.assertRaisesRegexp(AnsibleFailJson, "There are no host ports available OR there are not enough unassigned host ports"): with mock.patch(self.REQ_FUNC, side_effect=[(200, self.EXISTING_HOSTS)]): self._set_args({'state': 'present', 'name': 'beegfs_metadata3', 'host_type': 'linux dm-mp', 'force_port': False, 'ports': [{'label': 'beegfs_metadata2_iscsi_0', 'type': 'iscsi', 'port': 'iqn.used_elsewhere'}]}) host = Host() host.host_exists() host.assigned_host_ports(apply_unassigning=True) with self.assertRaisesRegexp(AnsibleFailJson, "Failed to unassign host port."): with mock.patch(self.REQ_FUNC, side_effect=[(200, self.EXISTING_HOSTS), Exception()]): self._set_args({'state': 'present', 'name': 'beegfs_metadata1', 'host_type': 'linux dm-mp', 'force_port': True, 'ports': [{'label': 'beegfs_metadata2_iscsi_0', 'type': 'iscsi', 'port': 'iqn.used_elsewhere'}]}) host = Host() host.host_exists() self.assertTrue(host.needs_update()) host.assigned_host_ports(apply_unassigning=True)