1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
package outputs
import (
"fmt"
"io"
"time"
"github.com/goss-org/goss/resource"
"github.com/goss-org/goss/util"
)
type Documentation struct{}
func (r Documentation) ValidOptions() []*formatOption {
return []*formatOption{
{name: foSort},
}
}
func (r Documentation) Output(w io.Writer, results <-chan []resource.TestResult,
outConfig util.OutputConfig) (exitCode int) {
includeRaw := !util.IsValueInList(foExcludeRaw, outConfig.FormatOptions)
sort := util.IsValueInList(foSort, outConfig.FormatOptions)
results = getResults(results, sort)
var startTime time.Time
var endTime time.Time
testCount := 0
var failedOrSkipped [][]resource.TestResult
var skipped, failed int
for resultGroup := range results {
failedOrSkippedGroup := []resource.TestResult{}
first := resultGroup[0]
header := header(first)
if header != "" {
fmt.Fprint(w, header)
}
for _, testResult := range resultGroup {
if startTime.IsZero() || testResult.StartTime.Before(startTime) {
startTime = testResult.StartTime
}
if endTime.IsZero() || testResult.EndTime.After(endTime) {
endTime = testResult.EndTime
}
switch testResult.Result {
case resource.SUCCESS:
fmt.Fprintln(w, humanizeResult(testResult, false, includeRaw))
case resource.SKIP:
fmt.Fprintln(w, humanizeResult(testResult, false, includeRaw))
failedOrSkippedGroup = append(failedOrSkippedGroup, testResult)
skipped++
case resource.FAIL:
fmt.Fprintln(w, humanizeResult(testResult, false, includeRaw))
failedOrSkippedGroup = append(failedOrSkippedGroup, testResult)
failed++
}
testCount++
}
if len(failedOrSkippedGroup) > 0 {
failedOrSkipped = append(failedOrSkipped, failedOrSkippedGroup)
}
}
fmt.Fprint(w, "\n\n")
fmt.Fprint(w, failedOrSkippedSummary(failedOrSkipped, includeRaw))
fmt.Fprint(w, summary(startTime, endTime, testCount, failed, skipped))
if failed > 0 {
return 1
}
return 0
}
|