6
6
"fmt"
7
7
"log"
8
8
"os"
9
- "os/exec"
10
- "path/filepath"
11
9
"strings"
12
10
"time"
13
11
@@ -293,64 +291,8 @@ func (rm *ReleaseManager) DeleteRemoteTag(version string) error {
293
291
return nil
294
292
}
295
293
296
- // BuildCLIBinaries builds CLI binaries for multiple architectures
297
- func (rm * ReleaseManager ) BuildCLIBinaries (version string ) ([]string , error ) {
298
- // Define target platforms
299
- platforms := []struct {
300
- GOOS string
301
- GOARCH string
302
- name string
303
- }{
304
- {"linux" , "amd64" , "linux-amd64" },
305
- {"linux" , "arm64" , "linux-arm64" },
306
- {"darwin" , "amd64" , "darwin-amd64" },
307
- {"darwin" , "arm64" , "darwin-arm64" },
308
- {"windows" , "amd64" , "windows-amd64" },
309
- }
310
-
311
- // Create output directory
312
- outputDir := "release-binaries"
313
- if err := os .MkdirAll (outputDir , 0755 ); err != nil {
314
- return nil , fmt .Errorf ("failed to create output directory: %w" , err )
315
- }
316
-
317
- var binaries []string
318
-
319
- for _ , platform := range platforms {
320
- outputName := fmt .Sprintf ("dbos-%s-%s" , version , platform .name )
321
- if platform .GOOS == "windows" {
322
- outputName += ".exe"
323
- }
324
- outputPath := filepath .Join (outputDir , outputName )
325
-
326
- fmt .Printf ("Building CLI for %s/%s...\n " , platform .GOOS , platform .GOARCH )
327
-
328
- cmd := exec .Command ("go" , "build" ,
329
- "-ldflags" , fmt .Sprintf ("-X main.Version=%s" , version ),
330
- "-o" , outputPath ,
331
- "./dbos/cmd" )
332
-
333
- cmd .Env = append (os .Environ (),
334
- fmt .Sprintf ("GOOS=%s" , platform .GOOS ),
335
- fmt .Sprintf ("GOARCH=%s" , platform .GOARCH ),
336
- "CGO_ENABLED=0" ,
337
- )
338
-
339
- output , err := cmd .CombinedOutput ()
340
- if err != nil {
341
- return nil , fmt .Errorf ("failed to build for %s/%s: %w\n Output: %s" ,
342
- platform .GOOS , platform .GOARCH , err , output )
343
- }
344
-
345
- binaries = append (binaries , outputPath )
346
- fmt .Printf ("✓ Built %s\n " , outputName )
347
- }
348
-
349
- return binaries , nil
350
- }
351
-
352
294
// CreateGitHubRelease creates a GitHub release with CLI binaries
353
- func (rm * ReleaseManager ) CreateGitHubRelease (version string , binaries [] string ) error {
295
+ func (rm * ReleaseManager ) CreateGitHubRelease (version string ) error {
354
296
ctx := context .Background ()
355
297
356
298
v , err := semver .NewVersion (version )
@@ -366,7 +308,7 @@ func (rm *ReleaseManager) CreateGitHubRelease(version string, binaries []string)
366
308
GenerateReleaseNotes : github .Ptr (true ),
367
309
}
368
310
369
- createdRelease , _ , err : = rm .client .Repositories .CreateRelease (
311
+ _ , _ , err = rm .client .Repositories .CreateRelease (
370
312
ctx ,
371
313
rm .githubOwner ,
372
314
rm .githubRepo ,
@@ -378,36 +320,6 @@ func (rm *ReleaseManager) CreateGitHubRelease(version string, binaries []string)
378
320
}
379
321
380
322
fmt .Printf ("✓ GitHub release %s created\n " , version )
381
-
382
- // Upload CLI binaries as release assets
383
- for _ , binaryPath := range binaries {
384
- file , err := os .Open (binaryPath )
385
- if err != nil {
386
- fmt .Printf ("Warning: failed to open binary %s: %v\n " , binaryPath , err )
387
- continue
388
- }
389
- defer file .Close ()
390
-
391
- opts := & github.UploadOptions {
392
- Name : filepath .Base (binaryPath ),
393
- }
394
-
395
- _ , _ , err = rm .client .Repositories .UploadReleaseAsset (
396
- ctx ,
397
- rm .githubOwner ,
398
- rm .githubRepo ,
399
- * createdRelease .ID ,
400
- opts ,
401
- file ,
402
- )
403
-
404
- if err != nil {
405
- fmt .Printf ("Warning: failed to upload %s: %v\n " , filepath .Base (binaryPath ), err )
406
- } else {
407
- fmt .Printf ("✓ Uploaded %s\n " , filepath .Base (binaryPath ))
408
- }
409
- }
410
-
411
323
return nil
412
324
}
413
325
@@ -477,24 +389,9 @@ func main() {
477
389
log .Fatalf ("Failed to create release branch: %v" , err )
478
390
}
479
391
480
- // Build CLI binaries for multiple platforms
481
- fmt .Printf ("\n Building CLI binaries...\n " )
482
- binaries , err := rm .BuildCLIBinaries (version )
483
- if err != nil {
484
- // Rollback: delete the remote tag
485
- if deleteErr := rm .DeleteRemoteTag (version ); deleteErr != nil {
486
- fmt .Printf ("Warning: failed to cleanup remote tag %s: %v\n " , version , deleteErr )
487
- }
488
- // Delete the local tag
489
- if deleteErr := rm .repo .DeleteTag (version ); deleteErr != nil {
490
- fmt .Printf ("Warning: failed to cleanup local tag %s: %v\n " , version , deleteErr )
491
- }
492
- log .Fatalf ("Failed to build CLI binaries: %v" , err )
493
- }
494
-
495
392
// Create GitHub release with CLI binaries
496
393
fmt .Printf ("\n Creating GitHub release...\n " )
497
- if err := rm .CreateGitHubRelease (version , binaries ); err != nil {
394
+ if err := rm .CreateGitHubRelease (version ); err != nil {
498
395
// Rollback: delete the remote tag
499
396
if deleteErr := rm .DeleteRemoteTag (version ); deleteErr != nil {
500
397
fmt .Printf ("Warning: failed to cleanup remote tag %s: %v\n " , version , deleteErr )
0 commit comments