mirror of
https://github.com/kubevela/kubevela.git
synced 2026-03-02 09:40:51 +00:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
192dc8966d |
@@ -403,14 +403,14 @@ func (w *workflow) setMetadataToContext(wfCtx wfContext.Context) error {
|
||||
return wfCtx.SetVar(metadata, wfTypes.ContextKeyMetadata)
|
||||
}
|
||||
|
||||
func (e *engine) getBackoffTimes(stepID string) (success bool, backoffTimes int) {
|
||||
func (e *engine) getBackoffTimes(stepID string) int {
|
||||
if v, ok := e.wfCtx.GetValueInMemory(wfTypes.ContextPrefixBackoffTimes, stepID); ok {
|
||||
times, ok := v.(int)
|
||||
if ok {
|
||||
return true, times
|
||||
return times
|
||||
}
|
||||
}
|
||||
return false, 0
|
||||
return -1
|
||||
}
|
||||
|
||||
func (e *engine) getBackoffWaitTime() int {
|
||||
@@ -418,17 +418,19 @@ func (e *engine) getBackoffWaitTime() int {
|
||||
minTimes := 15
|
||||
found := false
|
||||
for _, step := range e.status.Steps {
|
||||
success, backoffTimes := e.getBackoffTimes(step.ID)
|
||||
if success && backoffTimes < minTimes {
|
||||
minTimes = backoffTimes
|
||||
if backoffTimes := e.getBackoffTimes(step.ID); backoffTimes > 0 {
|
||||
found = true
|
||||
if backoffTimes < minTimes {
|
||||
minTimes = backoffTimes
|
||||
}
|
||||
}
|
||||
if step.SubStepsStatus != nil {
|
||||
for _, subStep := range step.SubStepsStatus {
|
||||
success, backoffTimes := e.getBackoffTimes(subStep.ID)
|
||||
if success && backoffTimes < minTimes {
|
||||
minTimes = backoffTimes
|
||||
if backoffTimes := e.getBackoffTimes(subStep.ID); backoffTimes > 0 {
|
||||
found = true
|
||||
if backoffTimes < minTimes {
|
||||
minTimes = backoffTimes
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -912,10 +912,12 @@ var _ = Describe("Test Workflow", func() {
|
||||
Expect(interval).Should(BeEquivalentTo(int(0.05 * math.Pow(2, float64(i+5)))))
|
||||
}
|
||||
|
||||
_, err = wf.ExecuteSteps(ctx, revision, runners)
|
||||
Expect(err).ToNot(HaveOccurred())
|
||||
interval = e.getBackoffWaitTime()
|
||||
Expect(interval).Should(BeEquivalentTo(MaxWorkflowWaitBackoffTime))
|
||||
for i := 0; i < 10; i++ {
|
||||
_, err = wf.ExecuteSteps(ctx, revision, runners)
|
||||
Expect(err).ToNot(HaveOccurred())
|
||||
interval = e.getBackoffWaitTime()
|
||||
Expect(interval).Should(BeEquivalentTo(MaxWorkflowWaitBackoffTime))
|
||||
}
|
||||
|
||||
By("Test get backoff time after clean")
|
||||
wfContext.CleanupMemoryStore(app.Name, app.Namespace)
|
||||
|
||||
Reference in New Issue
Block a user