Remove support for "lvm_share_export_ip"
The LVM driver accepts a "lvm_share_export_ips" option instead of "lvm_share_export_ip" since the Pike release [1]. Let's drop support for this option and cleanup compatibility code. [1] Ib3594aa5d7751c829820fce830d87f6ceea6b049 Change-Id: Ifdeb470438c204cc6cc370517833cb2cab5b7822
This commit is contained in:
		| @@ -40,11 +40,12 @@ below: | |||||||
|    [LVM_sample_backend] |    [LVM_sample_backend] | ||||||
|    driver_handles_share_servers = False |    driver_handles_share_servers = False | ||||||
|    share_driver = manila.share.drivers.lvm.LVMShareDriver |    share_driver = manila.share.drivers.lvm.LVMShareDriver | ||||||
|    lvm_share_export_ip = 1.2.3.4 |    lvm_share_export_ips = 1.2.3.4 | ||||||
|  |  | ||||||
| In the example above, ``lvm_share_export_ip`` is the address to be used by | In the example above, ``lvm_share_export_ips`` is the address to be used by | ||||||
| clients for accessing shares. In the simplest case, it should be the same | clients for accessing shares. In the simplest case, it should be the same | ||||||
| as host's address. | as host's address. The option allows configuring more than one IP address as | ||||||
|  | a comma separated string. | ||||||
|  |  | ||||||
| Supported shared file systems and operations | Supported shared file systems and operations | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|   | |||||||
| @@ -18,8 +18,8 @@ | |||||||
|      - Description |      - Description | ||||||
|    * - **[DEFAULT]** |    * - **[DEFAULT]** | ||||||
|      - |      - | ||||||
|    * - ``lvm_share_export_ip`` = ``None`` |    * - ``lvm_share_export_ips`` = ``None`` | ||||||
|      - (String) IP to be added to export string. |      - (String) List of IPs to export shares belonging to the LVM storage driver. | ||||||
|    * - ``lvm_share_export_root`` = ``$state_path/mnt`` |    * - ``lvm_share_export_root`` = ``$state_path/mnt`` | ||||||
|      - (String) Base folder where exported shares are located. |      - (String) Base folder where exported shares are located. | ||||||
|    * - ``lvm_share_helpers`` = ``CIFS=manila.share.drivers.helpers.CIFSHelperUserAccess, NFS=manila.share.drivers.helpers.NFSHelper`` |    * - ``lvm_share_helpers`` = ``CIFS=manila.share.drivers.helpers.CIFSHelperUserAccess, NFS=manila.share.drivers.helpers.NFSHelper`` | ||||||
|   | |||||||
| @@ -85,12 +85,12 @@ Configure components | |||||||
|         share_driver = manila.share.drivers.lvm.LVMShareDriver |         share_driver = manila.share.drivers.lvm.LVMShareDriver | ||||||
|         driver_handles_share_servers = False |         driver_handles_share_servers = False | ||||||
|         lvm_share_volume_group = manila-volumes |         lvm_share_volume_group = manila-volumes | ||||||
|         lvm_share_export_ip = MANAGEMENT_INTERFACE_IP_ADDRESS |         lvm_share_export_ips = MANAGEMENT_INTERFACE_IP_ADDRESS | ||||||
|  |  | ||||||
|      Replace ``MANAGEMENT_INTERFACE_IP_ADDRESS`` with the IP address |      Replace ``MANAGEMENT_INTERFACE_IP_ADDRESS`` with the IP address | ||||||
|      of the management network interface on your storage node, |      of the management network interface on your storage node. The value of | ||||||
|      typically 10.0.0.41 for the first node in the example architecture |      this option can be a comma separated string of one or more IP addresses. | ||||||
|      shown below: |      In the example architecture shown below, the address would be 10.0.0.41: | ||||||
|  |  | ||||||
|      .. figure:: figures/hwreqs.png |      .. figure:: figures/hwreqs.png | ||||||
|         :alt: Hardware requirements |         :alt: Hardware requirements | ||||||
|   | |||||||
| @@ -41,12 +41,9 @@ share_opts = [ | |||||||
|     cfg.StrOpt('lvm_share_export_root', |     cfg.StrOpt('lvm_share_export_root', | ||||||
|                default='$state_path/mnt', |                default='$state_path/mnt', | ||||||
|                help='Base folder where exported shares are located.'), |                help='Base folder where exported shares are located.'), | ||||||
|     cfg.StrOpt('lvm_share_export_ip', |  | ||||||
|                deprecated_for_removal=True, |  | ||||||
|                deprecated_reason='Use lvm_share_export_ips instead.', |  | ||||||
|                help='IP to be added to export string.'), |  | ||||||
|     cfg.ListOpt('lvm_share_export_ips', |     cfg.ListOpt('lvm_share_export_ips', | ||||||
|                 help='List of IPs to export shares.'), |                 help='List of IPs to export shares belonging to the LVM ' | ||||||
|  |                      'storage driver.'), | ||||||
|     cfg.IntOpt('lvm_share_mirrors', |     cfg.IntOpt('lvm_share_mirrors', | ||||||
|                default=0, |                default=0, | ||||||
|                help='If set, create LVMs with multiple mirrors. Note that ' |                help='If set, create LVMs with multiple mirrors. Note that ' | ||||||
| @@ -78,15 +75,8 @@ class LVMMixin(driver.ExecuteMixin): | |||||||
|                    % self.configuration.lvm_share_volume_group) |                    % self.configuration.lvm_share_volume_group) | ||||||
|             raise exception.InvalidParameterValue(err=msg) |             raise exception.InvalidParameterValue(err=msg) | ||||||
|  |  | ||||||
|         if (self.configuration.lvm_share_export_ip and |         if not self.configuration.lvm_share_export_ips: | ||||||
|                 self.configuration.lvm_share_export_ips): |             msg = _("The option lvm_share_export_ips must be specified.") | ||||||
|             msg = (_("Only one of lvm_share_export_ip or lvm_share_export_ips" |  | ||||||
|                      " may be specified.")) |  | ||||||
|             raise exception.InvalidParameterValue(err=msg) |  | ||||||
|         if not (self.configuration.lvm_share_export_ip or |  | ||||||
|                 self.configuration.lvm_share_export_ips): |  | ||||||
|             msg = (_("Neither lvm_share_export_ip nor lvm_share_export_ips is" |  | ||||||
|                      " specified.")) |  | ||||||
|             raise exception.InvalidParameterValue(err=msg) |             raise exception.InvalidParameterValue(err=msg) | ||||||
|  |  | ||||||
|     def _allocate_container(self, share): |     def _allocate_container(self, share): | ||||||
| @@ -176,12 +166,9 @@ class LVMShareDriver(LVMMixin, driver.ShareDriver): | |||||||
|             'instance_id': self.backend_name, |             'instance_id': self.backend_name, | ||||||
|             'lock_name': 'manila_lvm', |             'lock_name': 'manila_lvm', | ||||||
|         } |         } | ||||||
|         if self.configuration.lvm_share_export_ip: |  | ||||||
|             self.share_server['public_addresses'] = [ |  | ||||||
|                 self.configuration.lvm_share_export_ip] |  | ||||||
|         else: |  | ||||||
|         self.share_server['public_addresses'] = ( |         self.share_server['public_addresses'] = ( | ||||||
|                 self.configuration.lvm_share_export_ips) |             self.configuration.lvm_share_export_ips | ||||||
|  |         ) | ||||||
|         self.ipv6_implemented = True |         self.ipv6_implemented = True | ||||||
|  |  | ||||||
|     def _ssh_exec_as_root(self, server, command, check_exit_code=True): |     def _ssh_exec_as_root(self, server, command, check_exit_code=True): | ||||||
| @@ -452,23 +439,12 @@ class LVMShareDriver(LVMMixin, driver.ShareDriver): | |||||||
|         if self.configured_ip_version is None: |         if self.configured_ip_version is None: | ||||||
|             try: |             try: | ||||||
|                 self.configured_ip_version = [] |                 self.configured_ip_version = [] | ||||||
|                 if self.configuration.lvm_share_export_ip: |  | ||||||
|                     self.configured_ip_version.append(ipaddress.ip_address( |  | ||||||
|                         six.text_type( |  | ||||||
|                             self.configuration.lvm_share_export_ip)).version) |  | ||||||
|                 else: |  | ||||||
|                 for ip in self.configuration.lvm_share_export_ips: |                 for ip in self.configuration.lvm_share_export_ips: | ||||||
|                     self.configured_ip_version.append( |                     self.configured_ip_version.append( | ||||||
|                         ipaddress.ip_address(six.text_type(ip)).version) |                         ipaddress.ip_address(six.text_type(ip)).version) | ||||||
|             except Exception: |             except Exception: | ||||||
|                 if self.configuration.lvm_share_export_ip: |                 message = (_("Invalid 'lvm_share_export_ips' option supplied " | ||||||
|                     message = (_("Invalid 'lvm_share_export_ip' option " |                              "%s.") % self.configuration.lvm_share_export_ips) | ||||||
|                                  "supplied %s.") % |  | ||||||
|                                self.configuration.lvm_share_export_ip) |  | ||||||
|                 else: |  | ||||||
|                     message = (_("Invalid 'lvm_share_export_ips' option " |  | ||||||
|                                  "supplied %s.") % |  | ||||||
|                                self.configuration.lvm_share_export_ips) |  | ||||||
|                 raise exception.InvalidInput(reason=message) |                 raise exception.InvalidInput(reason=message) | ||||||
|         return self.configured_ip_version |         return self.configured_ip_version | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ from manila.tests.share.drivers.container import fakes as cont_fakes | |||||||
|  |  | ||||||
|  |  | ||||||
| CONF = cfg.CONF | CONF = cfg.CONF | ||||||
| CONF.import_opt('lvm_share_export_ip', 'manila.share.drivers.lvm') | CONF.import_opt('lvm_share_export_ips', 'manila.share.drivers.lvm') | ||||||
|  |  | ||||||
|  |  | ||||||
| @ddt.ddt | @ddt.ddt | ||||||
| @@ -53,7 +53,7 @@ class ContainerShareDriverTestCase(test.TestCase): | |||||||
|         self.share = cont_fakes.fake_share() |         self.share = cont_fakes.fake_share() | ||||||
|         self.access = cont_fakes.fake_access() |         self.access = cont_fakes.fake_access() | ||||||
|         self.server = { |         self.server = { | ||||||
|             'public_address': self.fake_conf.lvm_share_export_ip, |             'public_address': self.fake_conf.lvm_share_export_ips, | ||||||
|             'instance_id': 'LVM', |             'instance_id': 'LVM', | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -150,16 +150,6 @@ class LVMShareDriverTestCase(test.TestCase): | |||||||
|         self.assertRaises(exception.InvalidParameterValue, |         self.assertRaises(exception.InvalidParameterValue, | ||||||
|                           self._driver.check_for_setup_error) |                           self._driver.check_for_setup_error) | ||||||
|  |  | ||||||
|     def test_check_for_setup_error_deprecated_export_ip(self): |  | ||||||
|         def exec_runner(*ignore_args, **ignore_kwargs): |  | ||||||
|             return '\n   fake1\n   fakevg\n   fake2\n', '' |  | ||||||
|  |  | ||||||
|         fake_utils.fake_execute_set_repliers([('vgs --noheadings -o name', |  | ||||||
|                                                exec_runner)]) |  | ||||||
|         CONF.set_default('lvm_share_export_ip', CONF.lvm_share_export_ips[0]) |  | ||||||
|         CONF.set_default('lvm_share_export_ips', None) |  | ||||||
|         self.assertIsNone(self._driver.check_for_setup_error()) |  | ||||||
|  |  | ||||||
|     def test_check_for_setup_error_no_export_ips(self): |     def test_check_for_setup_error_no_export_ips(self): | ||||||
|         def exec_runner(*ignore_args, **ignore_kwargs): |         def exec_runner(*ignore_args, **ignore_kwargs): | ||||||
|             return '\n   fake1\n   fakevg\n   fake2\n', '' |             return '\n   fake1\n   fakevg\n   fake2\n', '' | ||||||
| @@ -170,16 +160,6 @@ class LVMShareDriverTestCase(test.TestCase): | |||||||
|         self.assertRaises(exception.InvalidParameterValue, |         self.assertRaises(exception.InvalidParameterValue, | ||||||
|                           self._driver.check_for_setup_error) |                           self._driver.check_for_setup_error) | ||||||
|  |  | ||||||
|     def test_check_for_setup_error_both_export_ip_and_ips(self): |  | ||||||
|         def exec_runner(*ignore_args, **ignore_kwargs): |  | ||||||
|             return '\n   fake1\n   fakevg\n   fake2\n', '' |  | ||||||
|  |  | ||||||
|         fake_utils.fake_execute_set_repliers([('vgs --noheadings -o name', |  | ||||||
|                                                exec_runner)]) |  | ||||||
|         CONF.set_default('lvm_share_export_ip', CONF.lvm_share_export_ips[0]) |  | ||||||
|         self.assertRaises(exception.InvalidParameterValue, |  | ||||||
|                           self._driver.check_for_setup_error) |  | ||||||
|  |  | ||||||
|     def test_local_path_normal(self): |     def test_local_path_normal(self): | ||||||
|         share = fake_share(name='fake_sharename') |         share = fake_share(name='fake_sharename') | ||||||
|         CONF.set_default('lvm_share_volume_group', 'fake_vg') |         CONF.set_default('lvm_share_volume_group', 'fake_vg') | ||||||
| @@ -403,15 +383,15 @@ class LVMShareDriverTestCase(test.TestCase): | |||||||
|                 self.server, self.share['name'], |                 self.server, self.share['name'], | ||||||
|                 access_rules, add_rules=add_rules, delete_rules=delete_rules)) |                 access_rules, add_rules=add_rules, delete_rules=delete_rules)) | ||||||
|  |  | ||||||
|     @ddt.data(('1001::1001/129', None, False), ('1.1.1.256', None, False), |     @ddt.data((['1001::1001/129'], False), | ||||||
|               ('1001::1001', None, [6]), ('1.1.1.0', None, [4]), |               (['1.1.1.256'], False), | ||||||
|               (None, ['1001::1001', '1.1.1.0'], [6, 4]), |               (['1001::1001'], [6]), | ||||||
|               (None, ['1001::1001'], [6]), (None, ['1.1.1.0'], [4]), |               ('1.1.1.0', [4]), | ||||||
|               (None, ['1001::1001/129', '1.1.1.0'], False)) |               (['1001::1001', '1.1.1.0'], [6, 4]), | ||||||
|  |               (['1001::1001/129', '1.1.1.0'], False)) | ||||||
|     @ddt.unpack |     @ddt.unpack | ||||||
|     def test_get_configured_ip_versions( |     def test_get_configured_ip_versions(self, configured_ips, | ||||||
|             self, configured_ip, configured_ips, configured_ip_version): |                                         configured_ip_version): | ||||||
|         CONF.set_default('lvm_share_export_ip', configured_ip) |  | ||||||
|         CONF.set_default('lvm_share_export_ips', configured_ips) |         CONF.set_default('lvm_share_export_ips', configured_ips) | ||||||
|         if configured_ip_version: |         if configured_ip_version: | ||||||
|             self.assertEqual(configured_ip_version, |             self.assertEqual(configured_ip_version, | ||||||
| @@ -547,10 +527,10 @@ class LVMShareDriverTestCase(test.TestCase): | |||||||
|                                               'count=1024', 'bs=1M', |                                               'count=1024', 'bs=1M', | ||||||
|                                               run_as_root=True) |                                               run_as_root=True) | ||||||
|  |  | ||||||
|     @ddt.data(('1.1.1.1', 4), ('1001::1001', 6)) |     @ddt.data((['1.1.1.1'], 4), (['1001::1001'], 6)) | ||||||
|     @ddt.unpack |     @ddt.unpack | ||||||
|     def test_update_share_stats(self, configured_ip, version): |     def test_update_share_stats(self, configured_ip, version): | ||||||
|         CONF.set_default('lvm_share_export_ip', configured_ip) |         CONF.set_default('lvm_share_export_ips', configured_ip) | ||||||
|         self.mock_object(self._driver, 'get_share_server_pools', |         self.mock_object(self._driver, 'get_share_server_pools', | ||||||
|                          mock.Mock(return_value='test-pool')) |                          mock.Mock(return_value='test-pool')) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -0,0 +1,7 @@ | |||||||
|  | --- | ||||||
|  | upgrade: | ||||||
|  |   - | | ||||||
|  |     The LVM driver configuration option ``lvm_share_export_ip`` is no longer | ||||||
|  |     supported. This option has been replaced by ``lvm_share_export_ips`` | ||||||
|  |     which accepts a comma-separated string of IP addresses of the host | ||||||
|  |     exporting the LVM shares (NFS/CIFS share server). | ||||||
		Reference in New Issue
	
	Block a user
	 Goutham Pacha Ravi
					Goutham Pacha Ravi