mirror of
https://github.com/MontFerret/ferret.git
synced 2024-12-16 11:37:36 +02:00
197 lines
3.2 KiB
Go
197 lines
3.2 KiB
Go
package runner
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"github.com/MontFerret/ferret/pkg/compiler"
|
|
"github.com/MontFerret/ferret/pkg/runtime"
|
|
"github.com/pkg/errors"
|
|
"github.com/rs/zerolog"
|
|
"io/ioutil"
|
|
"path/filepath"
|
|
"time"
|
|
)
|
|
|
|
type (
|
|
Settings struct {
|
|
ServerAddress string
|
|
CDPAddress string
|
|
Dir string
|
|
}
|
|
|
|
Result struct {
|
|
name string
|
|
duration time.Duration
|
|
err error
|
|
}
|
|
|
|
Summary struct {
|
|
passed int
|
|
failed int
|
|
duration time.Duration
|
|
}
|
|
|
|
Runner struct {
|
|
logger zerolog.Logger
|
|
settings Settings
|
|
}
|
|
)
|
|
|
|
func New(logger zerolog.Logger, settings Settings) *Runner {
|
|
return &Runner{
|
|
logger,
|
|
settings,
|
|
}
|
|
}
|
|
|
|
func (r *Runner) Run() error {
|
|
results, err := r.runQueries(r.settings.Dir)
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
sum := r.report(results)
|
|
|
|
var event *zerolog.Event
|
|
|
|
if sum.failed == 0 {
|
|
event = r.logger.Info()
|
|
} else {
|
|
event = r.logger.Error()
|
|
}
|
|
|
|
event.
|
|
Timestamp().
|
|
Int("passed", sum.passed).
|
|
Int("failed", sum.failed).
|
|
Dur("time", sum.duration).
|
|
Msg("Completed")
|
|
|
|
if sum.failed > 0 {
|
|
return errors.New("failed")
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (r *Runner) runQueries(dir string) ([]Result, error) {
|
|
files, err := ioutil.ReadDir(dir)
|
|
|
|
if err != nil {
|
|
r.logger.Error().
|
|
Timestamp().
|
|
Err(err).
|
|
Str("dir", dir).
|
|
Msg("failed to read scripts directory")
|
|
|
|
return nil, err
|
|
}
|
|
|
|
results := make([]Result, 0, len(files))
|
|
|
|
c := compiler.New()
|
|
c.RegisterFunctions(Assertions())
|
|
|
|
// read scripts
|
|
for _, f := range files {
|
|
fName := filepath.Join(dir, f.Name())
|
|
b, err := ioutil.ReadFile(fName)
|
|
|
|
if err != nil {
|
|
results = append(results, Result{
|
|
name: fName,
|
|
err: errors.Wrap(err, "failed to read script file"),
|
|
})
|
|
|
|
continue
|
|
}
|
|
|
|
results = append(results, r.runQuery(c, fName, string(b)))
|
|
}
|
|
|
|
return results, nil
|
|
}
|
|
|
|
func (r *Runner) runQuery(c *compiler.FqlCompiler, name, script string) Result {
|
|
start := time.Now()
|
|
|
|
p, err := c.Compile(script)
|
|
|
|
if err != nil {
|
|
return Result{
|
|
name: name,
|
|
duration: time.Duration(0) * time.Millisecond,
|
|
err: errors.Wrap(err, "failed to compile query"),
|
|
}
|
|
}
|
|
|
|
out, err := p.Run(
|
|
context.Background(),
|
|
runtime.WithBrowser(r.settings.CDPAddress),
|
|
runtime.WithParam("server", r.settings.ServerAddress),
|
|
)
|
|
|
|
duration := time.Now().Sub(start)
|
|
|
|
if err != nil {
|
|
return Result{
|
|
name: name,
|
|
duration: duration,
|
|
err: errors.Wrap(err, "failed to execute query"),
|
|
}
|
|
}
|
|
|
|
var result string
|
|
|
|
json.Unmarshal(out, &result)
|
|
|
|
if result == "" {
|
|
return Result{
|
|
name: name,
|
|
duration: duration,
|
|
}
|
|
}
|
|
|
|
return Result{
|
|
name: name,
|
|
duration: duration,
|
|
err: errors.New(result),
|
|
}
|
|
}
|
|
|
|
func (r *Runner) report(results []Result) Summary {
|
|
var failed int
|
|
var passed int
|
|
var sumDuration time.Duration
|
|
|
|
for _, res := range results {
|
|
if res.err != nil {
|
|
r.logger.Error().
|
|
Timestamp().
|
|
Err(res.err).
|
|
Str("file", res.name).
|
|
Dur("time", res.duration).
|
|
Msg("Test failed")
|
|
|
|
failed++
|
|
} else {
|
|
r.logger.Info().
|
|
Timestamp().
|
|
Str("file", res.name).
|
|
Dur("time", res.duration).
|
|
Msg("Test passed")
|
|
|
|
passed++
|
|
}
|
|
|
|
sumDuration += res.duration
|
|
}
|
|
|
|
return Summary{
|
|
passed: passed,
|
|
failed: failed,
|
|
duration: sumDuration,
|
|
}
|
|
}
|