mirror of
https://github.com/redis/go-redis.git
synced 2025-12-02 06:22:31 +03:00
43 lines
911 B
Go
43 lines
911 B
Go
package e2e
|
|
|
|
import (
|
|
"log"
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/redis/go-redis/v9"
|
|
"github.com/redis/go-redis/v9/logging"
|
|
)
|
|
|
|
// Global log collector
|
|
var logCollector *TestLogCollector
|
|
|
|
const defaultTestTimeout = 30 * time.Minute
|
|
|
|
// Global fault injector client
|
|
var faultInjector *FaultInjectorClient
|
|
|
|
func TestMain(m *testing.M) {
|
|
var err error
|
|
if os.Getenv("E2E_SCENARIO_TESTS") != "true" {
|
|
log.Println("Skipping scenario tests, E2E_SCENARIO_TESTS is not set")
|
|
return
|
|
}
|
|
|
|
faultInjector, err = CreateTestFaultInjector()
|
|
if err != nil {
|
|
panic("Failed to create fault injector: " + err.Error())
|
|
}
|
|
// use log collector to capture logs from redis clients
|
|
logCollector = NewTestLogCollector()
|
|
redis.SetLogger(logCollector)
|
|
redis.SetLogLevel(logging.LogLevelDebug)
|
|
|
|
logCollector.Clear()
|
|
defer logCollector.Clear()
|
|
log.Println("Running scenario tests...")
|
|
status := m.Run()
|
|
os.Exit(status)
|
|
}
|