Files
old-vegeta/main.go

107 lines
2.6 KiB
Go
Raw Normal View History

2013-08-13 13:47:01 +02:00
package main
import (
"flag"
2013-09-07 22:59:12 +01:00
"fmt"
vegeta "github.com/tsenart/vegeta/lib"
2013-08-14 17:48:51 +02:00
"io"
2013-08-13 13:47:01 +02:00
"log"
2013-08-13 18:51:00 +02:00
"os"
2013-08-14 18:24:20 +02:00
"runtime"
2013-08-13 13:47:01 +02:00
"time"
)
2013-08-14 18:24:20 +02:00
func init() {
runtime.GOMAXPROCS(runtime.NumCPU())
}
2013-08-13 13:47:01 +02:00
func main() {
var (
2013-08-16 20:08:10 +02:00
rate = flag.Uint64("rate", 50, "Requests per second")
2013-08-13 18:51:00 +02:00
targetsf = flag.String("targets", "targets.txt", "Targets file")
ordering = flag.String("ordering", "random", "Attack ordering [sequential, random]")
duration = flag.Duration("duration", 10*time.Second, "Duration of the test")
2013-08-17 19:52:29 +02:00
reporter = flag.String("reporter", "text", "Reporter to use [text, plot:timings]")
2013-08-14 17:48:51 +02:00
output = flag.String("output", "stdout", "Reporter output file")
2013-08-13 13:47:01 +02:00
)
flag.Parse()
2013-08-13 18:51:00 +02:00
if flag.NFlag() == 0 {
flag.Usage()
return
}
2013-09-07 22:59:12 +01:00
if err := run(*rate, *duration, *targetsf, *ordering, *reporter, *output); err != nil {
log.Fatal(err)
2013-08-13 13:47:01 +02:00
}
2013-09-07 22:59:12 +01:00
}
2013-08-16 19:09:06 +02:00
2013-09-07 22:59:12 +01:00
var (
errRatePrefix = "Rate: "
errDurationPrefix = "Duration: "
errOutputFilePrefix = "Output file: "
errTargetsFilePrefix = "Targets file: "
errOrderingPrefix = "Ordering: "
errReportingPrefix = "Reporting: "
)
// attack is an utility function that validates the attack arguments, sets up the
// required resources, launches the attack and reports the results
func run(rate uint64, duration time.Duration, targetsf, ordering, reporter, output string) error {
if rate == 0 {
return fmt.Errorf(errRatePrefix + "can't be zero")
2013-08-13 13:47:01 +02:00
}
2013-09-07 22:59:12 +01:00
if duration == 0 {
return fmt.Errorf(errDurationPrefix + "can't be zero")
2013-08-13 13:47:01 +02:00
}
2013-09-07 22:59:12 +01:00
var out io.Writer
switch output {
case "stdout":
out = os.Stdout
default:
file, err := os.Create(output)
if err != nil {
return fmt.Errorf(errOutputFilePrefix+"(%s): %s", output, err)
}
defer file.Close()
out = file
2013-08-13 13:47:01 +02:00
}
var rep vegeta.Reporter
2013-09-07 22:59:12 +01:00
switch reporter {
2013-08-13 18:51:00 +02:00
case "text":
rep = vegeta.NewTextReporter()
2013-08-17 19:52:29 +02:00
case "plot:timings":
rep = vegeta.NewTimingsPlotReporter()
2013-08-13 18:51:00 +02:00
default:
2013-09-07 22:59:12 +01:00
log.Println("Reporter provided is not supported. Using text")
rep = vegeta.NewTextReporter()
2013-08-13 18:51:00 +02:00
}
2013-09-07 22:59:12 +01:00
targets, err := vegeta.NewTargetsFromFile(targetsf)
if err != nil {
return fmt.Errorf(errTargetsFilePrefix+"(%s): %s", targetsf, err)
}
switch ordering {
case "random":
targets.Shuffle(time.Now().UnixNano())
case "sequential":
break
2013-08-14 17:48:51 +02:00
default:
2013-09-07 22:59:12 +01:00
return fmt.Errorf(errOrderingPrefix+"`%s` is invalid", ordering)
2013-08-14 17:48:51 +02:00
}
2013-08-14 18:04:20 +02:00
2013-09-07 22:59:12 +01:00
log.Printf("Vegeta is attacking %d targets in %s order for %s...\n", len(targets), ordering, duration)
vegeta.Attack(targets, rate, duration, rep)
2013-08-14 18:04:20 +02:00
log.Println("Done!")
2013-09-07 22:59:12 +01:00
log.Printf("Writing report to '%s'...", output)
2013-08-23 16:17:52 +02:00
if err = rep.Report(out); err != nil {
2013-09-07 22:59:12 +01:00
return fmt.Errorf(errReportingPrefix+"%s", err)
2013-08-13 13:47:01 +02:00
}
2013-09-07 22:59:12 +01:00
return nil
2013-08-13 13:47:01 +02:00
}