From f5faf04bc569dc1394ccdac33b53d5e89ed80886 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Juho=20M=C3=A4kinen?= Date: Mon, 9 Dec 2024 14:04:05 +1100 Subject: [PATCH] fix: return startup errors properly (#3682) We were returning "context cancelled" error before getting the errgroup error that caused the context to be cancelled. --- frontend/cli/cmd_serve.go | 41 +++++++++++++++++++++------------------ 1 file changed, 22 insertions(+), 19 deletions(-) diff --git a/frontend/cli/cmd_serve.go b/frontend/cli/cmd_serve.go index c2c6d7b8a8..9bfafe31a0 100644 --- a/frontend/cli/cmd_serve.go +++ b/frontend/cli/cmd_serve.go @@ -362,29 +362,32 @@ func (s *serveCommonConfig) run( return nil }) // Wait for controller to start, then run startup commands. - start := time.Now() - if err := waitForControllerOnline(ctx, s.StartupTimeout, controllerClient); err != nil { - return fmt.Errorf("controller failed to start: %w", err) - } - if s.Provisioners > 0 { - if err := rpc.Wait(ctx, backoff.Backoff{Max: s.StartupTimeout}, s.StartupTimeout, provisionerClient); err != nil { - return fmt.Errorf("provisioner failed to start: %w", err) + wg.Go(func() error { + start := time.Now() + if err := waitForControllerOnline(ctx, s.StartupTimeout, controllerClient); err != nil { + return fmt.Errorf("controller failed to start: %w", err) } - } - logger.Infof("Controller started in %.2fs", time.Since(start).Seconds()) - - if len(projConfig.Commands.Startup) > 0 { - for _, cmd := range projConfig.Commands.Startup { - logger.Debugf("Executing startup command: %s", cmd) - if err := exec.Command(ctx, log.Info, ".", "bash", "-c", cmd).Run(); err != nil { - return fmt.Errorf("startup command failed: %w", err) + if s.Provisioners > 0 { + if err := rpc.Wait(ctx, backoff.Backoff{Max: s.StartupTimeout}, s.StartupTimeout, provisionerClient); err != nil { + return fmt.Errorf("provisioner failed to start: %w", err) + } + } + logger.Infof("Controller started in %.2fs", time.Since(start).Seconds()) + + if len(projConfig.Commands.Startup) > 0 { + for _, cmd := range projConfig.Commands.Startup { + logger.Debugf("Executing startup command: %s", cmd) + if err := exec.Command(ctx, log.Info, ".", "bash", "-c", cmd).Run(); err != nil { + return fmt.Errorf("startup command failed: %w", err) + } } } - } - if ch, ok := initialised.Get(); ok { - ch <- true - } + if ch, ok := initialised.Get(); ok { + ch <- true + } + return nil + }) if err := wg.Wait(); err != nil { return fmt.Errorf("serve failed: %w", err)