Skip to content

Commit

Permalink
Show file tree
Hide file tree
Showing 18 changed files with 116 additions and 20 deletions.
15 changes: 12 additions & 3 deletions modules/certmanager/certificate.go
Original file line number Diff line number Diff line change
Expand Up @@ -112,16 +112,19 @@ func (c *Certificate) CreateOrPatch(
},
}

var currentOwner client.Object

op, err := controllerutil.CreateOrPatch(ctx, h.GetClient(), cert, func() error {
cert.Labels = util.MergeStringMaps(cert.Labels, c.certificate.Labels)
cert.Annotations = util.MergeStringMaps(cert.Annotations, c.certificate.Annotations)
cert.Spec = c.certificate.Spec

if owner != nil {
err = controllerutil.SetControllerReference(owner, cert, h.GetScheme())
currentOwner = owner
} else {
err = controllerutil.SetControllerReference(h.GetBeforeObject(), cert, h.GetScheme())
currentOwner = h.GetBeforeObject()
}
err = controllerutil.SetControllerReference(currentOwner, cert, h.GetScheme())
if err != nil {
return err
}
Expand All @@ -133,8 +136,14 @@ func (c *Certificate) CreateOrPatch(
h.GetLogger().Info(fmt.Sprintf("Certificate %s not found, reconcile in %s", cert.Name, c.timeout))
return ctrl.Result{RequeueAfter: c.timeout}, nil
}
h.GetRecorder().Event(currentOwner, k8s_corev1.EventTypeWarning, "Error", fmt.Sprintf("error create/updating certificate: %s", c.certificate.Name))
return ctrl.Result{}, err
}

if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(currentOwner, k8s_corev1.EventTypeNormal, "Created", fmt.Sprintf("certificate %s created", c.certificate.Name))
}

if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("Route %s - %s", cert.Name, op))
}
Expand All @@ -152,7 +161,7 @@ func (c *Certificate) Delete(
if err != nil && !k8s_errors.IsNotFound(err) {
return fmt.Errorf("Error deleting certificate %s: %w", c.certificate.Name, err)
}

h.GetRecorder().Event(h.GetBeforeObject(), k8s_corev1.EventTypeNormal, "CertificateDeleted", fmt.Sprintf("certificate: %s deleted", c.certificate.Name))
return nil
}

Expand Down
9 changes: 8 additions & 1 deletion modules/certmanager/issuer.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import (
"github.com/openstack-k8s-operators/lib-common/modules/common/helper"
"github.com/openstack-k8s-operators/lib-common/modules/common/util"
appsv1 "k8s.io/api/apps/v1"
corev1 "k8s.io/api/core/v1"
k8s_errors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
Expand Down Expand Up @@ -133,8 +134,14 @@ func (i *Issuer) CreateOrPatch(
h.GetLogger().Info(fmt.Sprintf("Issuer %s not found, reconcile in %s", issuer.Name, i.timeout))
return ctrl.Result{RequeueAfter: i.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "IssuerError", fmt.Sprintf("error create/updating issuer: %s", i.issuer.Name))
return ctrl.Result{}, err
}

if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "IssuerCreated", fmt.Sprintf("issuer %s created", i.issuer.Name))
}

if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("Issuer %s - %s", issuer.Name, op))
}
Expand All @@ -152,7 +159,7 @@ func (i *Issuer) Delete(
if err != nil && !k8s_errors.IsNotFound(err) {
return fmt.Errorf("Error deleting issuer %s: %w", i.issuer.Name, err)
}

h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "IssuerDeleted", fmt.Sprintf("issuer: %s deleted", i.issuer.Name))
return nil
}

