Fix step duration calculation (#616)
Этот коммит содержится в:
		
							родитель
							
								
									153db4eacb
								
							
						
					
					
						коммит
						da57dd0766
					
				
					 2 изменённых файлов: 29 добавлений и 31 удалений
				
			
		|  | @ -31,8 +31,20 @@ type PickleStepResult struct { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // NewStepResult ... | // NewStepResult ... | ||||||
| func NewStepResult(pickleID, pickleStepID string, match *StepDefinition) PickleStepResult { | func NewStepResult( | ||||||
| 	return PickleStepResult{FinishedAt: utils.TimeNowFunc(), PickleID: pickleID, PickleStepID: pickleStepID, Def: match} | 	status StepResultStatus, | ||||||
|  | 	pickleID, pickleStepID string, | ||||||
|  | 	match *StepDefinition, | ||||||
|  | 	err error, | ||||||
|  | ) PickleStepResult { | ||||||
|  | 	return PickleStepResult{ | ||||||
|  | 		Status:       status, | ||||||
|  | 		FinishedAt:   utils.TimeNowFunc(), | ||||||
|  | 		Err:          err, | ||||||
|  | 		PickleID:     pickleID, | ||||||
|  | 		PickleStepID: pickleStepID, | ||||||
|  | 		Def:          match, | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // StepResultStatus ... | // StepResultStatus ... | ||||||
|  |  | ||||||
							
								
								
									
										44
									
								
								suite.go
									
										
									
									
									
								
							
							
						
						
									
										44
									
								
								suite.go
									
										
									
									
									
								
							|  | @ -77,13 +77,10 @@ func (s *suite) matchStep(step *messages.PickleStep) *models.StepDefinition { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (s *suite) runStep(ctx context.Context, pickle *Scenario, step *Step, scenarioErr error, isFirst, isLast bool) (rctx context.Context, err error) { | func (s *suite) runStep(ctx context.Context, pickle *Scenario, step *Step, scenarioErr error, isFirst, isLast bool) (rctx context.Context, err error) { | ||||||
| 	var ( | 	var match *models.StepDefinition | ||||||
| 		match *models.StepDefinition |  | ||||||
| 		sr    = models.NewStepResult(pickle.Id, step.Id, match) |  | ||||||
| 	) |  | ||||||
| 
 | 
 | ||||||
| 	rctx = ctx | 	rctx = ctx | ||||||
| 	sr.Status = StepUndefined | 	status := StepUndefined | ||||||
| 
 | 
 | ||||||
| 	// user multistep definitions may panic | 	// user multistep definitions may panic | ||||||
| 	defer func() { | 	defer func() { | ||||||
|  | @ -105,19 +102,19 @@ func (s *suite) runStep(ctx context.Context, pickle *Scenario, step *Step, scena | ||||||
| 
 | 
 | ||||||
| 		switch { | 		switch { | ||||||
| 		case errors.Is(err, ErrPending): | 		case errors.Is(err, ErrPending): | ||||||
| 			sr.Status = StepPending | 			status = StepPending | ||||||
| 		case errors.Is(err, ErrSkip), err == nil && scenarioErr != nil: | 		case errors.Is(err, ErrSkip), err == nil && scenarioErr != nil: | ||||||
| 			sr.Status = StepSkipped | 			status = StepSkipped | ||||||
| 		case errors.Is(err, ErrUndefined): | 		case errors.Is(err, ErrUndefined): | ||||||
| 			sr.Status = StepUndefined | 			status = StepUndefined | ||||||
| 		case err != nil: | 		case err != nil: | ||||||
| 			sr.Status = StepFailed | 			status = StepFailed | ||||||
| 		case err == nil && scenarioErr == nil: | 		case err == nil && scenarioErr == nil: | ||||||
| 			sr.Status = StepPassed | 			status = StepPassed | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		// Run after step handlers. | 		// Run after step handlers. | ||||||
| 		rctx, err = s.runAfterStepHooks(ctx, step, sr.Status, err) | 		rctx, err = s.runAfterStepHooks(ctx, step, status, err) | ||||||
| 
 | 
 | ||||||
| 		shouldFail := s.shouldFail(err) | 		shouldFail := s.shouldFail(err) | ||||||
| 
 | 
 | ||||||
|  | @ -132,25 +129,20 @@ func (s *suite) runStep(ctx context.Context, pickle *Scenario, step *Step, scena | ||||||
| 
 | 
 | ||||||
| 		switch { | 		switch { | ||||||
| 		case err == nil: | 		case err == nil: | ||||||
| 			sr.Status = models.Passed | 			sr := models.NewStepResult(models.Passed, pickle.Id, step.Id, match, nil) | ||||||
| 			s.storage.MustInsertPickleStepResult(sr) | 			s.storage.MustInsertPickleStepResult(sr) | ||||||
| 
 |  | ||||||
| 			s.fmt.Passed(pickle, step, match.GetInternalStepDefinition()) | 			s.fmt.Passed(pickle, step, match.GetInternalStepDefinition()) | ||||||
| 		case errors.Is(err, ErrPending): | 		case errors.Is(err, ErrPending): | ||||||
| 			sr.Status = models.Pending | 			sr := models.NewStepResult(models.Pending, pickle.Id, step.Id, match, nil) | ||||||
| 			s.storage.MustInsertPickleStepResult(sr) | 			s.storage.MustInsertPickleStepResult(sr) | ||||||
| 
 |  | ||||||
| 			s.fmt.Pending(pickle, step, match.GetInternalStepDefinition()) | 			s.fmt.Pending(pickle, step, match.GetInternalStepDefinition()) | ||||||
| 		case errors.Is(err, ErrSkip): | 		case errors.Is(err, ErrSkip): | ||||||
| 			sr.Status = models.Skipped | 			sr := models.NewStepResult(models.Skipped, pickle.Id, step.Id, match, nil) | ||||||
| 			s.storage.MustInsertPickleStepResult(sr) | 			s.storage.MustInsertPickleStepResult(sr) | ||||||
| 
 |  | ||||||
| 			s.fmt.Skipped(pickle, step, match.GetInternalStepDefinition()) | 			s.fmt.Skipped(pickle, step, match.GetInternalStepDefinition()) | ||||||
| 		default: | 		default: | ||||||
| 			sr.Status = models.Failed | 			sr := models.NewStepResult(models.Failed, pickle.Id, step.Id, match, err) | ||||||
| 			sr.Err = err |  | ||||||
| 			s.storage.MustInsertPickleStepResult(sr) | 			s.storage.MustInsertPickleStepResult(sr) | ||||||
| 
 |  | ||||||
| 			s.fmt.Failed(pickle, step, match.GetInternalStepDefinition(), err) | 			s.fmt.Failed(pickle, step, match.GetInternalStepDefinition(), err) | ||||||
| 		} | 		} | ||||||
| 	}() | 	}() | ||||||
|  | @ -165,14 +157,11 @@ func (s *suite) runStep(ctx context.Context, pickle *Scenario, step *Step, scena | ||||||
| 
 | 
 | ||||||
| 	match = s.matchStep(step) | 	match = s.matchStep(step) | ||||||
| 	s.storage.MustInsertStepDefintionMatch(step.AstNodeIds[0], match) | 	s.storage.MustInsertStepDefintionMatch(step.AstNodeIds[0], match) | ||||||
| 	sr.Def = match |  | ||||||
| 	s.fmt.Defined(pickle, step, match.GetInternalStepDefinition()) | 	s.fmt.Defined(pickle, step, match.GetInternalStepDefinition()) | ||||||
| 
 | 
 | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		sr = models.NewStepResult(pickle.Id, step.Id, match) | 		sr := models.NewStepResult(models.Failed, pickle.Id, step.Id, match, nil) | ||||||
| 		sr.Status = models.Failed |  | ||||||
| 		s.storage.MustInsertPickleStepResult(sr) | 		s.storage.MustInsertPickleStepResult(sr) | ||||||
| 
 |  | ||||||
| 		return ctx, err | 		return ctx, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | @ -191,11 +180,9 @@ func (s *suite) runStep(ctx context.Context, pickle *Scenario, step *Step, scena | ||||||
| 				Nested:       match.Nested, | 				Nested:       match.Nested, | ||||||
| 				Undefined:    undef, | 				Undefined:    undef, | ||||||
| 			} | 			} | ||||||
| 			sr.Def = match |  | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		sr = models.NewStepResult(pickle.Id, step.Id, match) | 		sr := models.NewStepResult(models.Undefined, pickle.Id, step.Id, match, nil) | ||||||
| 		sr.Status = models.Undefined |  | ||||||
| 		s.storage.MustInsertPickleStepResult(sr) | 		s.storage.MustInsertPickleStepResult(sr) | ||||||
| 
 | 
 | ||||||
| 		s.fmt.Undefined(pickle, step, match.GetInternalStepDefinition()) | 		s.fmt.Undefined(pickle, step, match.GetInternalStepDefinition()) | ||||||
|  | @ -203,8 +190,7 @@ func (s *suite) runStep(ctx context.Context, pickle *Scenario, step *Step, scena | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if scenarioErr != nil { | 	if scenarioErr != nil { | ||||||
| 		sr = models.NewStepResult(pickle.Id, step.Id, match) | 		sr := models.NewStepResult(models.Skipped, pickle.Id, step.Id, match, nil) | ||||||
| 		sr.Status = models.Skipped |  | ||||||
| 		s.storage.MustInsertPickleStepResult(sr) | 		s.storage.MustInsertPickleStepResult(sr) | ||||||
| 
 | 
 | ||||||
| 		s.fmt.Skipped(pickle, step, match.GetInternalStepDefinition()) | 		s.fmt.Skipped(pickle, step, match.GetInternalStepDefinition()) | ||||||
|  |  | ||||||
		Загрузка…
	
	Создание таблицы
		
		Сослаться в новой задаче
	
	 Iaroslav Ciupin
						Iaroslav Ciupin