Skip to content

Commit

Permalink
Fix sidekick pod create issue (#5)
Browse files Browse the repository at this point in the history
Signed-off-by: Mehedi Hasan <[email protected]>
  • Loading branch information
heheh13 authored Nov 6, 2023
1 parent a375154 commit 65b446e
Showing 1 changed file with 44 additions and 20 deletions.
64 changes: 44 additions & 20 deletions pkg/controllers/apps/sidekick_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import (
"regexp"
"sort"
"strconv"
"time"

appsv1alpha1 "kubeops.dev/sidekick/apis/apps/v1alpha1"

Expand All @@ -31,6 +32,7 @@ import (
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/runtime/schema"
"k8s.io/apimachinery/pkg/types"
"k8s.io/klog/v2"
"k8s.io/utils/pointer"
cu "kmodules.xyz/client-go/client"
core_util "kmodules.xyz/client-go/core/v1"
Expand All @@ -47,8 +49,9 @@ import (
)

const (
keyHash = "sidekick.appscode.com/hash"
keyLeader = "sidekick.appscode.com/leader"
keyHash = "sidekick.appscode.com/hash"
keyLeader = "sidekick.appscode.com/leader"
SidekickPhaseCurrent = "Current"
)

// SidekickReconciler reconciles a Sidekick object
Expand All @@ -71,6 +74,7 @@ type SidekickReconciler struct {
// For more details, check Reconcile and its Result here:
// - https://pkg.go.dev/sigs.k8s.io/[email protected]/pkg/reconcile
func (r *SidekickReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) {
klog.Infoln(fmt.Sprintf("reconciling %v ", req.NamespacedName))
logger := log.FromContext(ctx, "sidekick", req.Name, "ns", req.Namespace)
ctx = log.IntoContext(ctx, logger)

Expand Down Expand Up @@ -106,48 +110,65 @@ func (r *SidekickReconciler) Reconcile(ctx context.Context, req ctrl.Request) (c
var pod corev1.Pod
e2 := r.Get(ctx, req.NamespacedName, &pod)
if e2 == nil {
r.Delete(ctx, &pod) // TODO
err := r.Delete(ctx, &pod)
if err != nil {
return ctrl.Result{}, err
}

sidekick.Status.Leader.Name = ""
sidekick.Status.Pod = ""
sidekick.Status.Phase = "Current"
sidekick.Status.Phase = SidekickPhaseCurrent
sidekick.Status.ObservedGeneration = sidekick.GetGeneration()
r.Status().Update(ctx, &sidekick) // TODO
return ctrl.Result{}, nil // client.IgnoreNotFound(err)
err = r.Status().Update(ctx, &sidekick)
if err != nil {
return ctrl.Result{}, err
}
return ctrl.Result{}, nil
} else if err != nil {
return ctrl.Result{}, client.IgnoreNotFound(err)
return ctrl.Result{
Requeue: true,
RequeueAfter: time.Second * 10,
}, client.IgnoreNotFound(err)
}
} else if err != nil {
return ctrl.Result{}, client.IgnoreNotFound(err)
}

var pod corev1.Pod
e2 := r.Get(ctx, req.NamespacedName, &pod)
if e2 != nil && !errors.IsNotFound(e2) {
return ctrl.Result{}, client.IgnoreNotFound(err)
return ctrl.Result{}, client.IgnoreNotFound(e2)
}
if e2 == nil {
expectedHash := meta.GenerationHash(&sidekick)
actualHash := pod.Annotations[keyHash]
if expectedHash != actualHash ||
leader.Name != pod.Annotations[keyLeader] ||
leader.Spec.NodeName != pod.Spec.NodeName {
r.Delete(ctx, &pod) // TODO
err := r.Delete(ctx, &pod)
if err != nil {
return ctrl.Result{}, err
}

sidekick.Status.Leader.Name = ""
sidekick.Status.Pod = ""
sidekick.Status.Phase = "Current"
sidekick.Status.Phase = SidekickPhaseCurrent
sidekick.Status.ObservedGeneration = sidekick.GetGeneration()
r.Status().Update(ctx, &sidekick) // TODO
return ctrl.Result{}, nil // client.IgnoreNotFound(err)
err = r.Status().Update(ctx, &sidekick)
if err != nil {
return ctrl.Result{}, err
}
return ctrl.Result{}, nil
}

// sidekick.Status.Leader.Name = ""
sidekick.Status.Pod = pod.Status.Phase
sidekick.Status.Phase = "Current"
sidekick.Status.Phase = SidekickPhaseCurrent
sidekick.Status.ObservedGeneration = sidekick.GetGeneration()
r.Status().Update(ctx, &sidekick) // TODO
return ctrl.Result{}, nil // client.IgnoreNotFound(err)
err := r.Status().Update(ctx, &sidekick)
if err != nil {
return ctrl.Result{}, err
}
return ctrl.Result{}, nil
} else if !errors.IsNotFound(e2) {
return ctrl.Result{}, e2
}
Expand Down Expand Up @@ -236,10 +257,13 @@ func (r *SidekickReconciler) Reconcile(ctx context.Context, req ctrl.Request) (c

sidekick.Status.Leader.Name = leader.Name
sidekick.Status.Pod = pod.Status.Phase
sidekick.Status.Phase = "Current"
sidekick.Status.Phase = SidekickPhaseCurrent
sidekick.Status.ObservedGeneration = sidekick.GetGeneration()
r.Status().Update(ctx, &sidekick) // TODO
return ctrl.Result{}, nil // client.IgnoreNotFound(err)
err = r.Status().Update(ctx, &sidekick)
if err != nil {
return ctrl.Result{}, err
}
return ctrl.Result{}, nil
}

func convContainer(leader *corev1.Pod, c appsv1alpha1.Container) (*corev1.Container, error) {
Expand Down Expand Up @@ -268,7 +292,7 @@ func convContainer(leader *corev1.Pod, c appsv1alpha1.Container) (*corev1.Contai
TTY: c.TTY,
}
for _, vm := range c.VolumeMounts {
empty := vm.ReadOnly == false &&
empty := !vm.ReadOnly &&
vm.MountPath == "" &&
vm.SubPath == "" &&
vm.MountPropagation == nil &&
Expand Down

0 comments on commit 65b446e

Please sign in to comment.