From be652f46bc111f36ac5b6bde93c94434592b38cb Mon Sep 17 00:00:00 2001 From: Jian Qiu Date: Thu, 22 Oct 2020 08:50:12 +0800 Subject: [PATCH] Fix bma status when using patch in syncset --- .../inventory/inventory_controller.go | 29 ++++++++++++++----- 1 file changed, 22 insertions(+), 7 deletions(-) diff --git a/pkg/controllers/inventory/inventory_controller.go b/pkg/controllers/inventory/inventory_controller.go index 23a2fdda0..429cc260e 100644 --- a/pkg/controllers/inventory/inventory_controller.go +++ b/pkg/controllers/inventory/inventory_controller.go @@ -689,20 +689,35 @@ func (r *ReconcileBareMetalAsset) checkHiveSyncStatus( Type: inventoryv1alpha1.ConditionAssetSyncCompleted, Status: metav1.ConditionFalse, Reason: "SyncSetAppliedFailed", - Message: "Failed to apply SyncSet", + Message: fmt.Sprintf("Failed to apply SyncSet with err %s", syncSetStatus.FailureMessage), }) return false } if patchCount == 1 { - if syncSetStatus.Result == hiveinternalv1alpha1.FailureSyncSetResult { - if strings.Contains(syncSetStatus.FailureMessage, "not found") { - if r.client.Delete(context.TODO(), syncSet) != nil { - klog.Errorf("Failed to delete syncSet %v", instance.Name) - } + if syncSetStatus.Result == hiveinternalv1alpha1.SuccessSyncSetResult { + meta.SetStatusCondition(&instance.Status.Conditions, metav1.Condition{ + Type: inventoryv1alpha1.ConditionAssetSyncCompleted, + Status: metav1.ConditionTrue, + Reason: "SyncSetAppliedSuccessful", + Message: "Successfully applied SyncSet", + }) + return true + } + + meta.SetStatusCondition(&instance.Status.Conditions, metav1.Condition{ + Type: inventoryv1alpha1.ConditionAssetSyncCompleted, + Status: metav1.ConditionFalse, + Reason: "SyncSetAppliedFailed", + Message: fmt.Sprintf("Failed to apply SyncSet with err %s", syncSetStatus.FailureMessage), + }) + + if strings.Contains(syncSetStatus.FailureMessage, "not found") { + if r.client.Delete(context.TODO(), syncSet) != nil { + klog.Errorf("Failed to delete syncSet %v", instance.Name) } - return false } + return false } err := fmt.Errorf(