Expand Down
6 changes: 5 additions & 1 deletion modules/certmanager/test/functional/suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ var (
logger logr.Logger
h *helper.Helper
th *certmanager_test.TestHelper
mgr ctrl.Manager
namespace string
names Names
)
Expand Down Expand Up @@ -117,6 +118,8 @@ var _ = BeforeSuite(func() {
Expect(k8sClient).NotTo(BeNil())
th = certmanager_test.NewTestHelper(ctx, k8sClient, timeout, interval, logger)
Expect(th).NotTo(BeNil())
mgr, err = ctrl.NewManager(cfg, ctrl.Options{})
Expect(err).NotTo(HaveOccurred())

go func() {
defer GinkgoRecover()
Expand Down Expand Up @@ -148,7 +151,8 @@ var _ = BeforeEach(func() {
// Note(mschuppert) using a Secret as a Namespace object does not have
// metadata with namespace and some functions use the BeforeObject.GetNamespace()
genericObject := th.CreateSecret(types.NamespacedName{Name: "generic", Namespace: namespace}, map[string][]byte{})
h, err = helper.NewHelper(genericObject, k8sClient, kclient, testEnv.Scheme, ctrl.Log)
recorder := mgr.GetEventRecorderFor("test")
h, err = helper.NewHelper(genericObject, k8sClient, kclient, testEnv.Scheme, ctrl.Log, recorder)
Expect(err).NotTo(HaveOccurred())
Expect(h).NotTo(BeNil())

Expand Down
4 changes: 4 additions & 0 deletions modules/common/configmap/configmap.go
Original file line number Diff line number Diff line change
Expand Up @@ -105,8 +105,12 @@ func createOrPatchConfigMap(
return nil
})
if err != nil {
h.GetRecorder().Event(obj, corev1.EventTypeWarning, "ConfigMapError", fmt.Sprintf("error create/updating configmap: %s", cm.Name))
return "", op, fmt.Errorf("error create/updating configmap: %w", err)
}
if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(obj, corev1.EventTypeNormal, "ConfigMapCreated", fmt.Sprintf("configmap %s created", cm.Name))
}

configMapHash, err := Hash(configMap)
if err != nil {
Expand Down
7 changes: 6 additions & 1 deletion modules/common/cronjob/cronjob.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import (
"time"

batchv1 "k8s.io/api/batch/v1"
corev1 "k8s.io/api/core/v1"
k8s_errors "k8s.io/apimachinery/pkg/api/errors"
"k8s.io/apimachinery/pkg/types"

Expand Down Expand Up @@ -63,8 +64,12 @@ func (cj *CronJob) CreateOrPatch(
h.GetLogger().Info(fmt.Sprintf("CronJob %s not found, reconcile in %s", cj.cronjob.Name, cj.timeout))
return ctrl.Result{RequeueAfter: cj.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "CronJobError", fmt.Sprintf("error create/updating cronjob: %s", cj.cronjob.Name))
return ctrl.Result{}, err
}
if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "CronJobCreated", fmt.Sprintf("cronjob %s created", cj.cronjob.Name))
}
if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("CronJob %s - %s", cj.cronjob.Name, op))
}
Expand All @@ -81,7 +86,7 @@ func (cj *CronJob) Delete(
if err != nil && !k8s_errors.IsNotFound(err) {
return fmt.Errorf("Error deleting cronjob %s: %w", cj.cronjob.Name, err)
}

h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "CronJobDeleted", fmt.Sprintf("cronjob: %s deleted", cj.cronjob.Name))
return nil
}

Expand Down
7 changes: 6 additions & 1 deletion modules/common/daemonset/daemonset.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import (
"github.com/openstack-k8s-operators/lib-common/modules/common/helper"
"github.com/openstack-k8s-operators/lib-common/modules/common/util"
appsv1 "k8s.io/api/apps/v1"
corev1 "k8s.io/api/core/v1"
k8s_errors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
Expand Down Expand Up @@ -76,8 +77,12 @@ func (d *DaemonSet) CreateOrPatch(
util.LogForObject(h, fmt.Sprintf("DaemonSet not found, reconcile in %s", d.timeout), daemonset)
return ctrl.Result{RequeueAfter: d.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "DaemonSetError", fmt.Sprintf("error create/updating daemonset: %s", d.daemonset.Name))
return ctrl.Result{}, err
}
if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "DaemonSetCreated", fmt.Sprintf("daemonset %s created", d.daemonset.Name))
}
if op != controllerutil.OperationResultNone {
util.LogForObject(h, fmt.Sprintf("DaemonSet: %s", op), daemonset)
}
Expand All @@ -103,7 +108,7 @@ func (d *DaemonSet) Delete(
if err != nil && !k8s_errors.IsNotFound(err) {
return fmt.Errorf("error deleting daemonset %s: %w", d.daemonset.Name, err)
}

h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "DaemonSetDeleted", fmt.Sprintf("daemonset: %s deleted", d.daemonset.Name))
return nil
}

