glog.V(0).Infof("CI-DEBUG: getLatestObjectVersion: attempt %d/%d failed to get .versions directory for %s/%s: %v",attempt,maxRetries,bucket,object,err)
glog.V(0).Infof("CI-DEBUG: getLatestObjectVersion: sleeping %v before retry %d",delay,attempt+1)
time.Sleep(delay)
}
}
iferr!=nil{
// .versions directory doesn't exist - this can happen for objects that existed
// before versioning was enabled on the bucket. Fall back to checking for a
// regular (non-versioned) object file.
glog.V(1).Infof("getLatestObjectVersion: no .versions directory for %s%s after %d attempts (error: %v), checking for pre-versioning object",bucket,object,maxRetries,err)
glog.V(0).Infof("CI-DEBUG: getLatestObjectVersion: no .versions directory for %s/%s after %d attempts (total delay ~%dms, error: %v), falling back to pre-versioning",bucket,object,maxRetries,(100*(1<<maxRetries-1)-100),err)
glog.V(0).Infof("CI-DEBUG: getLatestObjectVersion: no .versions directory for %s/%s after %d attempts (total delay ~%dms, error: %v), falling back to pre-versioning",bucket,object,maxRetries,(100*(1<<maxRetries-1)-100),err)
// Check if directory has latest version metadata - retry if missing due to race condition
ifversionsEntry.Extended==nil{
glog.V(0).Infof("CI-DEBUG: getLatestObjectVersion: .versions directory exists but NO Extended metadata for %s/%s - retrying to handle race condition",bucket,object)
// Retry a few times to handle the race condition where directory exists but metadata is not yet written
glog.V(0).Infof("CI-DEBUG: getLatestObjectVersion: metadata retry %d failed to re-read .versions for %s/%s: %v",metaAttempt,bucket,object,err)
break
}
ifversionsEntry.Extended!=nil{
glog.V(0).Infof("CI-DEBUG: getLatestObjectVersion: metadata retry %d SUCCESS - found Extended metadata for %s/%s",metaAttempt,bucket,object)
break
}
}
// If still no metadata after retries, fall back to pre-versioning object
ifversionsEntry.Extended==nil{
glog.V(2).Infof("getLatestObjectVersion: no Extended metadata in .versions directory for %s%s after retries, checking for pre-versioning object",bucket,object)