Enhance dev runner with automatic service builds

This commit is contained in:
Ilya Groshev
2026-04-22 21:47:51 +03:00
parent 056537998a
commit 945ca2e3df
4 changed files with 98 additions and 5 deletions
+22 -1
View File
@@ -30,6 +30,27 @@ build-auth:
build-claim-account:
go build -o claim-account$(EXE) ./cmd/claim-account
build-dev:
go build -o bin/dev$(EXE) ./cmd/dev
build-all:
ifeq ($(OS),Windows_NT)
if not exist bin mkdir bin
else
mkdir -p bin
endif
go build -o bin/dev$(EXE) ./cmd/dev
go build -o bin/auth-server$(EXE) ./cmd/auth-server
go build -o bin/octo-cdn$(EXE) ./cmd/octo-cdn
go build -o bin/lunar-tear$(EXE) ./cmd/lunar-tear
clean:
ifeq ($(OS),Windows_NT)
if exist bin rmdir /s /q bin
else
rm -rf bin
endif
dev:
go run ./cmd/dev $(ARGS)
@@ -50,4 +71,4 @@ ifndef UUID
endif
go run ./cmd/import-snapshot --snapshot $(SNAPSHOT) --uuid $(UUID)
.PHONY: proto build build-cdn build-auth build-import build-claim-account dev migrate import
.PHONY: proto build build-cdn build-auth build-import build-claim-account build-dev build-all clean dev migrate import
+56 -3
View File
@@ -10,6 +10,8 @@ import (
"os"
"os/exec"
"os/signal"
"path/filepath"
"runtime"
"sync"
"syscall"
)
@@ -28,6 +30,53 @@ type service struct {
cmd *exec.Cmd
}
func binExt() string {
if runtime.GOOS == "windows" {
return ".exe"
}
return ""
}
func buildAll() {
if err := os.MkdirAll("bin", 0755); err != nil {
log.Fatalf("create bin/: %v", err)
}
type target struct {
name string
pkg string
}
targets := []target{
{"auth-server", "./cmd/auth-server"},
{"octo-cdn", "./cmd/octo-cdn"},
{"lunar-tear", "./cmd/lunar-tear"},
}
ext := binExt()
var wg sync.WaitGroup
errs := make(chan error, len(targets))
for _, t := range targets {
wg.Add(1)
go func(t target) {
defer wg.Done()
out := filepath.Join("bin", t.name+ext)
cmd := exec.Command("go", "build", "-o", out, t.pkg)
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
if err := cmd.Run(); err != nil {
errs <- fmt.Errorf("build %s: %w", t.name, err)
}
}(t)
}
wg.Wait()
close(errs)
for err := range errs {
log.Fatal(err)
}
}
func main() {
// auth-server flags
authListen := flag.String("auth.listen", "0.0.0.0:3000", "auth-server listen address (host:port)")
@@ -62,6 +111,10 @@ func main() {
colorCyan = ""
}
log.Println("building services...")
buildAll()
ext := binExt()
ctx, stop := signal.NotifyContext(context.Background(), os.Interrupt, syscall.SIGTERM)
defer stop()
@@ -69,7 +122,7 @@ func main() {
{
label: "auth",
color: colorGreen,
cmd: exec.CommandContext(ctx, "go", "run", "./cmd/auth-server",
cmd: exec.CommandContext(ctx, filepath.Join("bin", "auth-server"+ext),
"--listen", *authListen,
"--db", *authDB,
),
@@ -77,7 +130,7 @@ func main() {
{
label: "cdn",
color: colorCyan,
cmd: exec.CommandContext(ctx, "go", "run", "./cmd/octo-cdn",
cmd: exec.CommandContext(ctx, filepath.Join("bin", "octo-cdn"+ext),
"--listen", *cdnListen,
"--public-addr", *cdnPublicAddr,
),
@@ -85,7 +138,7 @@ func main() {
{
label: "grpc",
color: colorYellow,
cmd: exec.CommandContext(ctx, "go", "run", "./cmd/lunar-tear",
cmd: exec.CommandContext(ctx, filepath.Join("bin", "lunar-tear"+ext),
"--listen", *grpcListen,
"--public-addr", *grpcPublicAddr,
"--db", *grpcDB,
+15 -1
View File
@@ -795,7 +795,21 @@ func saveConfig(cfg config) {
}
func launchDev(ip string, p ports) {
cmd := exec.Command("go", "run", "./cmd/dev",
ext := ""
if runtime.GOOS == "windows" {
ext = ".exe"
}
devBin := filepath.Join("bin", "dev"+ext)
_ = spinner.New().Title(" Building services...").Action(func() {
if err := os.MkdirAll("bin", 0755); err != nil {
fmt.Fprintf(os.Stderr, " Failed to create bin/: %v\n", err)
os.Exit(1)
}
runQuiet(exec.Command("go", "build", "-o", devBin, "./cmd/dev"), "build dev")
}).Run()
cmd := exec.Command(devBin,
"--grpc.listen", fmt.Sprintf("0.0.0.0:%d", p.GRPC),
"--grpc.public-addr", fmt.Sprintf("%s:%d", ip, p.GRPC),
"--cdn.listen", fmt.Sprintf("0.0.0.0:%d", p.CDN),