From 4be7b843d053e81947da4f16aa5550fce1c9c488 Mon Sep 17 00:00:00 2001 From: Nick Hale <4175918+njhale@users.noreply.github.com> Date: Mon, 17 Jul 2023 15:06:42 -0400 Subject: [PATCH] Add top-level appName field to events Add an optional appName field to events to support referencing associated Acorns Signed-off-by: Nick Hale <4175918+njhale@users.noreply.github.com> --- pkg/apis/internal.acorn.io/v1/event.go | 4 ++++ pkg/controller/appdefinition/pullappimage.go | 1 + pkg/controller/appdefinition/pullappimage_test.go | 10 +++++++--- pkg/server/registry/apigroups/acorn/apps/events.go | 3 +++ 4 files changed, 15 insertions(+), 3 deletions(-) diff --git a/pkg/apis/internal.acorn.io/v1/event.go b/pkg/apis/internal.acorn.io/v1/event.go index 5ecb71271..bfb725606 100644 --- a/pkg/apis/internal.acorn.io/v1/event.go +++ b/pkg/apis/internal.acorn.io/v1/event.go @@ -36,6 +36,10 @@ type EventInstance struct { // +optional Actor string `json:"actor,omitempty"` + // AppName is the name of the app that the event is related to, if any. + // +optional + AppName string `json:"appName,omitempty"` + // Source identifies the object the Event is regarding. Source EventSource `json:"source"` diff --git a/pkg/controller/appdefinition/pullappimage.go b/pkg/controller/appdefinition/pullappimage.go index 10a4949c9..404f6cde8 100644 --- a/pkg/controller/appdefinition/pullappimage.go +++ b/pkg/controller/appdefinition/pullappimage.go @@ -210,6 +210,7 @@ func recordPullEvent(ctx context.Context, recorder event.Recorder, observed meta Type: AppImagePullSuccessEventType, Severity: v1.EventSeverityInfo, Description: fmt.Sprintf("Pulled %s", target.Name), + AppName: obj.GetName(), Source: event.ObjectSource(obj), Observed: v1.MicroTime(observed), } diff --git a/pkg/controller/appdefinition/pullappimage_test.go b/pkg/controller/appdefinition/pullappimage_test.go index 2fa54b02e..8acda8dbd 100644 --- a/pkg/controller/appdefinition/pullappimage_test.go +++ b/pkg/controller/appdefinition/pullappimage_test.go @@ -107,8 +107,9 @@ func TestPullAppImageEvents(t *testing.T) { Type: AppImagePullSuccessEventType, Severity: v1.EventSeverityInfo, Description: "Pulled acorn.io/img:1", + AppName: "foo", Source: v1.EventSource{Kind: "app", Name: "foo", UID: types.UID("foo-uid")}, - Observed: v1.MicroTime(now), + Observed: now, Details: mustMapify(t, AppImagePullEventDetails{ ResourceVersion: "1", AutoUpgrade: false, @@ -129,8 +130,9 @@ func TestPullAppImageEvents(t *testing.T) { Type: AppImagePullSuccessEventType, Severity: v1.EventSeverityInfo, Description: "Pulled acorn.io/img:1", + AppName: "foo", Source: v1.EventSource{Kind: "app", Name: "foo"}, - Observed: v1.MicroTime(now), + Observed: now, Details: mustMapify(t, AppImagePullEventDetails{ AutoUpgrade: true, Previous: ImageSummary{Name: "acorn.io/img:1"}, @@ -149,8 +151,9 @@ func TestPullAppImageEvents(t *testing.T) { Type: AppImagePullSuccessEventType, Severity: v1.EventSeverityInfo, Description: "Pulled acorn.io/img:1", + AppName: "foo", Source: v1.EventSource{Kind: "app", Name: "foo"}, - Observed: v1.MicroTime(now), + Observed: now, Details: mustMapify(t, AppImagePullEventDetails{ AutoUpgrade: true, Target: ImageSummary{Name: "acorn.io/img:1"}, @@ -169,6 +172,7 @@ func TestPullAppImageEvents(t *testing.T) { Type: AppImagePullFailureEventType, Severity: v1.EventSeverityError, Description: "Failed to pull acorn.io/img:1", + AppName: "foo", Source: v1.EventSource{Kind: "app", Name: "foo"}, Observed: now, Details: mustMapify(t, AppImagePullEventDetails{ diff --git a/pkg/server/registry/apigroups/acorn/apps/events.go b/pkg/server/registry/apigroups/acorn/apps/events.go index 139684c73..a9abb8595 100644 --- a/pkg/server/registry/apigroups/acorn/apps/events.go +++ b/pkg/server/registry/apigroups/acorn/apps/events.go @@ -82,6 +82,7 @@ func (s *eventRecordingStrategy) Create(ctx context.Context, obj types.Object) ( Severity: v1.EventSeverityInfo, Details: details, Description: fmt.Sprintf("App %s/%s created", obj.GetNamespace(), obj.GetName()), + AppName: obj.GetName(), Source: event.ObjectSource(obj), Observed: v1.MicroTime(metav1.NowMicro()), }); err != nil { @@ -115,6 +116,7 @@ func (s *eventRecordingStrategy) Delete(ctx context.Context, obj types.Object) ( Severity: v1.EventSeverityInfo, Details: details, Description: fmt.Sprintf("App %s/%s deleted", obj.GetNamespace(), obj.GetName()), + AppName: obj.GetName(), Source: event.ObjectSource(obj), Observed: v1.MicroTime(metav1.NowMicro()), }); err != nil { @@ -169,6 +171,7 @@ func (s *eventRecordingStrategy) Update(ctx context.Context, obj types.Object) ( Severity: v1.EventSeverityInfo, Details: details, Description: fmt.Sprintf("Spec field updated for App %s/%s", obj.GetNamespace(), obj.GetName()), + AppName: obj.GetName(), Source: event.ObjectSource(obj), Observed: v1.MicroTime(metav1.NowMicro()), }); err != nil {