Skip to content

Commit

Permalink
pool_test: Change checkMacPoolMapEntries to check for deleted MACs
Browse files Browse the repository at this point in the history
Currently not all unit tests check macpool size after doing changes in
the macpool map (allocate, update or delete MACs entries)
Moving the check inside checkMacPoolMapEntries so that all tests check
this, removing the now redundant checks.
Also refactoring use of "errors.New(fmt.Sprintf(...))" into
"fmt.Errorf(...)"

Signed-off-by: Ram Lavi <[email protected]>
  • Loading branch information
RamLavi committed Dec 30, 2024
1 parent e070eaf commit 8a641a4
Showing 1 changed file with 7 additions and 10 deletions.
17 changes: 7 additions & 10 deletions pkg/pool-manager/pool_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ import (
. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"

"github.com/pkg/errors"
multus "gopkg.in/k8snetworkplumbingwg/multus-cni.v3/pkg/types"
admissionregistrationv1 "k8s.io/api/admissionregistration/v1"
v1 "k8s.io/api/core/v1"
Expand Down Expand Up @@ -293,7 +292,6 @@ var _ = Describe("Pool", func() {
err := poolManager.AllocateVirtualMachineMac(&newVM, &transactionTimestamp, true, logger)
Expect(err).ToNot(HaveOccurred())

Expect(poolManager.macPoolMap).To(HaveLen(2))
Expect(checkMacPoolMapEntries(poolManager.macPoolMap, &transactionTimestamp, []string{"02:00:00:00:00:01"}, []string{managedNamespaceMAC})).To(Succeed(), "Failed to check macs in macMap")
Expect(newVM.Spec.Template.Spec.Domain.Devices.Interfaces[0].MacAddress).To(Equal("02:00:00:00:00:01"))

Expand All @@ -310,15 +308,13 @@ var _ = Describe("Pool", func() {
err := poolManager.AllocateVirtualMachineMac(newVM, &transactionTimestamp, true, logger)
Expect(err).ToNot(HaveOccurred())

Expect(poolManager.macPoolMap).To(HaveLen(3))
Expect(checkMacPoolMapEntries(poolManager.macPoolMap, &transactionTimestamp, []string{"02:00:00:00:00:01", "02:00:00:00:00:02"}, []string{managedNamespaceMAC})).To(Succeed(), "Failed to check macs in macMap")

Expect(newVM.Spec.Template.Spec.Domain.Devices.Interfaces[0].MacAddress).To(Equal("02:00:00:00:00:01"))
Expect(newVM.Spec.Template.Spec.Domain.Devices.Interfaces[1].MacAddress).To(Equal("02:00:00:00:00:02"))

err = poolManager.ReleaseAllVirtualMachineMacs(VmNamespaced(newVM), logf.Log.WithName("VirtualMachine Controller"))
Expect(err).ToNot(HaveOccurred())
Expect(poolManager.macPoolMap).To(HaveLen(1), "Should keep the pod mac in the macMap")
Expect(checkMacPoolMapEntries(poolManager.macPoolMap, &transactionTimestamp, []string{}, []string{managedNamespaceMAC})).To(Succeed(), "Failed to check macs in macMap")
})
})
Expand Down Expand Up @@ -727,7 +723,6 @@ var _ = Describe("Pool", func() {
Expect(err).ToNot(HaveOccurred())
preAllocatedPodMac := managedNamespaceMAC
expectedAllocatedMac := "02:00:00:00:00:01"
Expect(poolManager.macPoolMap).To(HaveLen(2))
Expect(checkMacPoolMapEntries(poolManager.macPoolMap, nil, []string{preAllocatedPodMac, expectedAllocatedMac}, []string{})).To(Succeed(), "Failed to check macs in macMap")

Expect(newPod.Annotations[networkv1.NetworkAttachmentAnnot]).To(Equal(afterAllocationAnnotation(managedNamespaceName, "02:00:00:00:00:01")[networkv1.NetworkAttachmentAnnot]))
Expand All @@ -740,7 +735,6 @@ var _ = Describe("Pool", func() {

err = poolManager.ReleaseAllPodMacs(podNamespaced(&newPod))
Expect(err).ToNot(HaveOccurred())
Expect(poolManager.macPoolMap).To(HaveLen(1))
Expect(checkMacPoolMapEntries(poolManager.macPoolMap, nil, []string{preAllocatedPodMac}, []string{})).To(Succeed(), "Failed to check macs in macMap")
_, exist := poolManager.macPoolMap[NewMacKey(expectedAllocatedMac)]
Expect(exist).To(BeFalse())
Expand Down Expand Up @@ -1119,22 +1113,25 @@ func createPoolManager(startMacAddr, endMacAddr string, fakeObjectsForClient ...
}

func checkMacPoolMapEntries(macPoolMap map[macKey]macEntry, updatedTransactionTimestamp *time.Time, updatedMacs, notUpdatedMacs []string) error {
if len(macPoolMap) != len(updatedMacs)+len(notUpdatedMacs) {
return fmt.Errorf("mac pool size %d is not as expected %d, should only contain MACs %v, macPoolMap %+v", len(macPoolMap), len(updatedMacs)+len(notUpdatedMacs), append(updatedMacs, notUpdatedMacs...), macPoolMap)
}
for _, macAddress := range updatedMacs {
macEntry, exist := macPoolMap[NewMacKey(macAddress)]
if !exist {
return errors.New(fmt.Sprintf("mac %s should exist in macPoolMap %v", macAddress, macPoolMap))
return fmt.Errorf("mac %s should exist in macPoolMap %v", macAddress, macPoolMap)
}
if macEntry.transactionTimestamp != updatedTransactionTimestamp {
return errors.New(fmt.Sprintf("mac %s has transactionTimestamp %s, should have an updated transactionTimestamp %s", macAddress, macEntry.transactionTimestamp, updatedTransactionTimestamp))
return fmt.Errorf("mac %s has transactionTimestamp %s, should have an updated transactionTimestamp %s", macAddress, macEntry.transactionTimestamp, updatedTransactionTimestamp)
}
}
for _, macAddress := range notUpdatedMacs {
macEntry, exist := macPoolMap[NewMacKey(macAddress)]
if !exist {
return errors.New(fmt.Sprintf("mac %s should exist in macPoolMap %v", macAddress, macPoolMap))
return fmt.Errorf("mac %s should exist in macPoolMap %v", macAddress, macPoolMap)
}
if macEntry.transactionTimestamp == updatedTransactionTimestamp {
return errors.New(fmt.Sprintf("mac %s has transactionTimestamp %s, should not have an updated transactionTimestamp %s", macAddress, macEntry.transactionTimestamp, updatedTransactionTimestamp))
return fmt.Errorf("mac %s has transactionTimestamp %s, should not have an updated transactionTimestamp %s", macAddress, macEntry.transactionTimestamp, updatedTransactionTimestamp)
}
}
return nil
Expand Down

0 comments on commit 8a641a4

Please sign in to comment.