2019-11-02 21:32:58 +07:00
|
|
|
package suites
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
|
2019-11-17 17:47:07 +07:00
|
|
|
"github.com/clems4ever/authelia/internal/utils"
|
2019-11-02 21:32:58 +07:00
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
var kubernetesSuiteName = "Kubernetes"
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
kind := Kind{}
|
|
|
|
kubectl := Kubectl{}
|
|
|
|
|
|
|
|
setup := func(suitePath string) error {
|
|
|
|
exists, err := kind.ClusterExists()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if exists {
|
|
|
|
log.Debug("Kubernetes cluster already exists")
|
|
|
|
} else {
|
|
|
|
err = kind.CreateCluster()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Debug("Building authelia:dist image...")
|
|
|
|
if err := utils.Shell("authelia-scripts docker build").Run(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Debug("Loading images into Kubernetes container...")
|
|
|
|
if err = loadDockerImages(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-11-16 22:22:10 +07:00
|
|
|
log.Debug("Starting Kubernetes dashboard...")
|
|
|
|
if err := kubectl.StartDashboard(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-11-02 21:32:58 +07:00
|
|
|
log.Debug("Deploying thirdparties...")
|
|
|
|
if err = kubectl.DeployThirdparties(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Debug("Waiting for services to be ready...")
|
|
|
|
if err := waitAllPodsAreReady(5 * time.Minute); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Debug("Deploying Authelia...")
|
|
|
|
if err = kubectl.DeployAuthelia(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Debug("Waiting for services to be ready...")
|
|
|
|
if err := waitAllPodsAreReady(2 * time.Minute); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Debug("Starting proxy...")
|
|
|
|
if err := kubectl.StartProxy(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
teardown := func(suitePath string) error {
|
|
|
|
kubectl.StopProxy()
|
|
|
|
return kind.DeleteCluster()
|
|
|
|
}
|
|
|
|
|
|
|
|
GlobalRegistry.Register(kubernetesSuiteName, Suite{
|
|
|
|
TestTimeout: 60 * time.Second,
|
|
|
|
SetUp: setup,
|
|
|
|
SetUpTimeout: 10 * time.Minute,
|
|
|
|
TearDown: teardown,
|
|
|
|
TearDownTimeout: 10 * time.Minute,
|
|
|
|
Description: "This suite has been created to test Authelia in a Kubernetes context and using nginx as the ingress controller.",
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func loadDockerImages() error {
|
|
|
|
kind := Kind{}
|
|
|
|
images := []string{"authelia:dist", "authelia-example-backend"}
|
|
|
|
|
|
|
|
for _, image := range images {
|
|
|
|
err := kind.LoadImage(image)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func waitAllPodsAreReady(timeout time.Duration) error {
|
|
|
|
kubectl := Kubectl{}
|
|
|
|
// Wait in case the deployment has just been done and some services do not appear in kubectl logs.
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
fmt.Println("Check services are running")
|
|
|
|
if err := kubectl.WaitPodsReady(timeout); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
fmt.Println("All pods are ready")
|
|
|
|
return nil
|
|
|
|
}
|