]> review.fuel-infra Code Review - openstack-build/cinder-build.git/commitdiff
Port IBM storewize_svc driver to Python 3
authorVictor Stinner <vstinner@redhat.com>
Sun, 8 Nov 2015 21:36:01 +0000 (22:36 +0100)
committerVictor Stinner <vstinner@redhat.com>
Tue, 24 Nov 2015 11:15:24 +0000 (12:15 +0100)
Change default preferred node in
StorwizeSVCDriver.initialize_connection(). For fiber channel without
multipath, pick the first node from the list of sorted nodes, to have
a determinist preferred node. The list of nodes is created indirectly
using list(set(nodes)) which doesn't have a determinist order. On
Python 3, the hash function is randomized, and so list(set()) has an
unknown order.

A similar change was done for volume throttling in the change
Icf7141f772397c7ac08f0f1e21ad74cb86a06351 to port the code
to Python 3.

Other changes:

* Use assertSetEqual() in test_storwize_svc to compare
  initiator_target_map, because conn_wwpns has a random order on
  Python 3.
* StorwizeSVCDriver._check_volume_copy_ops(): replace dict.items()
  with list(dict.items()) to iterate on items. On Python 3,
  dict.items() now returns a view instead of a copy. The loop
  modifies the dictionary and a dict must not be modified while
  iterating on it, we really need a copy of items.
* StorwizeHelpers: replace a/b with a//b to use integer division on
  Python 3.
* tests-py3.txt: add cinder.tests.unit.test_storwize_svc

Partial-Implements: blueprint cinder-python3
Change-Id: I534a85928816d6cce921545e1820311aedd1b884

cinder/volume/drivers/ibm/storwize_svc/__init__.py
cinder/volume/drivers/ibm/storwize_svc/storwize_svc_common.py
tests-py3.txt

index f41a7d87bd4d5b97620a79198a66e9a85aaa9a54..e341ff72cff8b93681f781ff71752441a533fe50 100644 (file)
@@ -749,7 +749,7 @@ class StorwizeSVCDriver(san.SanDriver,
     def _check_volume_copy_ops(self):
         LOG.debug("Enter: update volume copy status.")
         ctxt = context.get_admin_context()
-        copy_items = self._vdiskcopyops.items()
+        copy_items = list(self._vdiskcopyops.items())
         for vol_id, copy_ops in copy_items:
             try:
                 volume = self.db.volume_get(ctxt, vol_id)
index c4370d0a8dc74b4488d668346c85c82917141d43..bbc426d45a6a566498988d332e42048c0d58adfb 100644 (file)
@@ -1014,7 +1014,7 @@ class StorwizeHelpers(object):
         self.ssh.prestartfcmap(fc_map_id)
         mapping_ready = False
         wait_time = 5
-        max_retries = (timeout / wait_time) + 1
+        max_retries = (timeout // wait_time) + 1
         for try_number in range(1, max_retries):
             mapping_attrs = self._get_flashcopy_mapping_attributes(fc_map_id)
             if (mapping_attrs is None or
index 18edc1ea253a5d7f9418b2e4f022ebe93cdb72df..3305ce77f45929016c904883909c4c7b9d4485e2 100644 (file)
@@ -105,6 +105,7 @@ cinder.tests.unit.test_smbfs
 cinder.tests.unit.test_srb
 cinder.tests.unit.test_solidfire
 cinder.tests.unit.test_ssh_utils
+cinder.tests.unit.test_storwize_svc
 cinder.tests.unit.test_test
 cinder.tests.unit.test_test_utils
 cinder.tests.unit.test_tintri