Skip to content

Commit

Permalink
[YUNIKORN-2765] Improve si_helper & resource funtion's test coverage (#…
Browse files Browse the repository at this point in the history
…881)

Closes: #881

Signed-off-by: Peter Bacsko <[email protected]>
  • Loading branch information
SP12893678 authored and pbacsko committed Jul 25, 2024
1 parent 4c78765 commit 498b8ea
Show file tree
Hide file tree
Showing 2 changed files with 157 additions and 0 deletions.
141 changes: 141 additions & 0 deletions pkg/common/resource_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -510,6 +510,31 @@ func TestGetPodResourcesWithInPlacePodVerticalScaling(t *testing.T) {
assert.Equal(t, res.Resources[siCommon.CPU].GetValue(), int64(4000))
assert.Equal(t, res.Resources["nvidia.com/gpu"].GetValue(), int64(5))
assert.Equal(t, res.Resources["pods"].GetValue(), int64(1))

// case: requested resource types are fewer than allocated types
containers = make([]v1.Container, 0)
c1Resources = make(map[v1.ResourceName]resource.Quantity)
containers = append(containers, v1.Container{
Name: "container-01",
Resources: v1.ResourceRequirements{
Requests: c1Resources,
},
})
pod.Spec.Containers = containers

c1Allocated[v1.ResourceMemory] = resource.MustParse("500M")
c1Allocated[v1.ResourceCPU] = resource.MustParse("2")
pod.Status.ContainerStatuses = []v1.ContainerStatus{
{AllocatedResources: c1Allocated},
{AllocatedResources: c2Allocated},
}
pod.Status.Resize = v1.PodResizeStatusProposed

res = GetPodResource(pod)
assert.Equal(t, res.Resources[siCommon.Memory].GetValue(), int64(500*1000*1000))
assert.Equal(t, res.Resources[siCommon.CPU].GetValue(), int64(2000))
assert.Equal(t, res.Resources["nvidia.com/gpu"].GetValue(), int64(1))
assert.Equal(t, res.Resources["pods"].GetValue(), int64(1))
}

func TestBestEffortPod(t *testing.T) {
Expand Down Expand Up @@ -741,3 +766,119 @@ func TestParseResourceString(t *testing.T) {
})
}
}

func TestGetResource(t *testing.T) {
tests := []struct {
name string
resMap map[string]string
expectedRes map[string]int64
}{
{
name: "empty resMap",
resMap: map[string]string{},
expectedRes: map[string]int64{},
},
{
name: "single resource",
resMap: map[string]string{
v1.ResourceCPU.String(): "100m",
},
expectedRes: map[string]int64{
siCommon.CPU: 100,
},
},
{
name: "multiple resources",
resMap: map[string]string{
v1.ResourceCPU.String(): "1",
v1.ResourceMemory.String(): "1G",
},
expectedRes: map[string]int64{
siCommon.CPU: 1000,
siCommon.Memory: 1000 * 1000 * 1000,
},
},
{
name: "invalid cpu resources",
resMap: map[string]string{
v1.ResourceCPU.String(): "xyz",
},
expectedRes: nil,
},
{
name: "invalid memory resources",
resMap: map[string]string{
v1.ResourceMemory.String(): "64MiB",
},
expectedRes: nil,
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
actualRes := GetResource(tt.resMap)
if tt.expectedRes == nil {
assert.Assert(t, actualRes == nil)
} else {
assert.Equal(t, len(actualRes.Resources), len(tt.expectedRes))
if len(tt.expectedRes) > 0 {
for name, value := range tt.expectedRes {
assert.Equal(t, actualRes.Resources[name].GetValue(), value)
}
}
}
})
}
}

func TestGetTGResource(t *testing.T) {
tests := []struct {
name string
resMap map[string]resource.Quantity
members int64
expectedRes map[string]int64
}{
{
name: "empty resMap",
resMap: map[string]resource.Quantity{},
members: 2,
expectedRes: map[string]int64{
"pods": 2,
},
},
{
name: "single resource",
resMap: map[string]resource.Quantity{
v1.ResourceCPU.String(): resource.MustParse("100m"),
},
members: 2,
expectedRes: map[string]int64{
"pods": 2,
siCommon.CPU: 2 * 100,
},
},
{
name: "multiple resources",
resMap: map[string]resource.Quantity{
v1.ResourceCPU.String(): resource.MustParse("1"),
v1.ResourceMemory.String(): resource.MustParse("1G"),
},
members: 2,
expectedRes: map[string]int64{
"pods": 2,
siCommon.CPU: 2 * 1000,
siCommon.Memory: 2 * 1000 * 1000 * 1000,
},
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
actualRes := GetTGResource(tt.resMap, tt.members)
assert.Equal(t, len(actualRes.Resources), len(tt.expectedRes))
for name, value := range tt.expectedRes {
assert.Equal(t, actualRes.Resources[name].GetValue(), value)
}
})
}
}
16 changes: 16 additions & 0 deletions pkg/common/si_helper_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ func TestCreateReleaseRequestForTask(t *testing.T) {
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].ApplicationID, "app01")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].AllocationKey, "task01")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].PartitionName, "default")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].TerminationType, si.TerminationType_UNKNOWN_TERMINATION_TYPE)

// without allocationKey
request = CreateReleaseRequestForTask("app01", "task01", "", "default", "STOPPED_BY_RM")
Expand All @@ -56,6 +57,21 @@ func TestCreateReleaseRequestForTask(t *testing.T) {
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].ApplicationID, "app01")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].AllocationKey, "task01")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].PartitionName, "default")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].TerminationType, si.TerminationType_UNKNOWN_TERMINATION_TYPE)

request = CreateReleaseRequestForTask("app01", "task01", "task01", "default", "UNKNOWN")
assert.Assert(t, request.Releases != nil)
assert.Assert(t, request.Releases.AllocationsToRelease != nil)
assert.Assert(t, request.Releases.AllocationAsksToRelease != nil)
assert.Equal(t, len(request.Releases.AllocationsToRelease), 1)
assert.Equal(t, len(request.Releases.AllocationAsksToRelease), 1)
assert.Equal(t, request.Releases.AllocationsToRelease[0].ApplicationID, "app01")
assert.Equal(t, request.Releases.AllocationsToRelease[0].AllocationKey, "task01")
assert.Equal(t, request.Releases.AllocationsToRelease[0].PartitionName, "default")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].ApplicationID, "app01")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].AllocationKey, "task01")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].PartitionName, "default")
assert.Equal(t, request.Releases.AllocationAsksToRelease[0].TerminationType, si.TerminationType_UNKNOWN_TERMINATION_TYPE)
}

func TestCreateUpdateRequestForRemoveApplication(t *testing.T) {
Expand Down

0 comments on commit 498b8ea

Please sign in to comment.