// ReportStageResult throw the results of specified stage to the messenger services. func (resources *Resources) ReportStageResult(stage stages.Stage, resultStr string) { if stage.GetSuppressAll() { return } name := stage.GetStageName() if !resources.Reporter.Suppress("result") { if resultStr == "true" { resources.Reporter.Post( fmt.Sprintf("[%s][RESULT] Succeeded", name)) } else if resultStr == "skipped" { resources.Reporter.Post( fmt.Sprintf("[%s][RESULT] Skipped", name)) } else { resources.Reporter.Post( fmt.Sprintf("[%s][RESULT] Failed", name)) } } if stage.GetStageOpts().ReportingFullOutput { if out := stage.GetOutResult(); (len(out) > 0) && (!resources.Reporter.Suppress("stdout")) { resources.Reporter.Post( fmt.Sprintf("[%s][STDOUT] %s", name, stage.GetOutResult())) } if err := stage.GetErrResult(); len(err) > 0 && (!resources.Reporter.Suppress("stderr")) { resources.Reporter.Post( fmt.Sprintf("[%s][STDERR] %s", name, stage.GetErrResult())) } } }
func (e *Engine) executeStage(stage stages.Stage, received []stages.Mediator, mediator stages.Mediator) string { var result string if !e.isUpstreamAnyFailure(received) || e.Opts.StopOnAnyFailure { result = strconv.FormatBool(stage.(stages.Runner).Run()) e.EnvVariables.ExportSpecialVariable("__OUT[\""+stage.GetStageName()+"\"]", stage.GetOutResult()) e.EnvVariables.ExportSpecialVariable("__ERR[\""+stage.GetStageName()+"\"]", stage.GetErrResult()) e.EnvVariables.ExportSpecialVariable("__COMBINED[\""+stage.GetStageName()+"\"]", stage.GetCombinedResult()) e.EnvVariables.ExportSpecialVariable("__RESULT[\""+stage.GetStageName()+"\"]", result) e.executeChildStages(&stage, &mediator) } else { log.Warnf("Execution is skipped: %v", stage.GetStageName()) if childStages := stage.GetChildStages(); childStages.Len() > 0 { for childStage := childStages.Front(); childStage != nil; childStage = childStage.Next() { log.Warnf("Execution of child stage is skipped: %v", childStage.Value.(stages.Stage).GetStageName()) } } result = "skipped" } if !stage.GetSuppressAll() { e.Resources.ReportStageResult(stage, result) } log.Debugf("Stage execution results: %+v, %+v", stage.GetStageName(), result) return result }