From 4c9b590877daa8f2a31c23e811a08d90b3439a4c Mon Sep 17 00:00:00 2001 From: Michael Vogt Date: Thu, 5 Dec 2024 13:24:46 +0100 Subject: [PATCH] disk: support automatic name generation for swap devices This commit adds support for automatic geneation of names for an lv swap devices. This saves the users of advanced blueprints some typing. --- pkg/disk/lvm.go | 13 ++++++++----- pkg/disk/lvm_test.go | 23 +++++++++++++++++++++++ 2 files changed, 31 insertions(+), 5 deletions(-) diff --git a/pkg/disk/lvm.go b/pkg/disk/lvm.go index 54fc2523d5..7d0898ea67 100644 --- a/pkg/disk/lvm.go +++ b/pkg/disk/lvm.go @@ -110,12 +110,15 @@ func (vg *LVMVolumeGroup) CreateLogicalVolume(lvName string, size uint64, payloa if lvName == "" { // generate a name based on the payload's mountpoint - mntble, ok := payload.(Mountable) - if !ok { - return nil, fmt.Errorf("could not create logical volume: no name provided and payload is not mountable") + switch ent := payload.(type) { + case Mountable: + lvName = ent.GetMountpoint() + case *Swap: + lvName = "swap" + default: + return nil, fmt.Errorf("could not create logical volume: no name provided and payload %T is not mountable or swap", payload) } - mountpoint := mntble.GetMountpoint() - autoName, err := vg.genLVName(mountpoint) + autoName, err := vg.genLVName(lvName) if err != nil { return nil, err } diff --git a/pkg/disk/lvm_test.go b/pkg/disk/lvm_test.go index e75dc9304c..0cd3755dc7 100644 --- a/pkg/disk/lvm_test.go +++ b/pkg/disk/lvm_test.go @@ -39,6 +39,29 @@ func TestLVMVCreateMountpoint(t *testing.T) { assert.Error(err) } +func TestLVMVCreateLogicalVolumeSwap(t *testing.T) { + vg := &LVMVolumeGroup{ + Name: "root", + Description: "root volume group", + } + swap := &Swap{} + lv, err := vg.CreateLogicalVolume("", 12345, swap) + assert.NoError(t, err) + assert.Equal(t, "swaplv", lv.Name) + // one more + lv2, err := vg.CreateLogicalVolume("", 12345, swap) + assert.NoError(t, err) + assert.Equal(t, "swaplv00", lv2.Name) +} + +func TestLVMVCreateLogicalVolumeWrongType(t *testing.T) { + vg := &LVMVolumeGroup{ + Name: "root", + } + _, err := vg.CreateLogicalVolume("", 12345, &LUKSContainer{}) + assert.EqualError(t, err, `could not create logical volume: no name provided and payload *disk.LUKSContainer is not mountable or swap`) +} + func TestImplementsInterfacesCompileTimeCheckLVM(t *testing.T) { var _ = Container(&LVMVolumeGroup{}) var _ = Sizeable(&LVMLogicalVolume{})