Skip to content

Commit

Permalink
Check milvus pod stopped before finalize
Browse files Browse the repository at this point in the history
Signed-off-by: shaoyue.chen <[email protected]>
  • Loading branch information
haorenfsa committed Oct 18, 2023
1 parent f4c56c8 commit 8f62a47
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 2 deletions.
2 changes: 1 addition & 1 deletion pkg/controllers/component_condition.go
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,7 @@ func GetComponentConditionGetter() ComponentConditionGetter {

var singletonComponentConditionGetter ComponentConditionGetter = ComponentConditionGetterImpl{}

func CheckMilvusStopped(ctx context.Context, cli client.Client, mc v1beta1.Milvus) (bool, error) {
var CheckMilvusStopped = func(ctx context.Context, cli client.Client, mc v1beta1.Milvus) (bool, error) {
podList := &corev1.PodList{}
opts := &client.ListOptions{
Namespace: mc.Namespace,
Expand Down
5 changes: 5 additions & 0 deletions pkg/controllers/milvus_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,11 @@ func (r *MilvusReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctr
}
}

stopped, err := CheckMilvusStopped(ctx, r.Client, *milvus)
if !stopped || err != nil {
return ctrl.Result{RequeueAfter: unhealthySyncInterval}, err
}

if controllerutil.ContainsFinalizer(milvus, MilvusFinalizerName) {
if err := r.Finalize(ctx, *milvus); err != nil {
return ctrl.Result{}, err
Expand Down
36 changes: 35 additions & 1 deletion pkg/controllers/milvus_controller_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import (
"github.com/pkg/errors"
"github.com/stretchr/testify/assert"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/controller-runtime/pkg/reconcile"

"github.com/milvus-io/milvus-operator/apis/milvus.io/v1beta1"
Expand All @@ -17,7 +18,19 @@ import (
"github.com/milvus-io/milvus-operator/pkg/util"
)

var mockCheckMilvusStopRet = false
var mockCheckMilvusStopErr error = nil
var mockCheckMilvusStop = func(ctx context.Context, cli client.Client, mc v1beta1.Milvus) (bool, error) {
return mockCheckMilvusStopRet, mockCheckMilvusStopErr
}

func TestClusterReconciler(t *testing.T) {
bak := CheckMilvusStopped
defer func() {
CheckMilvusStopped = bak
}()
CheckMilvusStopped = mockCheckMilvusStop

config.Init(util.GetGitRepoRootDir())

ctrl := gomock.NewController(t)
Expand Down Expand Up @@ -65,7 +78,7 @@ func TestClusterReconciler(t *testing.T) {

t.Run("case delete remove finalizer", func(t *testing.T) {
defer ctrl.Finish()

mockCheckMilvusStopRet = true
m.ObjectMeta.DeletionTimestamp = &metav1.Time{Time: time.Now()}
mockClient.EXPECT().Get(gomock.Any(), gomock.Any(), gomock.Any()).
Do(func(ctx, key, obj interface{}) {
Expand All @@ -88,6 +101,27 @@ func TestClusterReconciler(t *testing.T) {
_, err := r.Reconcile(ctx, reconcile.Request{})
assert.NoError(t, err)
})

t.Run("milvus not stopped or check failed", func(t *testing.T) {
defer ctrl.Finish()
mockClient.EXPECT().Get(gomock.Any(), gomock.Any(), gomock.Any()).
Do(func(ctx, key, obj interface{}) {
o := obj.(*v1beta1.Milvus)
*o = m
}).
Return(nil).Times(2)

mockCheckMilvusStopRet = false
m.Status.Status = v1beta1.StatusDeleting
m.ObjectMeta.DeletionTimestamp = &metav1.Time{Time: time.Now()}
_, err := r.Reconcile(ctx, reconcile.Request{})
assert.NoError(t, err)

mockCheckMilvusStopErr = errMock
ret, err := r.Reconcile(ctx, reconcile.Request{})
assert.Error(t, err)
assert.True(t, ret.RequeueAfter > 0)
})
}

func TestMilvusReconciler_ReconcileLegacyValues(t *testing.T) {
Expand Down

0 comments on commit 8f62a47

Please sign in to comment.