Skip to content

Commit

Permalink
Fix dashboard internal api tests
Browse files Browse the repository at this point in the history
  • Loading branch information
lburgazzoli committed Oct 29, 2024
1 parent 6a939e1 commit b1bb237
Show file tree
Hide file tree
Showing 3 changed files with 64 additions and 31 deletions.
4 changes: 2 additions & 2 deletions controllers/components/dashboard/dashboard_support.go
Original file line number Diff line number Diff line change
Expand Up @@ -81,9 +81,9 @@ func computeKustomizeVariable(ctx context.Context, cli client.Client, platform c
func computeComponentName() string {
release := cluster.GetRelease()

name := ComponentNameDownstream
name := ComponentNameUpstream
if release.Name == cluster.SelfManagedRhods || release.Name == cluster.ManagedRhods {
name = ComponentNameUpstream
name = ComponentNameDownstream
}

return name
Expand Down
23 changes: 16 additions & 7 deletions pkg/controller/reconciler/component_reconciler.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import (
"fmt"
"reflect"

k8serr "k8s.io/apimachinery/pkg/api/errors"

"github.com/go-logr/logr"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/runtime/schema"
Expand Down Expand Up @@ -166,17 +168,24 @@ func (r *ComponentReconciler) Reconcile(ctx context.Context, req ctrl.Request) (
}
}

// update status
err = r.Client.ApplyStatus(
//
// update status with standard update mechanism as the SSA one seems causing
// a weird issue on some openshift releases:
//
// failed to create typed patch object (...): .status.url: field not declared in schema
//
err = r.Client.Status().Update(
ctx,
rr.Instance,
client.FieldOwner(rr.Instance.GetName()),
client.ForceOwnership,
)

if err != nil {
switch {
case err == nil:
return ctrl.Result{}, nil
case k8serr.IsConflict(err):
l.Info("conflict detected while updating status, retrying")
return ctrl.Result{Requeue: true}, nil
default:
return ctrl.Result{}, err
}

return ctrl.Result{}, nil
}
68 changes: 46 additions & 22 deletions tests/e2e/dashboard_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import (
k8serr "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
"k8s.io/apimachinery/pkg/util/wait"
"k8s.io/client-go/util/retry"
"sigs.k8s.io/controller-runtime/pkg/client"

Expand Down Expand Up @@ -47,7 +48,7 @@ func dashboardTestSuite(t *testing.T) {
})

t.Run("Validate Ownerrefrences exist", func(t *testing.T) {
err = dashboardCtx.testOwnerrefrences()
err = dashboardCtx.testOwnerReferences()
require.NoError(t, err, "error getting all Dashboard's Ownerrefrences")
})

Expand All @@ -71,20 +72,35 @@ func dashboardTestSuite(t *testing.T) {
}

func (tc *DashboardTestCtx) testDashboardCreation() error {
existingDashboardList := &componentsv1.DashboardList{}
if tc.testCtx.testDsc.Spec.Components.Dashboard.ManagementState != operatorv1.Managed {
return nil
}

if tc.testCtx.testDsc.Spec.Components.Dashboard.ManagementState == operatorv1.Managed {
err := tc.testCtx.customClient.List(tc.testCtx.ctx, existingDashboardList)
if err == nil {
if len(existingDashboardList.Items) == 1 {
tc.testDashboardInstance = existingDashboardList.Items[0]
return nil
} else {
return fmt.Errorf("unexpected Dashboard CR instances. Expected 1 , "+
"Found %v instance", len(existingDashboardList.Items))
}
err := tc.testCtx.wait(func(ctx context.Context) (bool, error) {
existingDashboardList := &componentsv1.DashboardList{}

err := tc.testCtx.customClient.List(ctx, existingDashboardList)
if err != nil {
return false, err
}

switch {
case len(existingDashboardList.Items) == 1:
tc.testDashboardInstance = existingDashboardList.Items[0]
return true, nil

case len(existingDashboardList.Items) > 1:
return false, fmt.Errorf(
"unexpected Dashboard CR instances. Expected 1 , Found %v instance", len(existingDashboardList.Items))
default:
return false, nil
}
})

if err != nil {
return fmt.Errorf("unable to find Dashboard CR instance: %w", err)
}

return nil
}

Expand All @@ -98,7 +114,11 @@ func (tc *DashboardTestCtx) validateDashboard() error {
return nil
}

func (tc *DashboardTestCtx) testOwnerrefrences() error {
func (tc *DashboardTestCtx) testOwnerReferences() error {
if len(tc.testDashboardInstance.OwnerReferences) != 1 {
return errors.New("expected ownerreferences to be non empty")
}

// Test Dashboard CR ownerref
if tc.testDashboardInstance.OwnerReferences[0].Kind != "DataScienceCluster" {
return fmt.Errorf("expected ownerreference not found. Got ownereferrence: %v",
Expand All @@ -124,8 +144,10 @@ func (tc *DashboardTestCtx) testOwnerrefrences() error {

// Verify Dashboard instance is in Ready phase when dashboard deployments are up and running.
func (tc *DashboardTestCtx) validateDashboardReady() error {
// wait for 2 mins which is on the safe side, normally it should get ready once all components are ready
err := tc.testCtx.wait(func(ctx context.Context) (bool, error) {
// the dashboard deployment may take quite a long time to get ready as the related readiness
// probes have an initial delay time of 30 sec and each check is performed with a delay of
// 30 sec.
err := wait.PollUntilContextTimeout(tc.testCtx.ctx, generalRetryInterval, componentReadyTimeout, true, func(ctx context.Context) (bool, error) {
key := types.NamespacedName{Name: tc.testDashboardInstance.Name}
dashboard := &componentsv1.Dashboard{}

Expand All @@ -147,7 +169,7 @@ func (tc *DashboardTestCtx) testUpdateOnDashboardResources() error {
// Test Updating Dashboard Replicas

appDeployments, err := tc.testCtx.kubeClient.AppsV1().Deployments(tc.testCtx.applicationsNamespace).List(tc.testCtx.ctx, metav1.ListOptions{
LabelSelector: labels.ODH.Component("dashboard"),
LabelSelector: labels.ComponentManagedBy + "=" + tc.testDashboardInstance.Name,
})
if err != nil {
return err
Expand Down Expand Up @@ -238,13 +260,15 @@ func (tc *DashboardTestCtx) testUpdateDashboardComponentDisabled() error {
return fmt.Errorf("error after retry %w", err)
}

// Verify dashboard CR is deleted
dashboard := &componentsv1.Dashboard{}
err = tc.testCtx.customClient.Get(tc.testCtx.ctx, client.ObjectKey{Name: tc.testDashboardInstance.Name}, dashboard)
if err == nil {
err = tc.testCtx.wait(func(ctx context.Context) (bool, error) {
// Verify dashboard CR is deleted
dashboard := &componentsv1.Dashboard{}
err = tc.testCtx.customClient.Get(ctx, client.ObjectKey{Name: tc.testDashboardInstance.Name}, dashboard)
return k8serr.IsNotFound(err), nil
})

if err != nil {
return fmt.Errorf("component %v is disabled, should not get the Dashboard CR %v", "dashboard", tc.testDashboardInstance.Name)
} else if !k8serr.IsNotFound(err) {
return err
}

// Sleep for 20 seconds to allow the operator to reconcile
Expand Down

0 comments on commit b1bb237

Please sign in to comment.