mirror of
https://github.com/Luzifer/duplicity-backup.git
synced 2024-12-21 11:01:20 +00:00
171 lines
6.2 KiB
Go
171 lines
6.2 KiB
Go
|
/*
|
||
|
Ginkgo accepts a number of configuration options.
|
||
|
|
||
|
These are documented [here](http://onsi.github.io/ginkgo/#the_ginkgo_cli)
|
||
|
|
||
|
You can also learn more via
|
||
|
|
||
|
ginkgo help
|
||
|
|
||
|
or (I kid you not):
|
||
|
|
||
|
go test -asdf
|
||
|
*/
|
||
|
package config
|
||
|
|
||
|
import (
|
||
|
"flag"
|
||
|
"time"
|
||
|
|
||
|
"fmt"
|
||
|
)
|
||
|
|
||
|
const VERSION = "1.2.0"
|
||
|
|
||
|
type GinkgoConfigType struct {
|
||
|
RandomSeed int64
|
||
|
RandomizeAllSpecs bool
|
||
|
FocusString string
|
||
|
SkipString string
|
||
|
SkipMeasurements bool
|
||
|
FailOnPending bool
|
||
|
FailFast bool
|
||
|
EmitSpecProgress bool
|
||
|
DryRun bool
|
||
|
|
||
|
ParallelNode int
|
||
|
ParallelTotal int
|
||
|
SyncHost string
|
||
|
StreamHost string
|
||
|
}
|
||
|
|
||
|
var GinkgoConfig = GinkgoConfigType{}
|
||
|
|
||
|
type DefaultReporterConfigType struct {
|
||
|
NoColor bool
|
||
|
SlowSpecThreshold float64
|
||
|
NoisyPendings bool
|
||
|
Succinct bool
|
||
|
Verbose bool
|
||
|
FullTrace bool
|
||
|
}
|
||
|
|
||
|
var DefaultReporterConfig = DefaultReporterConfigType{}
|
||
|
|
||
|
func processPrefix(prefix string) string {
|
||
|
if prefix != "" {
|
||
|
prefix = prefix + "."
|
||
|
}
|
||
|
return prefix
|
||
|
}
|
||
|
|
||
|
func Flags(flagSet *flag.FlagSet, prefix string, includeParallelFlags bool) {
|
||
|
prefix = processPrefix(prefix)
|
||
|
flagSet.Int64Var(&(GinkgoConfig.RandomSeed), prefix+"seed", time.Now().Unix(), "The seed used to randomize the spec suite.")
|
||
|
flagSet.BoolVar(&(GinkgoConfig.RandomizeAllSpecs), prefix+"randomizeAllSpecs", false, "If set, ginkgo will randomize all specs together. By default, ginkgo only randomizes the top level Describe/Context groups.")
|
||
|
flagSet.BoolVar(&(GinkgoConfig.SkipMeasurements), prefix+"skipMeasurements", false, "If set, ginkgo will skip any measurement specs.")
|
||
|
flagSet.BoolVar(&(GinkgoConfig.FailOnPending), prefix+"failOnPending", false, "If set, ginkgo will mark the test suite as failed if any specs are pending.")
|
||
|
flagSet.BoolVar(&(GinkgoConfig.FailFast), prefix+"failFast", false, "If set, ginkgo will stop running a test suite after a failure occurs.")
|
||
|
flagSet.BoolVar(&(GinkgoConfig.DryRun), prefix+"dryRun", false, "If set, ginkgo will walk the test hierarchy without actually running anything. Best paired with -v.")
|
||
|
flagSet.StringVar(&(GinkgoConfig.FocusString), prefix+"focus", "", "If set, ginkgo will only run specs that match this regular expression.")
|
||
|
flagSet.StringVar(&(GinkgoConfig.SkipString), prefix+"skip", "", "If set, ginkgo will only run specs that do not match this regular expression.")
|
||
|
flagSet.BoolVar(&(GinkgoConfig.EmitSpecProgress), prefix+"progress", false, "If set, ginkgo will emit progress information as each spec runs to the GinkgoWriter.")
|
||
|
|
||
|
if includeParallelFlags {
|
||
|
flagSet.IntVar(&(GinkgoConfig.ParallelNode), prefix+"parallel.node", 1, "This worker node's (one-indexed) node number. For running specs in parallel.")
|
||
|
flagSet.IntVar(&(GinkgoConfig.ParallelTotal), prefix+"parallel.total", 1, "The total number of worker nodes. For running specs in parallel.")
|
||
|
flagSet.StringVar(&(GinkgoConfig.SyncHost), prefix+"parallel.synchost", "", "The address for the server that will synchronize the running nodes.")
|
||
|
flagSet.StringVar(&(GinkgoConfig.StreamHost), prefix+"parallel.streamhost", "", "The address for the server that the running nodes should stream data to.")
|
||
|
}
|
||
|
|
||
|
flagSet.BoolVar(&(DefaultReporterConfig.NoColor), prefix+"noColor", false, "If set, suppress color output in default reporter.")
|
||
|
flagSet.Float64Var(&(DefaultReporterConfig.SlowSpecThreshold), prefix+"slowSpecThreshold", 5.0, "(in seconds) Specs that take longer to run than this threshold are flagged as slow by the default reporter (default: 5 seconds).")
|
||
|
flagSet.BoolVar(&(DefaultReporterConfig.NoisyPendings), prefix+"noisyPendings", true, "If set, default reporter will shout about pending tests.")
|
||
|
flagSet.BoolVar(&(DefaultReporterConfig.Verbose), prefix+"v", false, "If set, default reporter print out all specs as they begin.")
|
||
|
flagSet.BoolVar(&(DefaultReporterConfig.Succinct), prefix+"succinct", false, "If set, default reporter prints out a very succinct report")
|
||
|
flagSet.BoolVar(&(DefaultReporterConfig.FullTrace), prefix+"trace", false, "If set, default reporter prints out the full stack trace when a failure occurs")
|
||
|
}
|
||
|
|
||
|
func BuildFlagArgs(prefix string, ginkgo GinkgoConfigType, reporter DefaultReporterConfigType) []string {
|
||
|
prefix = processPrefix(prefix)
|
||
|
result := make([]string, 0)
|
||
|
|
||
|
if ginkgo.RandomSeed > 0 {
|
||
|
result = append(result, fmt.Sprintf("--%sseed=%d", prefix, ginkgo.RandomSeed))
|
||
|
}
|
||
|
|
||
|
if ginkgo.RandomizeAllSpecs {
|
||
|
result = append(result, fmt.Sprintf("--%srandomizeAllSpecs", prefix))
|
||
|
}
|
||
|
|
||
|
if ginkgo.SkipMeasurements {
|
||
|
result = append(result, fmt.Sprintf("--%sskipMeasurements", prefix))
|
||
|
}
|
||
|
|
||
|
if ginkgo.FailOnPending {
|
||
|
result = append(result, fmt.Sprintf("--%sfailOnPending", prefix))
|
||
|
}
|
||
|
|
||
|
if ginkgo.FailFast {
|
||
|
result = append(result, fmt.Sprintf("--%sfailFast", prefix))
|
||
|
}
|
||
|
|
||
|
if ginkgo.DryRun {
|
||
|
result = append(result, fmt.Sprintf("--%sdryRun", prefix))
|
||
|
}
|
||
|
|
||
|
if ginkgo.FocusString != "" {
|
||
|
result = append(result, fmt.Sprintf("--%sfocus=%s", prefix, ginkgo.FocusString))
|
||
|
}
|
||
|
|
||
|
if ginkgo.SkipString != "" {
|
||
|
result = append(result, fmt.Sprintf("--%sskip=%s", prefix, ginkgo.SkipString))
|
||
|
}
|
||
|
|
||
|
if ginkgo.EmitSpecProgress {
|
||
|
result = append(result, fmt.Sprintf("--%sprogress", prefix))
|
||
|
}
|
||
|
|
||
|
if ginkgo.ParallelNode != 0 {
|
||
|
result = append(result, fmt.Sprintf("--%sparallel.node=%d", prefix, ginkgo.ParallelNode))
|
||
|
}
|
||
|
|
||
|
if ginkgo.ParallelTotal != 0 {
|
||
|
result = append(result, fmt.Sprintf("--%sparallel.total=%d", prefix, ginkgo.ParallelTotal))
|
||
|
}
|
||
|
|
||
|
if ginkgo.StreamHost != "" {
|
||
|
result = append(result, fmt.Sprintf("--%sparallel.streamhost=%s", prefix, ginkgo.StreamHost))
|
||
|
}
|
||
|
|
||
|
if ginkgo.SyncHost != "" {
|
||
|
result = append(result, fmt.Sprintf("--%sparallel.synchost=%s", prefix, ginkgo.SyncHost))
|
||
|
}
|
||
|
|
||
|
if reporter.NoColor {
|
||
|
result = append(result, fmt.Sprintf("--%snoColor", prefix))
|
||
|
}
|
||
|
|
||
|
if reporter.SlowSpecThreshold > 0 {
|
||
|
result = append(result, fmt.Sprintf("--%sslowSpecThreshold=%.5f", prefix, reporter.SlowSpecThreshold))
|
||
|
}
|
||
|
|
||
|
if !reporter.NoisyPendings {
|
||
|
result = append(result, fmt.Sprintf("--%snoisyPendings=false", prefix))
|
||
|
}
|
||
|
|
||
|
if reporter.Verbose {
|
||
|
result = append(result, fmt.Sprintf("--%sv", prefix))
|
||
|
}
|
||
|
|
||
|
if reporter.Succinct {
|
||
|
result = append(result, fmt.Sprintf("--%ssuccinct", prefix))
|
||
|
}
|
||
|
|
||
|
if reporter.FullTrace {
|
||
|
result = append(result, fmt.Sprintf("--%strace", prefix))
|
||
|
}
|
||
|
|
||
|
return result
|
||
|
}
|