tile38/tests/tests_test.go

177 lines
3.7 KiB
Go
Raw Normal View History

package tests
import (
"fmt"
2020-04-08 21:36:37 +03:00
"math/rand"
"os"
2016-12-02 19:14:34 +03:00
"os/signal"
"syscall"
"testing"
2020-04-08 21:36:37 +03:00
"time"
"github.com/gomodule/redigo/redis"
)
2016-12-02 19:14:34 +03:00
const (
clear = "\x1b[0m"
bright = "\x1b[1m"
dim = "\x1b[2m"
black = "\x1b[30m"
red = "\x1b[31m"
green = "\x1b[32m"
yellow = "\x1b[33m"
blue = "\x1b[34m"
magenta = "\x1b[35m"
cyan = "\x1b[36m"
white = "\x1b[37m"
)
2016-12-02 19:14:34 +03:00
func TestAll(t *testing.T) {
2020-04-08 21:36:37 +03:00
mockCleanup(false)
defer mockCleanup(false)
2022-09-23 17:30:03 +03:00
ch := make(chan os.Signal, 1)
2016-12-02 19:14:34 +03:00
signal.Notify(ch, os.Interrupt, syscall.SIGTERM)
go func() {
2016-12-02 19:14:34 +03:00
<-ch
2020-04-08 21:36:37 +03:00
mockCleanup(false)
2016-12-02 19:14:34 +03:00
os.Exit(1)
}()
2020-04-08 21:36:37 +03:00
mc, err := mockOpenServer(false)
if err != nil {
t.Fatal(err)
}
2016-12-02 19:14:34 +03:00
defer mc.Close()
runSubTest(t, "keys", mc, subTestKeys)
runSubTest(t, "json", mc, subTestJSON)
runSubTest(t, "search", mc, subTestSearch)
2019-02-09 00:58:04 +03:00
runSubTest(t, "testcmd", mc, subTestTestCmd)
2017-02-12 17:58:03 +03:00
runSubTest(t, "fence", mc, subTestFence)
2017-10-05 18:20:40 +03:00
runSubTest(t, "scripts", mc, subTestScripts)
runSubTest(t, "info", mc, subTestInfo)
runSubTest(t, "client", mc, subTestClient)
2019-04-24 23:20:57 +03:00
runSubTest(t, "timeouts", mc, subTestTimeout)
2021-05-12 04:41:47 +03:00
runSubTest(t, "metrics", mc, subTestMetrics)
}
2016-12-02 19:14:34 +03:00
func runSubTest(t *testing.T, name string, mc *mockServer, test func(t *testing.T, mc *mockServer)) {
t.Run(name, func(t *testing.T) {
fmt.Printf(bright+"Testing %s\n"+clear, name)
test(t, mc)
})
}
2016-12-02 19:14:34 +03:00
func runStep(t *testing.T, mc *mockServer, name string, step func(mc *mockServer) error) {
t.Helper()
2016-12-02 19:14:34 +03:00
t.Run(name, func(t *testing.T) {
t.Helper()
2016-12-02 19:14:34 +03:00
if err := func() error {
// reset the current server
mc.ResetConn()
defer mc.ResetConn()
// clear the database so the test is consistent
if err := mc.DoBatch([][]interface{}{
{"OUTPUT", "resp"}, {"OK"},
{"FLUSHDB"}, {"OK"},
}); err != nil {
2016-12-02 19:14:34 +03:00
return err
}
2016-12-02 19:14:34 +03:00
if err := step(mc); err != nil {
return err
}
2016-12-02 19:14:34 +03:00
return nil
}(); err != nil {
2022-09-23 17:30:03 +03:00
fmt.Fprintf(os.Stderr, "["+red+"fail"+clear+"]: %s\n", name)
2016-12-02 19:14:34 +03:00
t.Fatal(err)
2022-09-23 17:30:03 +03:00
// t.Fatal(err)
}
2016-12-02 19:14:34 +03:00
fmt.Printf("["+green+"ok"+clear+"]: %s\n", name)
})
}
2020-04-08 21:36:37 +03:00
func BenchmarkAll(b *testing.B) {
mockCleanup(true)
defer mockCleanup(true)
2022-09-23 17:30:03 +03:00
ch := make(chan os.Signal, 1)
2020-04-08 21:36:37 +03:00
signal.Notify(ch, os.Interrupt, syscall.SIGTERM)
go func() {
<-ch
mockCleanup(true)
os.Exit(1)
}()
mc, err := mockOpenServer(true)
if err != nil {
b.Fatal(err)
}
defer mc.Close()
runSubBenchmark(b, "search", mc, subBenchSearch)
}
func loadBenchmarkPoints(b *testing.B, mc *mockServer) (err error) {
const nPoints = 200000
rand.Seed(time.Now().UnixNano())
// add a bunch of points
for i := 0; i < nPoints; i++ {
val := fmt.Sprintf("val:%d", i)
var resp string
var lat, lon, fval float64
fval = rand.Float64()
lat = rand.Float64()*180 - 90
lon = rand.Float64()*360 - 180
resp, err = redis.String(mc.conn.Do("SET",
"mykey", val,
"FIELD", "foo", fval,
"POINT", lat, lon))
if err != nil {
return
}
if resp != "OK" {
err = fmt.Errorf("expected 'OK', got '%s'", resp)
return
}
}
return
}
func runSubBenchmark(b *testing.B, name string, mc *mockServer, bench func(t *testing.B, mc *mockServer)) {
b.Run(name, func(b *testing.B) {
bench(b, mc)
})
}
func runBenchStep(b *testing.B, mc *mockServer, name string, step func(mc *mockServer) error) {
b.Helper()
b.Run(name, func(b *testing.B) {
b.Helper()
if err := func() error {
// reset the current server
mc.ResetConn()
defer mc.ResetConn()
// clear the database so the test is consistent
if err := mc.DoBatch([][]interface{}{
{"OUTPUT", "resp"}, {"OK"},
{"FLUSHDB"}, {"OK"},
}); err != nil {
return err
}
err := loadBenchmarkPoints(b, mc)
if err != nil {
return err
}
b.ResetTimer()
for i := 0; i < b.N; i++ {
if err := step(mc); err != nil {
return err
}
}
return nil
}(); err != nil {
b.Fatal(err)
}
})
}