Skip to content

Commit

Permalink
test: fix race between action status and metrics in controller test (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
hairyhum authored Feb 12, 2024
1 parent 051dcc5 commit 58469ff
Showing 1 changed file with 19 additions and 1 deletion.
20 changes: 19 additions & 1 deletion pkg/controller/controller_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -668,7 +668,9 @@ func (s *ControllerSuite) TestExecActionSet(c *C) {
if !cancel {
err = s.waitOnActionSetState(c, as, final)
c.Assert(err, IsNil, Commentf("Failed case: %s", tc.name))
c.Assert(getCounterVecValue(s.ctrl.metrics.actionSetResolutionCounterVec, []string{tc.metricResolution}), Equals, oldValue+1, Commentf("Failed case: %s", tc.name))
expectedValue := oldValue + 1
err = waitForMetrics(s.ctrl.metrics.actionSetResolutionCounterVec, []string{tc.metricResolution}, expectedValue, time.Second)
c.Assert(err, IsNil, Commentf("Failed case: %s, failed waiting for metric update to %v", tc.name, expectedValue))
}
err = s.crCli.Blueprints(s.namespace).Delete(context.TODO(), bp.GetName(), metav1.DeleteOptions{})
c.Assert(err, IsNil)
Expand All @@ -682,6 +684,22 @@ func (s *ControllerSuite) TestExecActionSet(c *C) {
}
}

func waitForMetrics(metrics prometheus.CounterVec, labels []string, expected float64, timeout time.Duration) error {
ctx, cancel := context.WithTimeout(context.Background(), timeout)
defer cancel()

err := poll.Wait(ctx, func(context.Context) (bool, error) {
current := getCounterVecValue(metrics, labels)
if current == expected {
return true, nil
} else {
return false, nil
}
})

return err
}

func (s *ControllerSuite) TestRuntimeObjEventLogs(c *C) {
c.Skip("This may not work in MiniKube")
ctx := context.Background()
Expand Down

0 comments on commit 58469ff

Please sign in to comment.