package suites import ( "fmt" "time" ) var oidcTraefikSuiteName = "OIDCTraefik" func init() { dockerEnvironment := NewDockerEnvironment([]string{ "internal/suites/docker-compose.yml", "internal/suites/OIDCTraefik/docker-compose.yml", "internal/suites/example/compose/authelia/docker-compose.backend.{}.yml", "internal/suites/example/compose/authelia/docker-compose.frontend.{}.yml", "internal/suites/example/compose/nginx/backend/docker-compose.yml", "internal/suites/example/compose/traefik2/docker-compose.yml", "internal/suites/example/compose/smtp/docker-compose.yml", "internal/suites/example/compose/oidc-client/docker-compose.yml", "internal/suites/example/compose/redis/docker-compose.yml", }) setup := func(suitePath string) error { // TODO(c.michaud): use version in tags for oidc-client but in the meantime we pull the image to make sure it's // up to date. err := dockerEnvironment.Pull("oidc-client") if err != nil { return err } err = dockerEnvironment.Up() if err != nil { return err } return waitUntilAutheliaIsReady(dockerEnvironment, oidcTraefikSuiteName) } displayAutheliaLogs := func() error { backendLogs, err := dockerEnvironment.Logs("authelia-backend", nil) if err != nil { return err } fmt.Println(backendLogs) frontendLogs, err := dockerEnvironment.Logs("authelia-frontend", nil) if err != nil { return err } fmt.Println(frontendLogs) oidcClientLogs, err := dockerEnvironment.Logs("oidc-client", nil) if err != nil { return err } fmt.Println(oidcClientLogs) return nil } teardown := func(suitePath string) error { err := dockerEnvironment.Down() return err } GlobalRegistry.Register(oidcTraefikSuiteName, Suite{ SetUp: setup, SetUpTimeout: 5 * time.Minute, OnSetupTimeout: displayAutheliaLogs, OnError: displayAutheliaLogs, TestTimeout: 2 * time.Minute, TearDown: teardown, TearDownTimeout: 2 * time.Minute, }) }