Expand Down
7 changes: 6 additions & 1 deletion modules/common/deployment/deployment.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import (
"github.com/openstack-k8s-operators/lib-common/modules/common/helper"
"github.com/openstack-k8s-operators/lib-common/modules/common/util"
appsv1 "k8s.io/api/apps/v1"
corev1 "k8s.io/api/core/v1"
k8s_errors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
Expand Down Expand Up @@ -78,8 +79,12 @@ func (d *Deployment) CreateOrPatch(
h.GetLogger().Info(fmt.Sprintf("Deployment %s not found, reconcile in %s", deployment.Name, d.timeout))
return ctrl.Result{RequeueAfter: d.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "DeploymentError", fmt.Sprintf("error create/updating deployment: %s", d.deployment.Name))
return ctrl.Result{}, err
}
if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "DeploymentCreated", fmt.Sprintf("deployment %s created", d.deployment.Name))
}
if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("Deployment %s - %s", deployment.Name, op))
}
Expand All @@ -102,7 +107,7 @@ func (d *Deployment) Delete(
if err != nil && !k8s_errors.IsNotFound(err) {
return fmt.Errorf("Error deleting deployment %s: %w", d.deployment.Name, err)
}

h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "DeploymentDeleted", fmt.Sprintf("deployment: %s deleted", d.deployment.Name))
return nil
}

Expand Down
10 changes: 9 additions & 1 deletion modules/common/helper/helper.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import (
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/runtime/schema"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/tools/record"

"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/controller-runtime/pkg/client/apiutil"
Expand All @@ -40,6 +41,7 @@ type Helper struct {
kclient kubernetes.Interface
gvk schema.GroupVersionKind
scheme *runtime.Scheme
recorder record.EventRecorder
beforeObject client.Object
before *unstructured.Unstructured
after *unstructured.Unstructured
Expand All @@ -50,7 +52,7 @@ type Helper struct {
}

// NewHelper returns an initialized Helper.
func NewHelper(obj client.Object, crClient client.Client, kclient kubernetes.Interface, scheme *runtime.Scheme, log logr.Logger) (*Helper, error) {
func NewHelper(obj client.Object, crClient client.Client, kclient kubernetes.Interface, scheme *runtime.Scheme, log logr.Logger, recorder record.EventRecorder) (*Helper, error) {
// Get the GroupVersionKind of the object,
// used to validate against later on.
gvk, err := apiutil.GVKForObject(obj, crClient.Scheme())
Expand All @@ -69,6 +71,7 @@ func NewHelper(obj client.Object, crClient client.Client, kclient kubernetes.Int
kclient: kclient,
gvk: gvk,
scheme: scheme,
recorder: recorder,
before: unstructuredObj,
beforeObject: obj.DeepCopyObject().(client.Object),
logger: log,
Expand Down Expand Up @@ -96,6 +99,11 @@ func (h *Helper) GetScheme() *runtime.Scheme {
return h.scheme
}

// GetRecorder - returns the event recorder of the object
func (h *Helper) GetRecorder() record.EventRecorder {
return h.recorder
}

// GetAfter - returns unstructured object after modification
func (h *Helper) GetAfter() *unstructured.Unstructured {
return h.after
Expand Down
7 changes: 6 additions & 1 deletion modules/common/job/job.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import (
"time"

batchv1 "k8s.io/api/batch/v1"
corev1 "k8s.io/api/core/v1"
k8s_errors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
Expand Down Expand Up @@ -79,9 +80,13 @@ func (j *Job) createJob(
h.GetLogger().Info(fmt.Sprintf("Job %s not found, reconcile in %s", job.Name, j.timeout))
return ctrl.Result{RequeueAfter: j.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "JobError", fmt.Sprintf("error create/updating job: %s", j.expectedJob.Name))
h.GetLogger().Error(err, "Job CreateOrPatch failed", "job", job.Name)
return ctrl.Result{}, err
}
if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "JobCreated", fmt.Sprintf("job %s created", j.expectedJob.Name))
}
j.actualJob = job
if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("Job %s %s - %s", j.jobType, job.Name, op))
Expand Down Expand Up @@ -225,7 +230,7 @@ func DeleteJob(
if err != nil && !k8s_errors.IsNotFound(err) {
return err
}

h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "JobDeleted", fmt.Sprintf("job: %s deleted", name))
return nil
}

Expand Down
5 changes: 4 additions & 1 deletion modules/common/pvc/pvc.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,9 +82,12 @@ func (p *Pvc) CreateOrPatch(
h.GetLogger().Info(fmt.Sprintf("Pvc %s not found, reconcile in %s", pvc.Name, p.timeout))
return ctrl.Result{RequeueAfter: p.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "PvcError", fmt.Sprintf("error create/updating pvc: %s", p.pvc.Name))
return ctrl.Result{}, err
}

if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "PvcCreated", fmt.Sprintf("pvc %s created", p.pvc.Name))
}
if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("Pvc %s - %s", pvc.Name, op))
}
Expand Down
7 changes: 6 additions & 1 deletion modules/common/role/role.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import (
rbacv1 "k8s.io/api/rbac/v1"
"sigs.k8s.io/controller-runtime/pkg/controller/controllerutil"

corev1 "k8s.io/api/core/v1"
k8s_errors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
ctrl "sigs.k8s.io/controller-runtime"
Expand Down Expand Up @@ -70,12 +71,16 @@ func (r *Role) CreateOrPatch(
h.GetLogger().Info(fmt.Sprintf("Role %s not found, reconcile in %s", role.Name, r.timeout))
return ctrl.Result{RequeueAfter: r.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "RoleError", fmt.Sprintf("error create/updating role: %s", r.role.Name))
return ctrl.Result{}, util.WrapErrorForObject(
fmt.Sprintf("Error creating role %s", role.Name),
role,
err,
)
}
if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "RoleCreated", fmt.Sprintf("role %s created", r.role.Name))
}
if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("Role %s - %s", role.Name, op))
}
Expand All @@ -94,6 +99,6 @@ func (r *Role) Delete(
err = fmt.Errorf("Error deleting role %s: %w", r.role.Name, err)
return err
}

