mirror of
https://github.com/redis/go-redis.git
synced 2025-10-20 09:52:25 +03:00
* e2e wip * cleanup * remove unused fault injector mock * errChan in test * remove log messages tests * cleanup log messages * s/hitless/maintnotifications/ * fix moving when none * better logs * test with second client after action has started * Fixes Signed-off-by: Elena Kolevska <elena@kolevska.com> * Test fix Signed-off-by: Elena Kolevska <elena@kolevska.com> * feat(e2e-test): Extended e2e tests * imroved e2e test resiliency --------- Signed-off-by: Elena Kolevska <elena@kolevska.com> Co-authored-by: Elena Kolevska <elena@kolevska.com> Co-authored-by: Elena Kolevska <elena-kolevska@users.noreply.github.com> Co-authored-by: Hristo Temelski <hristo.temelski@redis.com>
40 lines
858 B
Go
40 lines
858 B
Go
package e2e
|
|
|
|
import (
|
|
"log"
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/redis/go-redis/v9"
|
|
"github.com/redis/go-redis/v9/logging"
|
|
)
|
|
|
|
// Global log collector
|
|
var logCollector *TestLogCollector
|
|
|
|
// 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)
|
|
}
|