diff --git a/cmd/plume/release.go b/cmd/plume/release.go index c1dcf7060..9f9a086d2 100644 --- a/cmd/plume/release.go +++ b/cmd/plume/release.go @@ -26,6 +26,7 @@ import ( "strings" "time" + "github.com/aws/aws-sdk-go/aws/awserr" "github.com/spf13/cobra" "golang.org/x/net/context" "google.golang.org/api/compute/v1" @@ -492,16 +493,25 @@ func modifyReleaseMetadataIndex(spec *fcosChannelSpec, commitId string) { } path := filepath.Join("prod", "streams", specChannel, "releases.json") - - f, err := api.DownloadFile(spec.Bucket, path) - if err != nil { - plog.Fatalf("downloading release metadata index: %v", err) - } - defer f.Close() - - data, err := ioutil.ReadAll(f) + data, err := func() ([]byte, error) { + f, err := api.DownloadFile(spec.Bucket, path) + if err != nil { + if awsErr, ok := err.(awserr.Error); ok { + if awsErr.Code() == "NoSuchKey" { + return []byte("{}"), nil + } + } + return []byte{}, fmt.Errorf("downloading release metadata index: %v", err) + } + defer f.Close() + d, err := ioutil.ReadAll(f) + if err != nil { + return []byte{}, fmt.Errorf("reading release metadata index: %v", err) + } + return d, nil + }() if err != nil { - plog.Fatalf("reading release metadata index: %v", err) + plog.Fatal(err) } var m ReleaseMetadata