]> git.apps.os.sepia.ceph.com Git - ceph-ci.git/commitdiff
ceph-volume: fix is_ceph_disk_member()
authorGuillaume Abrioux <gabrioux@redhat.com>
Tue, 26 Jul 2022 14:24:31 +0000 (16:24 +0200)
committerGuillaume Abrioux <gabrioux@redhat.com>
Wed, 27 Jul 2022 07:59:16 +0000 (09:59 +0200)
`dev['NAME']` can't match `part` given that it's the name of the
parent device being compared to the partition name.

Signed-off-by: Guillaume Abrioux <gabrioux@redhat.com>
src/ceph-volume/ceph_volume/util/device.py

index 3892b69b05a06b56c4722cd3f086941fc7238b51..a68377169ff9353335a567714bbdadf479c02f4b 100644 (file)
@@ -408,11 +408,14 @@ class Device(object):
         # If we come from Devices(), self.lsblk_all is set already.
         # Otherwise, we have to grab the data.
         details = self.lsblk_all or disk.lsblk_all()
+        _is_member = False
         if self.sys_api.get("partitions"):
             for part in self.sys_api.get("partitions").keys():
                 for dev in details:
-                    if dev['NAME'] == part:
-                        return is_member(dev)
+                    if part.startswith(dev['NAME']):
+                        if is_member(dev):
+                            _is_member = True
+                return _is_member
         else:
             return is_member(self.disk_api)
         raise RuntimeError(f"Couln't check if device {self.path} is a ceph-disk member.")