From bd6c1b60f09907706683863187fe387e7e373c0e Mon Sep 17 00:00:00 2001 From: Claire McGinty Date: Thu, 9 Sep 2021 19:14:32 -0400 Subject: [PATCH] add composable PluginCleanupPolicy (flyteorg/flyte#1345) (#203) * add composable PluginCleanupPolicy Signed-off-by: Claire McGinty * fix generated mocks Signed-off-by: Claire McGinty * use PluginAbortOverride in PluginProperties Signed-off-by: Claire McGinty * Update go/tasks/pluginmachinery/k8s/plugin.go Co-authored-by: Haytham Abuelfutuh Signed-off-by: Claire McGinty * add custom constructors for AbortBehavior Signed-off-by: Claire McGinty * Apply Ketan's suggestions Signed-off-by: Claire McGinty * Apply suggestions from code review Co-authored-by: Haytham Abuelfutuh Signed-off-by: Claire McGinty * lint/goimports Signed-off-by: Claire McGinty Co-authored-by: Haytham Abuelfutuh --- .../k8s/mocks/plugin_abort_override.go | 59 ++++++++++++++++ go/tasks/pluginmachinery/k8s/plugin.go | 69 +++++++++++++++++++ 2 files changed, 128 insertions(+) create mode 100644 go/tasks/pluginmachinery/k8s/mocks/plugin_abort_override.go diff --git a/go/tasks/pluginmachinery/k8s/mocks/plugin_abort_override.go b/go/tasks/pluginmachinery/k8s/mocks/plugin_abort_override.go new file mode 100644 index 0000000000..41463d1039 --- /dev/null +++ b/go/tasks/pluginmachinery/k8s/mocks/plugin_abort_override.go @@ -0,0 +1,59 @@ +// Code generated by mockery v1.0.1. DO NOT EDIT. + +package mocks + +import ( + context "context" + + client "sigs.k8s.io/controller-runtime/pkg/client" + + core "github.com/flyteorg/flyteplugins/go/tasks/pluginmachinery/core" + + k8s "github.com/flyteorg/flyteplugins/go/tasks/pluginmachinery/k8s" + + mock "github.com/stretchr/testify/mock" +) + +// PluginAbortOverride is an autogenerated mock type for the PluginAbortOverride type +type PluginAbortOverride struct { + mock.Mock +} + +type PluginAbortOverride_OnAbort struct { + *mock.Call +} + +func (_m PluginAbortOverride_OnAbort) Return(behavior k8s.AbortBehavior, err error) *PluginAbortOverride_OnAbort { + return &PluginAbortOverride_OnAbort{Call: _m.Call.Return(behavior, err)} +} + +func (_m *PluginAbortOverride) OnOnAbort(ctx context.Context, tCtx core.TaskExecutionContext, resource client.Object) *PluginAbortOverride_OnAbort { + c := _m.On("OnAbort", ctx, tCtx, resource) + return &PluginAbortOverride_OnAbort{Call: c} +} + +func (_m *PluginAbortOverride) OnOnAbortMatch(matchers ...interface{}) *PluginAbortOverride_OnAbort { + c := _m.On("OnAbort", matchers...) + return &PluginAbortOverride_OnAbort{Call: c} +} + +// OnAbort provides a mock function with given fields: ctx, tCtx, resource +func (_m *PluginAbortOverride) OnAbort(ctx context.Context, tCtx core.TaskExecutionContext, resource client.Object) (k8s.AbortBehavior, error) { + ret := _m.Called(ctx, tCtx, resource) + + var r0 k8s.AbortBehavior + if rf, ok := ret.Get(0).(func(context.Context, core.TaskExecutionContext, client.Object) k8s.AbortBehavior); ok { + r0 = rf(ctx, tCtx, resource) + } else { + r0 = ret.Get(0).(k8s.AbortBehavior) + } + + var r1 error + if rf, ok := ret.Get(1).(func(context.Context, core.TaskExecutionContext, client.Object) error); ok { + r1 = rf(ctx, tCtx, resource) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} diff --git a/go/tasks/pluginmachinery/k8s/plugin.go b/go/tasks/pluginmachinery/k8s/plugin.go index 0a746c9919..8f83d4ee02 100644 --- a/go/tasks/pluginmachinery/k8s/plugin.go +++ b/go/tasks/pluginmachinery/k8s/plugin.go @@ -91,3 +91,72 @@ type Plugin interface { // Properties desired by the plugin GetProperties() PluginProperties } + +// An optional interface a Plugin can implement to override its default OnAbort finalizer (deletion of the underlying resource). +type PluginAbortOverride interface { + OnAbort(ctx context.Context, tCtx pluginsCore.TaskExecutionContext, resource client.Object) (behavior AbortBehavior, err error) +} + +// Defines the overridden OnAbort behavior. The resource (by default, the underlying resource, although this +// can be overridden) can be either patched, updated, or deleted. +type AbortBehavior struct { + // Optional override to the default k8s Resource being acted on. + Resource client.Object + DeleteResource bool + Update *UpdateResourceOperation + Patch *PatchResourceOperation + // Determines whether to delete the Resource if the specified operations return an error + DeleteOnErr bool +} + +// Defines a Patch operation on a Resource +type PatchResourceOperation struct { + Patch client.Patch + Options []client.PatchOption +} + +// Defines an Update operation on a Resource +type UpdateResourceOperation struct { + Options []client.UpdateOption +} + +// AbortBehavior that patches the default resource +func AbortBehaviorPatchDefaultResource(patchOperation PatchResourceOperation, deleteOnErr bool) AbortBehavior { + return AbortBehaviorPatch(patchOperation, deleteOnErr, nil) +} + +// AbortBehavior that patches the specified resource +func AbortBehaviorPatch(patchOperation PatchResourceOperation, deleteOnErr bool, resource client.Object) AbortBehavior { + return AbortBehavior{ + Resource: resource, + Patch: &patchOperation, + DeleteOnErr: deleteOnErr, + } +} + +// AbortBehavior that updates the default resource +func AbortBehaviorUpdateDefaultResource(updateOperation UpdateResourceOperation, deleteOnErr bool) AbortBehavior { + return AbortBehaviorUpdate(updateOperation, deleteOnErr, nil) +} + +// AbortBehavior that updates the specified resource +func AbortBehaviorUpdate(updateOperation UpdateResourceOperation, deleteOnErr bool, resource client.Object) AbortBehavior { + return AbortBehavior{ + Resource: resource, + Update: &updateOperation, + DeleteOnErr: deleteOnErr, + } +} + +// AbortBehavior that deletes the default resource +func AbortBehaviorDeleteDefaultResource() AbortBehavior { + return AbortBehaviorDelete(nil) +} + +// AbortBehavior that deletes the specified resource +func AbortBehaviorDelete(resource client.Object) AbortBehavior { + return AbortBehavior{ + Resource: resource, + DeleteResource: true, + } +}