From 0ef71126721a7cba6f8898d7b04f1dba46285d8d Mon Sep 17 00:00:00 2001 From: Rahul Ganesh Date: Fri, 7 Jun 2024 17:04:45 -0700 Subject: [PATCH 1/2] shuffle hardware inventory for tinkerbell before reservation Signed-off-by: Rahul Ganesh --- internal/test/e2e/run.go | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/internal/test/e2e/run.go b/internal/test/e2e/run.go index e5b97abaa5b9..b1ade83bd504 100644 --- a/internal/test/e2e/run.go +++ b/internal/test/e2e/run.go @@ -2,6 +2,7 @@ package e2e import ( "fmt" + "math/rand" "os" "regexp" "sort" @@ -217,6 +218,9 @@ func RunTests(conf instanceRunConf, inventoryCatalogue map[string]*hardwareCatal } else { hardwareCatalogue = inventoryCatalogue[nonAirgappedHardware] } + conf.Logger.Info("Shuffling hardware inventory for tinkerbell") + // shuffle hardware to introduce randomness during hardware reservation. + shuffleHardwareInventory(hardwareCatalogue) err = reserveTinkerbellHardware(&conf, hardwareCatalogue) if err != nil { return "", nil, err @@ -592,3 +596,10 @@ func logTinkerbellTestHardwareInfo(conf *instanceRunConf, action string) { } conf.Logger.V(1).Info(action+" hardware for TestRunner", "hardwarePool", strings.Join(hardwareInfo, ", ")) } + +func shuffleHardwareInventory(invCatalogue *hardwareCatalogue) { + random := rand.New(rand.NewSource(time.Now().UnixNano())) + random.Shuffle(len(invCatalogue.hws), func(i, j int) { + invCatalogue.hws[i], invCatalogue.hws[j] = invCatalogue.hws[j], invCatalogue.hws[i] + }) +} From 85a4cae904d810d0e18ce78f7f6bb3627d1d9969 Mon Sep 17 00:00:00 2001 From: Rahul Ganesh Date: Mon, 8 Jul 2024 15:23:03 -0700 Subject: [PATCH 2/2] Account for mutexes during shuffle and move it to struct method Signed-off-by: Rahul Ganesh --- internal/test/e2e/run.go | 14 +++++--------- internal/test/e2e/tinkerbell_hardware_queue.go | 10 ++++++++++ 2 files changed, 15 insertions(+), 9 deletions(-) diff --git a/internal/test/e2e/run.go b/internal/test/e2e/run.go index b1ade83bd504..8faab2b6ab3b 100644 --- a/internal/test/e2e/run.go +++ b/internal/test/e2e/run.go @@ -2,7 +2,6 @@ package e2e import ( "fmt" - "math/rand" "os" "regexp" "sort" @@ -220,7 +219,11 @@ func RunTests(conf instanceRunConf, inventoryCatalogue map[string]*hardwareCatal } conf.Logger.Info("Shuffling hardware inventory for tinkerbell") // shuffle hardware to introduce randomness during hardware reservation. - shuffleHardwareInventory(hardwareCatalogue) + // we do not want quick e2e runs to always pick the first few available hardware from the list and over-populate the boot entries + // this will quickly break the booting process as the hardware runs out of boot space to store these entries. + // randomly picking the hardware will distribute the boot entries across these hardware during each run + // ideally for long term we want a clear cleanup of the boot entries in the hardware + hardwareCatalogue.shuffleHardware() err = reserveTinkerbellHardware(&conf, hardwareCatalogue) if err != nil { return "", nil, err @@ -596,10 +599,3 @@ func logTinkerbellTestHardwareInfo(conf *instanceRunConf, action string) { } conf.Logger.V(1).Info(action+" hardware for TestRunner", "hardwarePool", strings.Join(hardwareInfo, ", ")) } - -func shuffleHardwareInventory(invCatalogue *hardwareCatalogue) { - random := rand.New(rand.NewSource(time.Now().UnixNano())) - random.Shuffle(len(invCatalogue.hws), func(i, j int) { - invCatalogue.hws[i], invCatalogue.hws[j] = invCatalogue.hws[j], invCatalogue.hws[i] - }) -} diff --git a/internal/test/e2e/tinkerbell_hardware_queue.go b/internal/test/e2e/tinkerbell_hardware_queue.go index 62dc3d7085cf..2c1c1c9ad558 100644 --- a/internal/test/e2e/tinkerbell_hardware_queue.go +++ b/internal/test/e2e/tinkerbell_hardware_queue.go @@ -2,6 +2,7 @@ package e2e import ( "fmt" + "math/rand" "sync" "time" @@ -42,6 +43,15 @@ func (hwQu *hardwareCatalogue) releaseHardware(hws []*api.Hardware) { hwQu.mu.Unlock() } +func (hwQu *hardwareCatalogue) shuffleHardware() { + hwQu.mu.Lock() + random := rand.New(rand.NewSource(time.Now().UnixNano())) + random.Shuffle(len(hwQu.hws), func(i, j int) { + hwQu.hws[i], hwQu.hws[j] = hwQu.hws[j], hwQu.hws[i] + }) + hwQu.mu.Unlock() +} + func newHardwareCatalogue(hws []*api.Hardware) *hardwareCatalogue { return &hardwareCatalogue{ hws: hws,