Ensure images exist before starting progress display for network / volumes, otherwise progress display is all mixed up

Signed-off-by: Guillaume Tardif <guillaume.tardif@gmail.com>
This commit is contained in:
Guillaume Tardif 2020-12-14 17:55:55 +01:00
parent 53ee1418af
commit d127cac6d4
1 changed files with 6 additions and 8 deletions

View File

@ -30,8 +30,11 @@ import (
) )
func (s *composeService) CreateOneOffContainer(ctx context.Context, project *types.Project, opts compose.RunOptions) (string, error) { func (s *composeService) CreateOneOffContainer(ctx context.Context, project *types.Project, opts compose.RunOptions) (string, error) {
name := opts.Name service, err := project.GetService(opts.Name)
service, err := project.GetService(name) if err != nil {
return "", err
}
err = s.ensureImagesExists(ctx, project)
if err != nil { if err != nil {
return "", err return "", err
} }
@ -133,12 +136,7 @@ func updateOneOffServiceConfig(service *types.ServiceConfig, projectName string,
} }
func (s *composeService) ensureRequiredServices(ctx context.Context, project *types.Project, service types.ServiceConfig) error { func (s *composeService) ensureRequiredServices(ctx context.Context, project *types.Project, service types.ServiceConfig) error {
err := s.ensureImagesExists(ctx, project) err := InDependencyOrder(ctx, project, func(c context.Context, svc types.ServiceConfig) error {
if err != nil {
return err
}
err = InDependencyOrder(ctx, project, func(c context.Context, svc types.ServiceConfig) error {
if svc.Name != service.Name { // only start dependencies, not service to run one-off if svc.Name != service.Name { // only start dependencies, not service to run one-off
return s.ensureService(c, project, svc) return s.ensureService(c, project, svc)
} }