Blame 0012-lvm-Add-support-for-starting-and-stopping-VG-locking.patch

Vojtech Trefny e28fe6
From f72ba6aded6093d34d5e8a1666a844ec2b0ee5eb Mon Sep 17 00:00:00 2001
Vojtech Trefny e28fe6
From: Vojtech Trefny <vtrefny@redhat.com>
Vojtech Trefny e28fe6
Date: Tue, 18 Apr 2023 12:05:35 +0200
Vojtech Trefny e28fe6
Subject: [PATCH] lvm: Add support for starting and stopping VG locking
Vojtech Trefny e28fe6
Vojtech Trefny e28fe6
---
Vojtech Trefny e28fe6
 docs/libblockdev-sections.txt |  2 ++
Vojtech Trefny e28fe6
 src/lib/plugin_apis/lvm.api   | 27 +++++++++++++++++++
Vojtech Trefny e28fe6
 src/plugins/lvm-dbus.c        | 49 ++++++++++++++++++++++++++++++++++-
Vojtech Trefny e28fe6
 src/plugins/lvm.c             | 41 +++++++++++++++++++++++++++++
Vojtech Trefny e28fe6
 src/plugins/lvm.h             |  3 +++
Vojtech Trefny e28fe6
 tests/lvm_dbus_tests.py       | 33 +++++++++++++++++++++++
Vojtech Trefny e28fe6
 tests/lvm_test.py             | 32 +++++++++++++++++++++++
Vojtech Trefny e28fe6
 7 files changed, 186 insertions(+), 1 deletion(-)
Vojtech Trefny e28fe6
Vojtech Trefny e28fe6
diff --git a/docs/libblockdev-sections.txt b/docs/libblockdev-sections.txt
Vojtech Trefny e28fe6
index 540e2b96..08ea309c 100644
Vojtech Trefny e28fe6
--- a/docs/libblockdev-sections.txt
Vojtech Trefny e28fe6
+++ b/docs/libblockdev-sections.txt
Vojtech Trefny e28fe6
@@ -286,6 +286,8 @@ bd_lvm_vgactivate
Vojtech Trefny e28fe6
 bd_lvm_vgdeactivate
Vojtech Trefny e28fe6
 bd_lvm_vgextend
Vojtech Trefny e28fe6
 bd_lvm_vgreduce
Vojtech Trefny e28fe6
+bd_lvm_vglock_start
Vojtech Trefny e28fe6
+bd_lvm_vglock_stop
Vojtech Trefny e28fe6
 bd_lvm_vginfo
Vojtech Trefny e28fe6
 bd_lvm_vgs
Vojtech Trefny e28fe6
 bd_lvm_lvorigin
Vojtech Trefny e28fe6
diff --git a/src/lib/plugin_apis/lvm.api b/src/lib/plugin_apis/lvm.api
Vojtech Trefny e28fe6
index 640eee49..1343fbdb 100644
Vojtech Trefny e28fe6
--- a/src/lib/plugin_apis/lvm.api
Vojtech Trefny e28fe6
+++ b/src/lib/plugin_apis/lvm.api
Vojtech Trefny e28fe6
@@ -603,6 +603,7 @@ typedef enum {
Vojtech Trefny e28fe6
     BD_LVM_TECH_GLOB_CONF,
Vojtech Trefny e28fe6
     BD_LVM_TECH_VDO,
Vojtech Trefny e28fe6
     BD_LVM_TECH_DEVICES,
Vojtech Trefny e28fe6
+    BD_LVM_TECH_SHARED,
Vojtech Trefny e28fe6
 } BDLVMTech;
Vojtech Trefny e28fe6
 
