Skip to content

Commit

Permalink
Remove check for Throughput
Browse files Browse the repository at this point in the history
Signed-off-by: Indresh-Prakash <indreshprakash24@gmail.com>
  • Loading branch information
Indresh2410 committed Jul 2, 2023
1 parent 2bac0f8 commit 288c467
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 1 deletion.
2 changes: 1 addition & 1 deletion pkg/cloud/cloud.go
Original file line number Diff line number Diff line change
Expand Up @@ -479,7 +479,7 @@ func (c *cloud) ModifyDisk(ctx context.Context, volumeID string, options *Modify
if options.VolumeType != "" {
req.VolumeType = aws.String(options.VolumeType)
}
if options.VolumeType == VolumeTypeGP3 {
if options.Throughput != 0 {
req.Throughput = aws.Int64(int64(options.Throughput))
}

Expand Down
58 changes: 58 additions & 0 deletions pkg/cloud/cloud_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -710,6 +710,64 @@ func TestDeleteDisk(t *testing.T) {
}
}

func TestModifyDisk(t *testing.T) {
testCases := []struct {
name string
volumeID string
modifyDiskOptions *ModifyDiskOptions
modifiedVolume *ec2.ModifyVolumeOutput
modifiedVolumeError awserr.Error
}{
{
name: "success: IOPS with GP3",
volumeID: "vol-test-1234",
modifyDiskOptions: &ModifyDiskOptions{
VolumeType: "GP3",
IOPS: 3000,
},
modifiedVolume: &ec2.ModifyVolumeOutput{
VolumeModification: &ec2.VolumeModification{
VolumeId: aws.String("vol-test"),
TargetIops: aws.Int64(3000),
ModificationState: aws.String(ec2.VolumeModificationStateCompleted),
},
},
},
{
name: "fail: ModifyVolume returned generic error",
volumeID: "vol-test-1234",
modifiedVolumeError: awserr.New("InvalidParameterCombination", "The parameter iops is not supported for gp2 volumes", nil),
modifyDiskOptions: &ModifyDiskOptions{
VolumeType: "GP2",
IOPS: 3000,
},
},
}

for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
mockCtrl := gomock.NewController(t)
mockEC2 := NewMockEC2API(mockCtrl)
c := newCloud(mockEC2)
ctx := context.Background()
if tc.modifiedVolumeError != nil {
mockEC2.EXPECT().ModifyVolumeWithContext(gomock.Any(), gomock.Any()).Return(nil, tc.modifiedVolumeError).AnyTimes()
} else {
mockEC2.EXPECT().ModifyVolumeWithContext(gomock.Any(), gomock.Any()).Return(tc.modifiedVolume, nil).AnyTimes()
}
err := c.ModifyDisk(ctx, tc.volumeID, tc.modifyDiskOptions)
if err != nil && tc.modifiedVolumeError == nil {
t.Fatalf("ModifyDisk() failed: expected no error, got: %v", err)
}

if err == nil && tc.modifiedVolumeError != nil {
t.Fatal("ModifyDisk() failed: expected error, got nothing")
}
mockCtrl.Finish()
})
}
}

func TestAttachDisk(t *testing.T) {
testCases := []struct {
name string
Expand Down

0 comments on commit 288c467

Please sign in to comment.