Skip to content

Commit

Permalink
fix: return error if ftl serve is already running
Browse files Browse the repository at this point in the history
  • Loading branch information
wesbillman committed Mar 7, 2024
1 parent db9acb4 commit eabd6bd
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 13 deletions.
14 changes: 9 additions & 5 deletions cmd/ftl/cmd_dev.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package main

import (
"context"
"errors"
"time"

"golang.org/x/sync/errgroup"
Expand All @@ -20,25 +21,28 @@ type devCmd struct {

func (d *devCmd) Run(ctx context.Context) error {
client := rpc.ClientFromContext[ftlv1connect.ControllerServiceClient](ctx)
engine, err := buildengine.New(ctx, client, d.Dirs...)
if err != nil {
return err
}

g, ctx := errgroup.WithContext(ctx)

if !d.NoServe {
if d.ServeCmd.isRunning(ctx, client) {
return errors.New("FTL is already running")
}
g.Go(func() error {
return d.ServeCmd.Run(ctx)
})
}

err = d.ServeCmd.pollControllerOnine(ctx, client)
err := d.ServeCmd.pollControllerOnine(ctx, client)
if err != nil {
return err
}

g.Go(func() error {
engine, err := buildengine.New(ctx, client, d.Dirs...)
if err != nil {
return err
}
return engine.Dev(ctx, d.Watch)
})

Expand Down
25 changes: 17 additions & 8 deletions cmd/ftl/cmd_serve.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,14 @@ func (s *serveCmd) Run(ctx context.Context) error {
logger := log.FromContext(ctx)
client := rpc.ClientFromContext[ftlv1connect.ControllerServiceClient](ctx)

if s.Stop {
return killBackgroundProcess(logger)
}

if s.isRunning(ctx, client) {
return errors.New("FTL is already running")
}

if s.Background {
if s.Stop {
// allow usage of --background and --stop together to "restart" the background process
Expand All @@ -65,10 +73,6 @@ func (s *serveCmd) Run(ctx context.Context) error {
os.Exit(0)
}

if s.Stop {
return killBackgroundProcess(logger)
}

logger.Infof("Starting FTL with %d controller(s) and %d runner(s)", s.Controllers, s.Runners)

dsn, err := s.setupDB(ctx)
Expand Down Expand Up @@ -177,16 +181,16 @@ func killBackgroundProcess(logger *log.Logger) error {
return nil
}

if err := os.Remove(pidFilePath); err != nil {
logger.Errorf(err, "Failed to remove pid file: %v", err)
}

if err := syscall.Kill(pid, syscall.SIGTERM); err != nil {
if !errors.Is(err, syscall.ESRCH) {
return err
}
}

if err := os.Remove(pidFilePath); err != nil {
logger.Errorf(err, "Failed to remove pid file: %v", err)
}

logger.Infof("`ftl serve` stopped (pid: %d)", pid)
return nil
}
Expand Down Expand Up @@ -375,3 +379,8 @@ func (s *serveCmd) pollControllerOnine(ctx context.Context, client ftlv1connect.
}
}
}

func (s *serveCmd) isRunning(ctx context.Context, client ftlv1connect.ControllerServiceClient) bool {
_, err := client.Ping(ctx, connect.NewRequest(&ftlv1.PingRequest{}))
return err == nil
}

0 comments on commit eabd6bd

Please sign in to comment.