Vojtech Trefny e28fe6
 typedef enum {
Vojtech Trefny e28fe6
@@ -943,6 +944,32 @@ gboolean bd_lvm_vgextend (const gchar *vg_name, const gchar *device, const BDExt
Vojtech Trefny e28fe6
  */
Vojtech Trefny e28fe6
 gboolean bd_lvm_vgreduce (const gchar *vg_name, const gchar *device, const BDExtraArg **extra, GError **error);
Vojtech Trefny e28fe6
 
Vojtech Trefny e28fe6
+/**
Vojtech Trefny e28fe6
+ * bd_lvm_vglock_start:
Vojtech Trefny e28fe6
+ * @vg_name: a shared VG to start the lockspace in lvmlockd
Vojtech Trefny e28fe6
+ * @extra: (nullable) (array zero-terminated=1): extra options for the vgchange command
Vojtech Trefny e28fe6
+ *                                               (just passed to LVM as is)
Vojtech Trefny e28fe6
+ * @error: (out): place to store error (if any)
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Returns: whether the lock was successfully started for @vg_name or not
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Tech category: %BD_LVM_TECH_SHARED-%BD_LVM_TECH_MODE_MODIFY
Vojtech Trefny e28fe6
+ */
Vojtech Trefny e28fe6
+gboolean bd_lvm_vglock_start (const gchar *vg_name, const BDExtraArg **extra, GError **error);
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+/**
Vojtech Trefny e28fe6
+ * bd_lvm_vglock_stop:
Vojtech Trefny e28fe6
+ * @vg_name: a shared VG to stop the lockspace in lvmlockd
Vojtech Trefny e28fe6
+ * @extra: (nullable) (array zero-terminated=1): extra options for the vgchange command
Vojtech Trefny e28fe6
+ *                                               (just passed to LVM as is)
Vojtech Trefny e28fe6
+ * @error: (out): place to store error (if any)
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Returns: whether the lock was successfully stopped for @vg_name or not
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Tech category: %BD_LVM_TECH_SHARED-%BD_LVM_TECH_MODE_MODIFY
Vojtech Trefny e28fe6
+ */
Vojtech Trefny e28fe6
+gboolean bd_lvm_vglock_stop (const gchar *vg_name, const BDExtraArg **extra, GError **error);
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
 /**
Vojtech Trefny e28fe6
  * bd_lvm_vginfo:
Vojtech Trefny e28fe6
  * @vg_name: a VG to get information about
Vojtech Trefny e28fe6
diff --git a/src/plugins/lvm-dbus.c b/src/plugins/lvm-dbus.c
Vojtech Trefny e28fe6
index 46e09833..a129d884 100644
Vojtech Trefny e28fe6
--- a/src/plugins/lvm-dbus.c
Vojtech Trefny e28fe6
+++ b/src/plugins/lvm-dbus.c
Vojtech Trefny e28fe6
@@ -1872,10 +1872,57 @@ gboolean bd_lvm_vgreduce (const gchar *vg_name, const gchar *device, const BDExt
Vojtech Trefny e28fe6
     return ((*error) == NULL);
Vojtech Trefny e28fe6
 }
Vojtech Trefny e28fe6
 
Vojtech Trefny e28fe6
+gboolean _vglock_start_stop (const gchar *vg_name, gboolean start, const BDExtraArg **extra, GError **error) {
Vojtech Trefny e28fe6
+    GVariantBuilder builder;
Vojtech Trefny e28fe6
+    GVariant *params = NULL;
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+    g_variant_builder_init (&builder, G_VARIANT_TYPE_DICTIONARY);
Vojtech Trefny e28fe6
+    if (start)
Vojtech Trefny e28fe6
+        g_variant_builder_add (&builder, "{sv}", "--lockstart", g_variant_new ("s", ""));
Vojtech Trefny e28fe6
+    else
Vojtech Trefny e28fe6
+        g_variant_builder_add (&builder, "{sv}", "--lockstop", g_variant_new ("s", ""));
Vojtech Trefny e28fe6
+    params = g_variant_builder_end (&builder);
Vojtech Trefny e28fe6
+    g_variant_builder_clear (&builder);
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+    call_lvm_obj_method_sync (vg_name, VG_INTF, "Change", NULL, params, extra, TRUE, error);
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+    return ((*error) == NULL);
Vojtech Trefny e28fe6
+}
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+/**
Vojtech Trefny e28fe6
+ * bd_lvm_vglock_start:
Vojtech Trefny e28fe6
+ * @vg_name: a shared VG to start the lockspace in lvmlockd
Vojtech Trefny e28fe6
+ * @extra: (nullable) (array zero-terminated=1): extra options for the vgchange command
Vojtech Trefny e28fe6
+ *                                               (just passed to LVM as is)
Vojtech Trefny e28fe6
+ * @error: (out): place to store error (if any)
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Returns: whether the lock was successfully started for @vg_name or not
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Tech category: %BD_LVM_TECH_BASIC-%BD_LVM_TECH_MODE_MODIFY
Vojtech Trefny e28fe6
+ */
Vojtech Trefny e28fe6
+gboolean bd_lvm_vglock_start (const gchar *vg_name, const BDExtraArg **extra, GError **error) {
Vojtech Trefny e28fe6
+    return _vglock_start_stop (vg_name, TRUE, extra, error);
Vojtech Trefny e28fe6
+}
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+/**
Vojtech Trefny e28fe6
+ * bd_lvm_vglock_stop:
Vojtech Trefny e28fe6
+ * @vg_name: a shared VG to stop the lockspace in lvmlockd
Vojtech Trefny e28fe6
+ * @extra: (nullable) (array zero-terminated=1): extra options for the vgchange command
Vojtech Trefny e28fe6
+ *                                               (just passed to LVM as is)
Vojtech Trefny e28fe6
+ * @error: (out): place to store error (if any)
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Returns: whether the lock was successfully stopped for @vg_name or not
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Tech category: %BD_LVM_TECH_BASIC-%BD_LVM_TECH_MODE_MODIFY
Vojtech Trefny e28fe6
+ */
Vojtech Trefny e28fe6
+gboolean bd_lvm_vglock_stop (const gchar *vg_name, const BDExtraArg **extra, GError **error) {
Vojtech Trefny e28fe6
+    return _vglock_start_stop (vg_name, FALSE, extra, error);
Vojtech Trefny e28fe6
+}
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
 /**
Vojtech Trefny e28fe6
  * bd_lvm_vginfo:
Vojtech Trefny e28fe6
  * @vg_name: a VG to get information about
Vojtech Trefny e28fe6
- * @error: (out): place to store error (if any)
Vojtech Trefny e28fe6
+ * @error: (out) (optional): place to store error (if any)
Vojtech Trefny e28fe6
  *
Vojtech Trefny e28fe6
  * Returns: (transfer full): information about the @vg_name VG or %NULL in case
Vojtech Trefny e28fe6
  * of error (the @error) gets populated in those cases)
Vojtech Trefny e28fe6
diff --git a/src/plugins/lvm.c b/src/plugins/lvm.c
Vojtech Trefny e28fe6
index 0db3bf4a..b0a71224 100644
Vojtech Trefny e28fe6
--- a/src/plugins/lvm.c
Vojtech Trefny e28fe6
+++ b/src/plugins/lvm.c
Vojtech Trefny e28fe6
@@ -1341,6 +1341,47 @@ gboolean bd_lvm_vgreduce (const gchar *vg_name, const gchar *device, const BDExt
Vojtech Trefny e28fe6
     return call_lvm_and_report_error (args, extra, TRUE, error);
Vojtech Trefny e28fe6
 }
Vojtech Trefny e28fe6
 
Vojtech Trefny e28fe6
+gboolean _vglock_start_stop (const gchar *vg_name, gboolean start, const BDExtraArg **extra, GError **error) {
Vojtech Trefny e28fe6
+    const gchar *args[4] = {"vgchange", NULL, vg_name, NULL};
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+    if (start)
Vojtech Trefny e28fe6
+        args[1] = "--lockstart";
Vojtech Trefny e28fe6
+    else
Vojtech Trefny e28fe6
+        args[1] = "--lockstop";
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+    return call_lvm_and_report_error (args, extra, TRUE, error);
Vojtech Trefny e28fe6
+}
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+/**
Vojtech Trefny e28fe6
+ * bd_lvm_vglock_start:
Vojtech Trefny e28fe6
+ * @vg_name: a shared VG to start the lockspace in lvmlockd
Vojtech Trefny e28fe6
+ * @extra: (nullable) (array zero-terminated=1): extra options for the vgchange command
Vojtech Trefny e28fe6
+ *                                               (just passed to LVM as is)
Vojtech Trefny e28fe6
+ * @error: (out): place to store error (if any)
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Returns: whether the lock was successfully started for @vg_name or not
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Tech category: %BD_LVM_TECH_SHARED-%BD_LVM_TECH_MODE_MODIFY
Vojtech Trefny e28fe6
+ */
Vojtech Trefny e28fe6
+gboolean bd_lvm_vglock_start (const gchar *vg_name, const BDExtraArg **extra, GError **error) {
Vojtech Trefny e28fe6
+    return _vglock_start_stop (vg_name, TRUE, extra, error);
Vojtech Trefny e28fe6
+}
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+/**
Vojtech Trefny e28fe6
+ * bd_lvm_vglock_stop:
Vojtech Trefny e28fe6
+ * @vg_name: a shared VG to stop the lockspace in lvmlockd
Vojtech Trefny e28fe6
+ * @extra: (nullable) (array zero-terminated=1): extra options for the vgchange command
Vojtech Trefny e28fe6
+ *                                               (just passed to LVM as is)
Vojtech Trefny e28fe6
+ * @error: (out): place to store error (if any)
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Returns: whether the lock was successfully stopped for @vg_name or not
Vojtech Trefny e28fe6
+ *
Vojtech Trefny e28fe6
+ * Tech category: %BD_LVM_TECH_SHARED-%BD_LVM_TECH_MODE_MODIFY
Vojtech Trefny e28fe6
+ */
Vojtech Trefny e28fe6
+gboolean bd_lvm_vglock_stop (const gchar *vg_name, const BDExtraArg **extra, GError **error) {
Vojtech Trefny e28fe6
+    return _vglock_start_stop (vg_name, FALSE, extra, error);
Vojtech Trefny e28fe6
+}
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
 /**
Vojtech Trefny e28fe6
  * bd_lvm_vginfo:
Vojtech Trefny e28fe6
  * @vg_name: a VG to get information about
Vojtech Trefny e28fe6
diff --git a/src/plugins/lvm.h b/src/plugins/lvm.h
Vojtech Trefny e28fe6
index c85c043d..2e47b06f 100644
Vojtech Trefny e28fe6
--- a/src/plugins/lvm.h
Vojtech Trefny e28fe6
+++ b/src/plugins/lvm.h
Vojtech Trefny e28fe6
@@ -218,6 +218,7 @@ typedef enum {
Vojtech Trefny e28fe6
     BD_LVM_TECH_GLOB_CONF,
Vojtech Trefny e28fe6
     BD_LVM_TECH_VDO,
Vojtech Trefny e28fe6
     BD_LVM_TECH_DEVICES,
Vojtech Trefny e28fe6
+    BD_LVM_TECH_SHARED,
Vojtech Trefny e28fe6
 } BDLVMTech;
Vojtech Trefny e28fe6
 
Vojtech Trefny e28fe6
 typedef enum {
Vojtech Trefny e28fe6
@@ -268,6 +269,8 @@ gboolean bd_lvm_vgactivate (const gchar *vg_name, const BDExtraArg **extra, GErr
Vojtech Trefny e28fe6
 gboolean bd_lvm_vgdeactivate (const gchar *vg_name, const BDExtraArg **extra, GError **error);
Vojtech Trefny e28fe6
 gboolean bd_lvm_vgextend (const gchar *vg_name, const gchar *device, const BDExtraArg **extra, GError **error);
Vojtech Trefny e28fe6
 gboolean bd_lvm_vgreduce (const gchar *vg_name, const gchar *device, const BDExtraArg **extra, GError **error);
Vojtech Trefny e28fe6
+gboolean bd_lvm_vglock_start (const gchar *vg_name, const BDExtraArg **extra, GError **error);
Vojtech Trefny e28fe6
+gboolean bd_lvm_vglock_stop (const gchar *vg_name, const BDExtraArg **extra, GError **error);
Vojtech Trefny e28fe6
 BDLVMVGdata* bd_lvm_vginfo (const gchar *vg_name, GError **error);
Vojtech Trefny e28fe6
 BDLVMVGdata** bd_lvm_vgs (GError **error);
Vojtech Trefny e28fe6
 
Vojtech Trefny e28fe6
diff --git a/tests/lvm_dbus_tests.py b/tests/lvm_dbus_tests.py
Vojtech Trefny e28fe6
index a821636e..bc8b3052 100644
Vojtech Trefny e28fe6
--- a/tests/lvm_dbus_tests.py
Vojtech Trefny e28fe6
+++ b/tests/lvm_dbus_tests.py
Vojtech Trefny e28fe6
@@ -655,6 +655,39 @@ class LvmTestVGs(LvmPVVGTestCase):
Vojtech Trefny e28fe6
         succ = BlockDev.lvm_pvremove(self.loop_dev, None)
Vojtech Trefny e28fe6
         self.assertTrue(succ)
Vojtech Trefny e28fe6
 
Vojtech Trefny e28fe6
+@unittest.skipUnless(lvm_dbus_running, "LVM DBus not running")
Vojtech Trefny e28fe6
+class LvmTestVGLocking(LvmPVVGTestCase):
Vojtech Trefny e28fe6
+    @tag_test(TestTags.UNSAFE)
Vojtech Trefny e28fe6
+    def test_vglock_stop_start(self):
Vojtech Trefny e28fe6
+        """Verify that it is possible to start and stop locking on a VG"""
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        # better not do anything if lvmlockd is running, shared VGs have
Vojtech Trefny e28fe6
+        # a tendency to wreak havoc on your system if you look at them wrong
Vojtech Trefny e28fe6
+        ret, _out, _err = run_command("systemctl is-active lvmlockd")
Vojtech Trefny e28fe6
+        if ret == 0:
Vojtech Trefny e28fe6
+            self.skipTest("lvmlockd is running, skipping")
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        _ret, out, _err = run_command("lvm config 'global/use_lvmlockd'")
Vojtech Trefny e28fe6
+        if "use_lvmlockd=0" not in out:
Vojtech Trefny e28fe6
+            self.skipTest("lvmlockd is enabled, skipping")
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_pvcreate(self.loop_dev, 0, 0, None)
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_pvcreate(self.loop_dev2, 0, 0, None)
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_vgcreate("testVG", [self.loop_dev, self.loop_dev2], 0, None)
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        # this actually doesn't "test" anything, the commands will just say lvmlockd is not
Vojtech Trefny e28fe6
+        # running and return 0, but that's good enough for us
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_vglock_start("testVG")
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_vglock_stop("testVG")
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
 @unittest.skipUnless(lvm_dbus_running, "LVM DBus not running")
Vojtech Trefny e28fe6
 class LvmPVVGLVTestCase(LvmPVVGTestCase):
Vojtech Trefny e28fe6
     def _clean_up(self):
Vojtech Trefny e28fe6
diff --git a/tests/lvm_test.py b/tests/lvm_test.py
Vojtech Trefny e28fe6
index 63f43afb..d517001b 100644
Vojtech Trefny e28fe6
--- a/tests/lvm_test.py
Vojtech Trefny e28fe6
+++ b/tests/lvm_test.py
Vojtech Trefny e28fe6
@@ -632,6 +632,38 @@ class LvmTestVGs(LvmPVVGTestCase):
Vojtech Trefny e28fe6
         succ = BlockDev.lvm_pvremove(self.loop_dev, None)
Vojtech Trefny e28fe6
         self.assertTrue(succ)
Vojtech Trefny e28fe6
 
Vojtech Trefny e28fe6
+class LvmTestVGLocking(LvmPVVGTestCase):
Vojtech Trefny e28fe6
+    @tag_test(TestTags.UNSAFE)
Vojtech Trefny e28fe6
+    def test_vglock_stop_start(self):
Vojtech Trefny e28fe6
+        """Verify that it is possible to start and stop locking on a VG"""
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        # better not do anything if lvmlockd is running, shared VGs have
Vojtech Trefny e28fe6
+        # a tendency to wreak havoc on your system if you look at them wrong
Vojtech Trefny e28fe6
+        ret, _out, _err = run_command("systemctl is-active lvmlockd")
Vojtech Trefny e28fe6
+        if ret == 0:
Vojtech Trefny e28fe6
+            self.skipTest("lvmlockd is running, skipping")
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        _ret, out, _err = run_command("lvm config 'global/use_lvmlockd'")
Vojtech Trefny e28fe6
+        if "use_lvmlockd=0" not in out:
Vojtech Trefny e28fe6
+            self.skipTest("lvmlockd is enabled, skipping")
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_pvcreate(self.loop_dev, 0, 0, None)
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_pvcreate(self.loop_dev2, 0, 0, None)
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_vgcreate("testVG", [self.loop_dev, self.loop_dev2], 0, None)
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        # this actually doesn't "test" anything, the commands will just say lvmlockd is not
Vojtech Trefny e28fe6
+        # running and return 0, but that's good enough for us
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_vglock_start("testVG")
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
+        succ = BlockDev.lvm_vglock_stop("testVG")
Vojtech Trefny e28fe6
+        self.assertTrue(succ)
Vojtech Trefny e28fe6
+
Vojtech Trefny e28fe6
 class LvmPVVGLVTestCase(LvmPVVGTestCase):
Vojtech Trefny e28fe6
     def _clean_up(self):
Vojtech Trefny e28fe6
         try:
Vojtech Trefny e28fe6
-- 
Vojtech Trefny e28fe6
2.41.0
Vojtech Trefny e28fe6