h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "RoleDeleted", fmt.Sprintf("role: %s deleted", r.role.Name))
return nil
}
9 changes: 7 additions & 2 deletions modules/common/rolebinding/rolebinding.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import (
rbacv1 "k8s.io/api/rbac/v1"
"sigs.k8s.io/controller-runtime/pkg/controller/controllerutil"

corev1 "k8s.io/api/core/v1"
k8s_errors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
ctrl "sigs.k8s.io/controller-runtime"
Expand Down Expand Up @@ -73,12 +74,16 @@ func (r *RoleBinding) CreateOrPatch(
h.GetLogger().Info(fmt.Sprintf("RoleBinding %s not found, reconcile in %s", rb.Name, r.timeout))
return ctrl.Result{RequeueAfter: r.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "RoleBindingError", fmt.Sprintf("error create/updating rolebinding: %s", r.roleBinding.Name))
return ctrl.Result{}, util.WrapErrorForObject(
fmt.Sprintf("Error creating rol binding %s", rb.Name),
fmt.Sprintf("Error creating role binding %s", rb.Name),
rb,
err,
)
}
if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "RoleBindingCreated", fmt.Sprintf("rolebinding %s created", r.roleBinding.Name))
}
if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("RoleBinding %s - %s", rb.Name, op))
}
Expand All @@ -97,6 +102,6 @@ func (r *RoleBinding) Delete(
err = fmt.Errorf("Error deleting roleBinding %s: %w", r.roleBinding.Name, err)
return err
}

h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "RoleBindingDeleted", fmt.Sprintf("rolebinding: %s deleted", r.roleBinding.Name))
return nil
}
7 changes: 6 additions & 1 deletion modules/common/route/route.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ import (
"github.com/openstack-k8s-operators/lib-common/modules/common/util"
"sigs.k8s.io/controller-runtime/pkg/controller/controllerutil"

corev1 "k8s.io/api/core/v1"
k8s_errors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/util/intstr"
Expand Down Expand Up @@ -164,8 +165,12 @@ func (r *Route) CreateOrPatch(
h.GetLogger().Info(fmt.Sprintf("Route %s not found, reconcile in %s", route.Name, r.timeout))
return ctrl.Result{RequeueAfter: r.timeout}, nil
}
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeWarning, "RouteError", fmt.Sprintf("error create/updating route: %s", r.route.Name))
return ctrl.Result{}, err
}
if op == controllerutil.OperationResultCreated {
h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "RouteCreated", fmt.Sprintf("route %s created", r.route.Name))
}
if op != controllerutil.OperationResultNone {
h.GetLogger().Info(fmt.Sprintf("Route %s - %s", route.Name, op))
}
Expand All @@ -186,7 +191,7 @@ func (r *Route) Delete(
if err != nil && !k8s_errors.IsNotFound(err) {
return fmt.Errorf("Error deleting route %s: %w", r.route.Name, err)
}

h.GetRecorder().Event(h.GetBeforeObject(), corev1.EventTypeNormal, "RouteDeleted", fmt.Sprintf("route: %s deleted", r.route.Name))
return nil
}

Expand Down
Loading

0 comments on commit c3153b2

Please sign in to comment.