Skip to content

Commit

Permalink
reintroduce child context with cancel along with CloseAndRecv to forc…
Browse files Browse the repository at this point in the history
…e goroutine cleanup by not interrupt UpdateLog call before it finishes

rh-pre-commit.version: 2.2.0
rh-pre-commit.check-secrets: ENABLED
  • Loading branch information
gabemontero committed Apr 11, 2024
1 parent 00da9e6 commit 4b55355
Showing 1 changed file with 7 additions and 4 deletions.
11 changes: 7 additions & 4 deletions pkg/watcher/reconciler/dynamic/dynamic.go
Original file line number Diff line number Diff line change
Expand Up @@ -500,13 +500,16 @@ func (r *Reconciler) getPodLogs(ctx context.Context, ns, pod, container, labelKe
}

func (r *Reconciler) streamLogs(ctx context.Context, o results.Object, labelKey, logName string) error {
logger := logging.FromContext(ctx)
// TODO consider making configurable after we get some real world usage feedback
streamCtx, streamCancel := context.WithTimeout(ctx, 5*time.Minute)
defer streamCancel()
logger := logging.FromContext(streamCtx)
logger.Debugw("Streaming log started",
zap.String("namespace", o.GetNamespace()),
zap.String("kind", o.GetObjectKind().GroupVersionKind().Kind),
zap.String("name", o.GetName()),
)
logsClient, err := r.resultsClient.UpdateLog(ctx)
logsClient, err := r.resultsClient.UpdateLog(streamCtx)
if err != nil {
return fmt.Errorf("failed to create UpdateLog client: %w", err)
}
Expand All @@ -519,7 +522,7 @@ func (r *Reconciler) streamLogs(ctx context.Context, o results.Object, labelKey,
LabelSelector: fmt.Sprintf("%s=%s", labelKey, o.GetName()),
}
var pods *corev1.PodList
pods, err = r.kubernetesClientset.CoreV1().Pods(o.GetNamespace()).List(ctx, lo)
pods, err = r.kubernetesClientset.CoreV1().Pods(o.GetNamespace()).List(streamCtx, lo)
if err != nil {
return err
}
Expand All @@ -537,7 +540,7 @@ func (r *Reconciler) streamLogs(ctx context.Context, o results.Object, labelKey,
if len(task) == 0 {
task = pipelineTaskName
}
ba, podLogsErr := r.getPodLogs(ctx, o.GetNamespace(), pod.Name, container.Name, labelKey, task)
ba, podLogsErr := r.getPodLogs(streamCtx, o.GetNamespace(), pod.Name, container.Name, labelKey, task)
if podLogsErr != nil {
return podLogsErr
}
Expand Down

0 comments on commit 4b55355

Please sign in to comment.