From 50272284aac9ce3b335ba34ffb28f6be1c86c8d7 Mon Sep 17 00:00:00 2001 From: Stuart Douglas Date: Wed, 18 Dec 2024 07:55:48 +1100 Subject: [PATCH] fix: cron deployment key --- backend/cron/service.go | 31 ++++++++++++++++++++----------- backend/cron/service_test.go | 5 +++++ 2 files changed, 25 insertions(+), 11 deletions(-) diff --git a/backend/cron/service.go b/backend/cron/service.go index 9d55f1535..7597d618e 100644 --- a/backend/cron/service.go +++ b/backend/cron/service.go @@ -22,11 +22,12 @@ import ( ) type cronJob struct { - module string - verb *schema.Verb - cronmd *schema.MetadataCronJob - pattern cron.Pattern - next time.Time + module string + deployment model.DeploymentKey + verb *schema.Verb + cronmd *schema.MetadataCronJob + pattern cron.Pattern + next time.Time } type Config struct { @@ -133,7 +134,7 @@ func scheduleNext(ctx context.Context, cronQueue []cronJob, timelineClient *time return 0, false } timelineClient.Publish(ctx, timeline.CronScheduled{ - DeploymentKey: model.NewDeploymentKey(cronQueue[0].module), + DeploymentKey: cronQueue[0].deployment, Verb: schema.Ref{Module: cronQueue[0].module, Name: cronQueue[0].verb.Name}, ScheduledAt: cronQueue[0].next, Schedule: cronQueue[0].pattern.String(), @@ -182,6 +183,9 @@ func rebuildQueue(cronJobs map[string][]cronJob) []cronJob { } func extractCronJobs(module *schema.Module) ([]cronJob, error) { + if module.Runtime == nil || module.Runtime.Deployment == nil { + return nil, nil + } cronJobs := []cronJob{} for verb := range slices.FilterVariants[*schema.Verb](module.Decls) { cronmd, ok := slices.FindVariant[*schema.MetadataCronJob](verb.Metadata) @@ -196,12 +200,17 @@ func extractCronJobs(module *schema.Module) ([]cronJob, error) { if err != nil { return nil, fmt.Errorf("%s: %w", cronmd.Pos, err) } + deploymentKey, err := model.ParseDeploymentKey(module.Runtime.Deployment.DeploymentKey) + if err != nil { + return nil, fmt.Errorf("%s: %w", cronmd.Pos, err) + } cronJobs = append(cronJobs, cronJob{ - module: module.Name, - verb: verb, - cronmd: cronmd, - pattern: pattern, - next: next, + module: module.Name, + deployment: deploymentKey, + verb: verb, + cronmd: cronmd, + pattern: pattern, + next: next, }) } return cronJobs, nil diff --git a/backend/cron/service_test.go b/backend/cron/service_test.go index 4f10f6a02..8fe5f7fff 100644 --- a/backend/cron/service_test.go +++ b/backend/cron/service_test.go @@ -39,6 +39,11 @@ func TestCron(t *testing.T) { eventSource := schemaeventsource.NewUnattached() module := &schema.Module{ Name: "echo", + Runtime: &schema.ModuleRuntime{ + Deployment: &schema.ModuleRuntimeDeployment{ + DeploymentKey: model.NewDeploymentKey("echo").String(), + }, + }, Decls: []schema.Decl{ &schema.Verb{ Name: "echo",