update download

This commit is contained in:
Michael Yang 2023-10-09 10:14:49 -07:00
parent b599946b74
commit a2055a1e93

View file

@ -30,6 +30,7 @@ type blobDownload struct {
Total int64 Total int64
Completed atomic.Int64 Completed atomic.Int64
done bool
Parts []*blobDownloadPart Parts []*blobDownloadPart
@ -124,7 +125,7 @@ func (b *blobDownload) Run(ctx context.Context, requestURL *url.URL, opts *Regis
file.Truncate(b.Total) file.Truncate(b.Total)
g, ctx := errgroup.WithContext(ctx) g, _ := errgroup.WithContext(ctx)
// TODO(mxyng): download concurrency should be configurable // TODO(mxyng): download concurrency should be configurable
g.SetLimit(64) g.SetLimit(64)
for i := range b.Parts { for i := range b.Parts {
@ -168,7 +169,12 @@ func (b *blobDownload) Run(ctx context.Context, requestURL *url.URL, opts *Regis
} }
} }
return os.Rename(file.Name(), b.Name) if err := os.Rename(file.Name(), b.Name); err != nil {
return err
}
b.done = true
return nil
} }
func (b *blobDownload) downloadChunk(ctx context.Context, requestURL *url.URL, w io.Writer, part *blobDownloadPart, opts *RegistryOptions) error { func (b *blobDownload) downloadChunk(ctx context.Context, requestURL *url.URL, w io.Writer, part *blobDownloadPart, opts *RegistryOptions) error {
@ -267,13 +273,10 @@ func (b *blobDownload) Wait(ctx context.Context, fn func(api.ProgressResponse))
Completed: b.Completed.Load(), Completed: b.Completed.Load(),
}) })
if b.Completed.Load() >= b.Total { if b.done {
// wait for the file to get renamed
if _, err := os.Stat(b.Name); err == nil {
return nil return nil
} }
} }
}
} }
type downloadOpts struct { type downloadOpts struct {