Merge pull request #5632 from VladRassokhin/do-not-donwload-twice

Do not re-download iso multiple times from different urls
This commit is contained in:
SwampDragons 2017-11-29 11:58:14 -08:00 committed by GitHub
commit 72afc2eab3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 31 additions and 14 deletions

View File

@ -61,10 +61,12 @@ func (s *StepDownload) Run(state multistep.StateBag) multistep.StepAction {
ui.Say(fmt.Sprintf("Downloading or copying %s", s.Description)) ui.Say(fmt.Sprintf("Downloading or copying %s", s.Description))
var finalPath string // First try to use any already downloaded file
for _, url := range s.Url { // If it fails, proceed to regualar download logic
ui.Message(fmt.Sprintf("Downloading or copying: %s", url))
var downloadConfigs = make([]*DownloadConfig, len(s.Url))
var finalPath string
for i, url := range s.Url {
targetPath := s.TargetPath targetPath := s.TargetPath
if targetPath == "" { if targetPath == "" {
// Determine a cache key. This is normally just the URL but // Determine a cache key. This is normally just the URL but
@ -90,22 +92,37 @@ func (s *StepDownload) Run(state multistep.StateBag) multistep.StepAction {
Checksum: checksum, Checksum: checksum,
UserAgent: "Packer", UserAgent: "Packer",
} }
downloadConfigs[i] = config
path, err, retry := s.download(config, state) if match, _ := NewDownloadClient(config).VerifyChecksum(config.TargetPath); match {
if err != nil { ui.Message(fmt.Sprintf("Found already downloaded, initial checksum matched, no download needed: %s", url))
ui.Message(fmt.Sprintf("Error downloading: %s", err)) finalPath = config.TargetPath
}
if !retry {
return multistep.ActionHalt
}
if err == nil {
finalPath = path
break break
} }
} }
if finalPath == "" {
for i, url := range s.Url {
ui.Message(fmt.Sprintf("Downloading or copying: %s", url))
config := downloadConfigs[i]
path, err, retry := s.download(config, state)
if err != nil {
ui.Message(fmt.Sprintf("Error downloading: %s", err))
}
if !retry {
return multistep.ActionHalt
}
if err == nil {
finalPath = path
break
}
}
}
if finalPath == "" { if finalPath == "" {
err := fmt.Errorf("%s download failed.", s.Description) err := fmt.Errorf("%s download failed.", s.Description)
state.Put("error", err) state.Put("error", err)