From efbeb4da49f8f7364490fd50566256133be26b0e Mon Sep 17 00:00:00 2001 From: Lasith Koswatta Gamage Date: Sat, 25 May 2024 14:25:21 +1000 Subject: [PATCH] (feat): Add test cases for layer.ShouldProcess() --- internal/layer/directory_test.go | 37 ++++++++++++++ internal/layer/format_test.go | 27 +++++++++++ internal/layer/label_test.go | 42 ++++++++++++++++ internal/layer/layer_test.go | 32 ++++++++++--- internal/layer/lv_activate_test.go | 45 +++++++++++++++++ internal/layer/lv_resize_test.go | 59 +++++++++++++++++++++++ internal/layer/lv_test.go | 45 +++++++++++++++++ internal/layer/mount_test.go | 37 ++++++++++++++ internal/layer/owner_test.go | 77 ++++++++++++++++++++++++++++++ internal/layer/permissions_test.go | 51 ++++++++++++++++++++ internal/layer/pv_resize_test.go | 59 +++++++++++++++++++++++ internal/layer/pv_test.go | 45 +++++++++++++++++ internal/layer/resize_test.go | 39 +++++++++++++++ internal/layer/vg_test.go | 45 +++++++++++++++++ 14 files changed, 633 insertions(+), 7 deletions(-) create mode 100644 internal/layer/lv_activate_test.go create mode 100644 internal/layer/lv_resize_test.go create mode 100644 internal/layer/lv_test.go create mode 100644 internal/layer/pv_resize_test.go create mode 100644 internal/layer/pv_test.go create mode 100644 internal/layer/vg_test.go diff --git a/internal/layer/directory_test.go b/internal/layer/directory_test.go index 26fc488..9934870 100644 --- a/internal/layer/directory_test.go +++ b/internal/layer/directory_test.go @@ -174,3 +174,40 @@ func TestCreateDirectoryLayerValidate(t *testing.T) { }) } } + +func TestCreateDirectoryLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedOutput bool + }{ + { + Name: "At Least Once Device Has Mount Point Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": {}, + "/dev/xvdf": { + MountPoint: "/mnt/foo", + }, + }, + }, + ExpectedOutput: true, + }, + { + Name: "No Device Has Mount Point Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + cdl := NewCreateDirectoryLayer(nil) + value := cdl.ShouldProcess(subtest.Config) + utils.CheckOutput("cdl.ShouldProcess()", t, subtest.ExpectedOutput, value) + }) + } +} diff --git a/internal/layer/format_test.go b/internal/layer/format_test.go index e10cef2..199a60a 100644 --- a/internal/layer/format_test.go +++ b/internal/layer/format_test.go @@ -166,3 +166,30 @@ func TestFormatDeviceLayerValidate(t *testing.T) { }) } } + +func TestFormatDeviceLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedOutput bool + }{ + { + Name: "File System Declared", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": { + Fs: model.Xfs, + }, + }, + }, + ExpectedOutput: true, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + ld := NewFormatDeviceLayer(nil) + output := ld.ShouldProcess(subtest.Config) + utils.CheckOutput("ld.ShouldProcess()", t, subtest.ExpectedOutput, output) + }) + } +} diff --git a/internal/layer/label_test.go b/internal/layer/label_test.go index b9f8b08..eecad0f 100644 --- a/internal/layer/label_test.go +++ b/internal/layer/label_test.go @@ -219,3 +219,45 @@ func TestLabelDeviceLayerValidate(t *testing.T) { }) } } + +func TestLabelDeviceLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedValue bool + }{ + { + Name: "At Least Once Device Has Label Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Fs: model.Ext4, + Label: "label", + }, + "/dev/xvdf": { + Fs: model.Ext4, + }, + }, + }, + ExpectedValue: true, + }, + { + Name: "No Device Has Label Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": { + Fs: model.Ext4, + }, + }, + }, + ExpectedValue: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + ldl := NewLabelDeviceLayer(nil) + value := ldl.ShouldProcess(subtest.Config) + utils.CheckOutput("ldl.ShouldProcess()", t, subtest.ExpectedValue, value) + }) + } +} diff --git a/internal/layer/layer_test.go b/internal/layer/layer_test.go index d973d61..44b026d 100644 --- a/internal/layer/layer_test.go +++ b/internal/layer/layer_test.go @@ -15,9 +15,10 @@ const ( ) type MockLayer struct { - from *utils.MockIncrementError - modify *utils.MockIncrementError - validate *utils.MockIncrementError + from *utils.MockIncrementError + modify *utils.MockIncrementError + validate *utils.MockIncrementError + shouldProcess bool } func (ml *MockLayer) From(c *config.Config) error { @@ -41,7 +42,7 @@ func (ml *MockLayer) Warning() string { } func (ml *MockLayer) ShouldProcess(c *config.Config) bool { - return true + return ml.shouldProcess } func TestExponentialBackoffLayerExecutor(t *testing.T) { @@ -110,9 +111,10 @@ func TestExponentialBackoffLayerExecutor(t *testing.T) { for _, subtest := range subtests { t.Run(subtest.Name, func(t *testing.T) { ml := &MockLayer{ - from: subtest.From, - modify: subtest.Modify, - validate: subtest.Validate, + from: subtest.From, + modify: subtest.Modify, + validate: subtest.Validate, + shouldProcess: true, } eb := NewExponentialBackoffLayerExecutor(nil, mae, ebp) err := eb.Execute([]Layer{ml}) @@ -120,3 +122,19 @@ func TestExponentialBackoffLayerExecutor(t *testing.T) { }) } } + +func TestExponentialBackoffLayerExecutorShouldProcess(t *testing.T) { + // This MockLayer will fail if any of the From(), Modify() or Validate() methods + // are invoked. `shouldProcess` has been set to false so these methods would be skipped + // and there should be no error generated + ml := &MockLayer{ + from: utils.NewMockIncrementError("From()", utils.SuccessUntilTrigger, 1), + modify: utils.NewMockIncrementError("Modidy()", utils.SuccessUntilTrigger, 1), + validate: utils.NewMockIncrementError("Validate()", utils.SuccessUntilTrigger, 1), + shouldProcess: false, + } + debp := DefaultExponentialBackoffParameters() + eb := NewExponentialBackoffLayerExecutor(nil, nil, debp) + err := eb.Execute([]Layer{ml}) + utils.CheckError("eb.Execute()", t, nil, err) +} diff --git a/internal/layer/lv_activate_test.go b/internal/layer/lv_activate_test.go new file mode 100644 index 0000000..8015e48 --- /dev/null +++ b/internal/layer/lv_activate_test.go @@ -0,0 +1,45 @@ +package layer + +import ( + "testing" + + "github.com/reecetech/ebs-bootstrap/internal/config" + "github.com/reecetech/ebs-bootstrap/internal/utils" +) + +func TestActivateLogicalVolumeLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedValue bool + }{ + { + Name: "At Least Once Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Lvm: "lvm-id", + }, + "/dev/xvdf": {}, + }, + }, + ExpectedValue: true, + }, + { + Name: "No Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedValue: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + alvl := NewActivateLogicalVolumeLayer(nil) + output := alvl.ShouldProcess(subtest.Config) + utils.CheckOutput("alvl.ShouldProcess()", t, subtest.ExpectedValue, output) + }) + } +} diff --git a/internal/layer/lv_resize_test.go b/internal/layer/lv_resize_test.go new file mode 100644 index 0000000..8816657 --- /dev/null +++ b/internal/layer/lv_resize_test.go @@ -0,0 +1,59 @@ +package layer + +import ( + "testing" + + "github.com/reecetech/ebs-bootstrap/internal/config" + "github.com/reecetech/ebs-bootstrap/internal/utils" +) + +func TestResizeLogicalVolumeLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedValue bool + }{ + { + Name: "At Least Once Device Has Lvm Specified and Resize Enabled", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Lvm: "lvm-id", + Options: config.Options{ + Resize: true, + }, + }, + "/dev/xvdf": {}, + }, + }, + ExpectedValue: true, + }, + { + Name: "Device Has Lvm Specified, but Resize Disabled", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Lvm: "lvm-id", + }, + }, + }, + ExpectedValue: false, + }, + { + Name: "No Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedValue: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + rlvl := NewResizeLogicalVolumeLayer(nil) + output := rlvl.ShouldProcess(subtest.Config) + utils.CheckOutput("rlvl.ShouldProcess()", t, subtest.ExpectedValue, output) + }) + } +} diff --git a/internal/layer/lv_test.go b/internal/layer/lv_test.go new file mode 100644 index 0000000..eebead8 --- /dev/null +++ b/internal/layer/lv_test.go @@ -0,0 +1,45 @@ +package layer + +import ( + "testing" + + "github.com/reecetech/ebs-bootstrap/internal/config" + "github.com/reecetech/ebs-bootstrap/internal/utils" +) + +func TestCreateLogicalVolumeLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedValue bool + }{ + { + Name: "At Least Once Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Lvm: "lvm-id", + }, + "/dev/xvdf": {}, + }, + }, + ExpectedValue: true, + }, + { + Name: "No Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedValue: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + clvl := NewCreateLogicalVolumeLayer(nil) + output := clvl.ShouldProcess(subtest.Config) + utils.CheckOutput("clvl.ShouldProcess()", t, subtest.ExpectedValue, output) + }) + } +} diff --git a/internal/layer/mount_test.go b/internal/layer/mount_test.go index 3735d62..638846c 100644 --- a/internal/layer/mount_test.go +++ b/internal/layer/mount_test.go @@ -565,3 +565,40 @@ func TestMountDeviceLayerValidate(t *testing.T) { }) } } + +func TestMountDeviceLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedOutput bool + }{ + { + Name: "At Least Once Device Has Mount Point Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": {}, + "/dev/xvdf": { + MountPoint: "/mnt/foo", + }, + }, + }, + ExpectedOutput: true, + }, + { + Name: "No Device Has Mount Point Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + mdl := NewMountDeviceLayer(nil, nil) + output := mdl.ShouldProcess(subtest.Config) + utils.CheckOutput("mdl.ShouldProcess()", t, subtest.ExpectedOutput, output) + }) + } +} diff --git a/internal/layer/owner_test.go b/internal/layer/owner_test.go index d17f4de..ac16c15 100644 --- a/internal/layer/owner_test.go +++ b/internal/layer/owner_test.go @@ -349,3 +349,80 @@ func TestChangeOwnerLayerValidate(t *testing.T) { }) } } + +func TestChangeOwnerLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedOutput bool + }{ + { + Name: "At Least One Device has Mount Point, User and Group Provided", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + MountPoint: "/mnt/foo", + User: "user-a", + Group: "group-a", + }, + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: true, + }, + { + Name: "Device has Mount Point and User Provided, but not Group", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + MountPoint: "/mnt/foo", + User: "user-a", + }, + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: true, + }, + { + Name: "Device has Mount Point and Group Provided, but not User", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + MountPoint: "/mnt/foo", + Group: "group-a", + }, + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: true, + }, + { + Name: "Device has Mount Point Provided, but not User and Group", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + MountPoint: "/mnt/foo", + }, + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: false, + }, + { + Name: "No Device has Mount Point Provided", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + col := NewChangeOwnerLayer(nil, nil) + output := col.ShouldProcess(subtest.Config) + utils.CheckOutput("col.ShouldProcess()", t, subtest.ExpectedOutput, output) + }) + } +} diff --git a/internal/layer/permissions_test.go b/internal/layer/permissions_test.go index 2363722..716efd2 100644 --- a/internal/layer/permissions_test.go +++ b/internal/layer/permissions_test.go @@ -218,3 +218,54 @@ func TestChangePermissionsLayerValidate(t *testing.T) { }) } } + +func TestChangePermissionsLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedOutput bool + }{ + { + Name: "At Least One Device Has a Mount Point and Permissions Declared", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + MountPoint: "/mnt/foo", + Permissions: model.FilePermissions(0755), + }, + "/dev/xvdf": { + MountPoint: "/mnt/bar", + }, + }, + }, + ExpectedOutput: true, + }, + { + Name: "No Device Has a Mount Point and Permissions Declared", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: false, + }, + { + Name: "Device Has a Mount Point Declared, but not Permissions", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + MountPoint: "/mnt/foo", + }, + }, + }, + ExpectedOutput: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + cpl := NewChangePermissionsLayer(nil) + output := cpl.ShouldProcess(subtest.Config) + utils.CheckOutput("cpl.ShouldProcess()", t, subtest.ExpectedOutput, output) + }) + } +} diff --git a/internal/layer/pv_resize_test.go b/internal/layer/pv_resize_test.go new file mode 100644 index 0000000..a496567 --- /dev/null +++ b/internal/layer/pv_resize_test.go @@ -0,0 +1,59 @@ +package layer + +import ( + "testing" + + "github.com/reecetech/ebs-bootstrap/internal/config" + "github.com/reecetech/ebs-bootstrap/internal/utils" +) + +func TestResizePhysicalVolumeLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedValue bool + }{ + { + Name: "At Least Once Device Has Lvm Specified and Resize Enabled", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Lvm: "lvm-id", + Options: config.Options{ + Resize: true, + }, + }, + "/dev/xvdf": {}, + }, + }, + ExpectedValue: true, + }, + { + Name: "Device Has Lvm Specified, but Resize Disabled", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Lvm: "lvm-id", + }, + }, + }, + ExpectedValue: false, + }, + { + Name: "No Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedValue: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + rpvl := NewResizePhysicalVolumeLayer(nil) + output := rpvl.ShouldProcess(subtest.Config) + utils.CheckOutput("rpvl.ShouldProcess()", t, subtest.ExpectedValue, output) + }) + } +} diff --git a/internal/layer/pv_test.go b/internal/layer/pv_test.go new file mode 100644 index 0000000..557acbd --- /dev/null +++ b/internal/layer/pv_test.go @@ -0,0 +1,45 @@ +package layer + +import ( + "testing" + + "github.com/reecetech/ebs-bootstrap/internal/config" + "github.com/reecetech/ebs-bootstrap/internal/utils" +) + +func TestCreatePhysicalVolumeLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedValue bool + }{ + { + Name: "At Least Once Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Lvm: "lvm-id", + }, + "/dev/xvdf": {}, + }, + }, + ExpectedValue: true, + }, + { + Name: "No Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedValue: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + cpvl := NewCreatePhysicalVolumeLayer(nil, nil) + output := cpvl.ShouldProcess(subtest.Config) + utils.CheckOutput("cpvl.ShouldProcess()", t, subtest.ExpectedValue, output) + }) + } +} diff --git a/internal/layer/resize_test.go b/internal/layer/resize_test.go index 752c702..eb19ada 100644 --- a/internal/layer/resize_test.go +++ b/internal/layer/resize_test.go @@ -288,3 +288,42 @@ func TestResizeDeviceLayerValidate(t *testing.T) { }) } } + +func TestResizeDeviceLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedOutput bool + }{ + { + Name: "At Least Once Device Has Resize Enabled", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Options: config.Options{ + Resize: true, + }, + }, + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: true, + }, + { + Name: "No Device Has Resize Enabled", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedOutput: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + rl := NewResizeDeviceLayer(nil, nil) + output := rl.ShouldProcess(subtest.Config) + utils.CheckOutput("rl.ShouldProcess()", t, subtest.ExpectedOutput, output) + }) + } +} diff --git a/internal/layer/vg_test.go b/internal/layer/vg_test.go new file mode 100644 index 0000000..28f108b --- /dev/null +++ b/internal/layer/vg_test.go @@ -0,0 +1,45 @@ +package layer + +import ( + "testing" + + "github.com/reecetech/ebs-bootstrap/internal/config" + "github.com/reecetech/ebs-bootstrap/internal/utils" +) + +func TestCreateVolumeGroupLayerShouldProcess(t *testing.T) { + subtests := []struct { + Name string + Config *config.Config + ExpectedValue bool + }{ + { + Name: "At Least Once Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdb": { + Lvm: "lvm-id", + }, + "/dev/xvdf": {}, + }, + }, + ExpectedValue: true, + }, + { + Name: "No Device Has Lvm Specified", + Config: &config.Config{ + Devices: map[string]config.Device{ + "/dev/xvdf": {}, + }, + }, + ExpectedValue: false, + }, + } + for _, subtest := range subtests { + t.Run(subtest.Name, func(t *testing.T) { + cvgl := NewCreateVolumeGroupLayer(nil) + output := cvgl.ShouldProcess(subtest.Config) + utils.CheckOutput("cvgl.ShouldProcess()", t, subtest.ExpectedValue, output) + }) + } +}