Report layer upload as unavialable when data missing
Signed-off-by: Stephen J Day <stephen.day@docker.com>
This commit is contained in:
parent
c080c40030
commit
f926a93778
2 changed files with 27 additions and 1 deletions
|
@ -102,7 +102,22 @@ func (luc *layerUploadController) validateLayer(dgst digest.Digest) (digest.Dige
|
|||
// Read the file from the backend driver and validate it.
|
||||
fr, err := newFileReader(luc.fileWriter.driver, luc.path)
|
||||
if err != nil {
|
||||
return "", err
|
||||
switch err := err.(type) {
|
||||
case storagedriver.PathNotFoundError:
|
||||
// NOTE(stevvooe): Path not found can mean several things by we
|
||||
// should report the upload is not available. This can happen if
|
||||
// the following happens:
|
||||
//
|
||||
// 1. If not data was received for the upload instance.
|
||||
// 2. Backend storage driver has not convereged after receiving latest data.
|
||||
//
|
||||
// This *does not* mean that the upload does not exist, since we
|
||||
// can't even get a LayerUpload object without having the
|
||||
// directory exist.
|
||||
return "", ErrLayerUploadUnavailable{Err: err}
|
||||
default:
|
||||
return "", err
|
||||
}
|
||||
}
|
||||
|
||||
tr := io.TeeReader(fr, digestVerifier)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue