package hst import ( "fmt" . "github.com/onsi/ginkgo/v2" "reflect" "runtime" "strings" ) var cpuPinningTests = map[string][]func(s *CpuPinningSuite){} var cpuPinningSoloTests = map[string][]func(s *CpuPinningSuite){} type CpuPinningSuite struct { HstSuite previousMaxContainerCount int } func RegisterCpuPinningTests(tests ...func(s *CpuPinningSuite)) { cpuPinningTests[getTestFilename()] = tests } func RegisterCpuPinningSoloTests(tests ...func(s *CpuPinningSuite)) { cpuPinningSoloTests[getTestFilename()] = tests } func (s *CpuPinningSuite) SetupSuite() { s.HstSuite.SetupSuite() s.LoadNetworkTopology("tap") s.LoadContainerTopology("singleCpuPinning") } func (s *CpuPinningSuite) SetupTest() { // Skip if we cannot allocate 3 CPUs for test container s.previousMaxContainerCount = s.CpuAllocator.maxContainerCount s.CpuCount = 3 s.CpuAllocator.maxContainerCount = 1 s.SkipIfNotEnoughAvailableCpus() s.HstSuite.SetupTest() container := s.GetContainerByName(SingleTopoContainerVpp) vpp, err := container.newVppInstance(container.AllocatedCpus) s.AssertNotNil(vpp, fmt.Sprint(err)) } func (s *CpuPinningSuite) TearDownTest() { // reset vars s.CpuCount = *NConfiguredCpus s.CpuAllocator.maxContainerCount = s.previousMaxContainerCount s.HstSuite.TearDownTest() } var _ = Describe("CpuPinningSuite", Ordered, ContinueOnFailure, func() { var s CpuPinningSuite BeforeAll(func() { s.SetupSuite() }) BeforeEach(func() { s.SetupTest() }) AfterAll(func() { s.TearDownSuite() }) AfterEach(func() { s.TearDownTest() }) // https://onsi.github.io/ginkgo/#dynamically-generating-specs for filename, tests := range cpuPinningTests { for _, test := range tests { test := test pc := reflect.ValueOf(test).Pointer() funcValue := runtime.FuncForPC(pc) testName := filename + "/" + strings.Split(funcValue.Name(), ".")[2] It(testName, func(ctx SpecContext) { s.Log(testName + ": BEGIN") test(&s) }, SpecTimeout(SuiteTimeout)) } } }) var _ = Describe("CpuPinningSuiteSolo", Ordered, ContinueOnFailure, Serial, func() { var s CpuPinningSuite BeforeAll(func() { s.SetupSuite() }) BeforeEach(func() { s.SetupTest() }) AfterAll(func() { s.TearDownSuite() }) AfterEach(func() { s.TearDownTest() }) for filename, tests := range cpuPinningSoloTests { for _, test := range tests { test := test pc := reflect.ValueOf(test).Pointer() funcValue := runtime.FuncForPC(pc) testName := filename + "/" + strings.Split(funcValue.Name(), ".")[2] It(testName, Label("SOLO"), func(ctx SpecContext) { s.Log(testName + ": BEGIN") test(&s) }, SpecTimeout(SuiteTimeout)) } } })