|
|
@@ -47,7 +47,7 @@ func (s *composeService) start(ctx context.Context, project *types.Project, opti
|
|
|
}
|
|
|
|
|
|
eg.Go(func() error {
|
|
|
- return s.watchContainers(project.Name, options.AttachTo, listener, attached, func(container moby.Container) error {
|
|
|
+ return s.watchContainers(ctx, project.Name, options.AttachTo, listener, attached, func(container moby.Container) error {
|
|
|
return s.attachContainer(ctx, container, listener, project)
|
|
|
})
|
|
|
})
|
|
|
@@ -69,13 +69,13 @@ func (s *composeService) start(ctx context.Context, project *types.Project, opti
|
|
|
type containerWatchFn func(container moby.Container) error
|
|
|
|
|
|
// watchContainers uses engine events to capture container start/die and notify ContainerEventListener
|
|
|
-func (s *composeService) watchContainers(projectName string, services []string, listener api.ContainerEventListener, containers Containers, onStart containerWatchFn) error {
|
|
|
+func (s *composeService) watchContainers(ctx context.Context, projectName string, services []string, listener api.ContainerEventListener, containers Containers, onStart containerWatchFn) error {
|
|
|
watched := map[string]int{}
|
|
|
for _, c := range containers {
|
|
|
watched[c.ID] = 0
|
|
|
}
|
|
|
|
|
|
- ctx, stop := context.WithCancel(context.Background())
|
|
|
+ ctx, stop := context.WithCancel(ctx)
|
|
|
err := s.Events(ctx, projectName, api.EventsOptions{
|
|
|
Services: services,
|
|
|
Consumer: func(event api.Event) error {
|