Skip to content

Commit

Permalink
Reuse WaitFor function to ensure DSPA is ready
Browse files Browse the repository at this point in the history
  • Loading branch information
diegolovison committed Oct 7, 2024
1 parent 85a1145 commit 82794c3
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 46 deletions.
50 changes: 13 additions & 37 deletions tests/suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@ import (
"flag"
"fmt"
routev1 "github.com/openshift/api/route/v1"
"k8s.io/apimachinery/pkg/types"
"log"
"testing"
"time"
Expand Down Expand Up @@ -191,8 +190,8 @@ func (suite *IntegrationTestSuite) SetupSuite() {
loggr.Info("Waiting for DSPA pods to ready...")
}

err = testUtil.WaitForDSPAReady(suite.T(), ctx, clientmgr.k8sClient, DSPA.Name, DSPANamespace, DeployTimeout, PollInterval)
require.NoError(suite.T(), err, fmt.Sprintf("Error Deploying DSPA:\n%s", testUtil.PrintConditions(ctx, DSPA, DSPANamespace, clientmgr.k8sClient)))
err = testUtil.WaitForDSPAReady(suite.T(), ctx, clientmgr.k8sClient, suite.Clientmgr.httpClient, DSPA.Name, DSPANamespace, DeployTimeout, PollInterval)
require.NoError(suite.T(), err, fmt.Sprintf("Error waiting for DSPA being ready:\n%s", testUtil.PrintConditions(ctx, DSPA, DSPANamespace, clientmgr.k8sClient)))
loggr.Info("DSPA Deployed.")

if endpointType == "service" {
Expand All @@ -218,28 +217,9 @@ func (suite *IntegrationTestSuite) SetupSuite() {

} else if endpointType == "route" {

// Define the namespaced name
key := types.NamespacedName{
Namespace: DSPANamespace,
Name: "ds-pipeline-" + suite.DSPA.Name,
}

route := &routev1.Route{}

// Retrieve the route
count := 1
ok := false
for count < 10 {
err := clientmgr.k8sClient.Get(context.TODO(), key, route)
if err == nil {
ok = true
break
}
count++
time.Sleep(1 * time.Second)
}
if !ok {
log.Fatal("failed to retrieve route")
route, err := testUtil.GetDSPARoute(clientmgr.k8sClient, DSPANamespace, suite.DSPA.Name)
if err != nil {
log.Fatal(err, "failed to retrieve route")
}

APIServerURL = fmt.Sprintf("https://%s", route.Status.Ingress[0].Host)
Expand All @@ -254,19 +234,15 @@ func (suite *IntegrationTestSuite) SetupSuite() {
}

// waiting for pods to sit down
count = 1
ok = false
for count < 10 {
response, _ := suite.Clientmgr.httpClient.Get(fmt.Sprintf("%s/apis/v2beta1/healthz", APIServerURL))
if response.StatusCode == 200 {
ok = true
break
err = testUtil.WaitFor(ctx, DeployTimeout, PollInterval, func() (bool, error) {
response, err := suite.Clientmgr.httpClient.Get(fmt.Sprintf("%s/apis/v2beta1/healthz", APIServerURL))
if response.StatusCode != 200 {
return false, err
}
count++
time.Sleep(1 * time.Second)
}
if !ok {
log.Fatal("Pods didn't started properly")
return true, nil
})
if err != nil {
log.Fatal(err, "healthz endpoint is not working properly")
}

} else {
Expand Down
48 changes: 39 additions & 9 deletions tests/util/resources.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ package testUtil
import (
"context"
"fmt"
routev1 "github.com/openshift/api/route/v1"
"net/http"
"testing"
"time"

Expand All @@ -41,7 +43,7 @@ func DeployDSPA(t *testing.T, ctx context.Context, client client.Client, deployD
Namespace: dspaNS,
}
fetchedDspa := &v1alpha1.DataSciencePipelinesApplication{}
return waitFor(ctx, timeout, interval, func() (bool, error) {
return WaitFor(ctx, timeout, interval, func() (bool, error) {
err := client.Get(ctx, nsn, fetchedDspa)
if err != nil {
return false, err
Expand All @@ -51,13 +53,13 @@ func DeployDSPA(t *testing.T, ctx context.Context, client client.Client, deployD
}

// WaitForDSPAReady will assert for DSPA CR Ready Status
func WaitForDSPAReady(t *testing.T, ctx context.Context, client client.Client, dspaName, dspaNS string, timeout, interval time.Duration) error {
func WaitForDSPAReady(t *testing.T, ctx context.Context, client client.Client, httpClient http.Client, dspaName, dspaNS string, timeout, interval time.Duration) error {
nsn := types.NamespacedName{
Name: dspaName,
Namespace: dspaNS,
}
dspa := &v1alpha1.DataSciencePipelinesApplication{}
return waitFor(ctx, timeout, interval, func() (bool, error) {
err := WaitFor(ctx, timeout, interval, func() (bool, error) {
err := client.Get(ctx, nsn, dspa)
if err != nil {
return false, err
Expand All @@ -69,6 +71,34 @@ func WaitForDSPAReady(t *testing.T, ctx context.Context, client client.Client, d
}
return false, nil
})
// fail fast
if err != nil {
return err
}
if dspa.Spec.EnableRoute {
err = WaitFor(ctx, timeout, interval, func() (bool, error) {
_, err := GetDSPARoute(client, dspaNS, dspa.ObjectMeta.Name)
if err != nil {
return false, err
}
return true, nil
})
// fail fast
if err != nil {
return err
}
}
return err
}

func GetDSPARoute(client client.Client, dspaNS, name string) (*routev1.Route, error) {
key := types.NamespacedName{
Namespace: dspaNS,
Name: "ds-pipeline-" + name,
}
route := &routev1.Route{}
err := client.Get(context.TODO(), key, route)
return route, err
}

// DeleteDSPA will delete DSPA found in path by requesting
Expand All @@ -85,7 +115,7 @@ func DeleteDSPA(t *testing.T, ctx context.Context, client client.Client, dspaNam
}
err := client.Delete(ctx, dspa)
require.NoError(t, err)
return waitFor(ctx, timeout, interval, func() (bool, error) {
return WaitFor(ctx, timeout, interval, func() (bool, error) {
err := client.Get(ctx, nsn, dspa)
if apierrs.IsNotFound(err) {
return true, nil
Expand Down Expand Up @@ -122,17 +152,17 @@ func GetDSPAFromPath(t *testing.T, opts mf.Option, path string) *v1alpha1.DataSc
return dspa
}

// waitFor is a helper function
func waitFor(ctx context.Context, timeout, interval time.Duration, conditionFunc func() (bool, error)) error {
// WaitFor is a helper function
func WaitFor(ctx context.Context, timeout, interval time.Duration, conditionFunc func() (bool, error)) error {
deadline := time.Now().Add(timeout)
for time.Now().Before(deadline) {
done, err := conditionFunc()
if done {
return nil
}
if err != nil {
return err
}
if done {
return nil
}
time.Sleep(interval)
}
return fmt.Errorf("timed out waiting for condition")
Expand Down

0 comments on commit 82794c3

Please sign in to comment.