Merge pull request #2104 from stevvooe/digest-parse

digest: remove stuttering ParseDigest function
This commit is contained in:
Derek McGowan 2016-12-15 15:44:27 -08:00 committed by GitHub
commit 898c26326d
10 changed files with 19 additions and 15 deletions

View File

@ -63,12 +63,16 @@ var (
// ParseDigest parses s and returns the validated digest object. An error will // ParseDigest parses s and returns the validated digest object. An error will
// be returned if the format is invalid. // be returned if the format is invalid.
func ParseDigest(s string) (Digest, error) { func Parse(s string) (Digest, error) {
d := Digest(s) d := Digest(s)
return d, d.Validate() return d, d.Validate()
} }
// ParseDigest is deprecated. Use Parse.
func ParseDigest(s string) (Digest, error) {
return Parse(s)
}
// FromReader returns the most valid digest for the underlying content using // FromReader returns the most valid digest for the underlying content using
// the canonical digest algorithm. // the canonical digest algorithm.
func FromReader(rd io.Reader) (Digest, error) { func FromReader(rd io.Reader) (Digest, error) {

View File

@ -51,7 +51,7 @@ func TestParseDigest(t *testing.T) {
err: ErrDigestUnsupported, err: ErrDigestUnsupported,
}, },
} { } {
digest, err := ParseDigest(testcase.input) digest, err := Parse(testcase.input)
if err != testcase.err { if err != testcase.err {
t.Fatalf("error differed from expected while parsing %q: %v != %v", testcase.input, err, testcase.err) t.Fatalf("error differed from expected while parsing %q: %v != %v", testcase.input, err, testcase.err)
} }
@ -69,7 +69,7 @@ func TestParseDigest(t *testing.T) {
} }
// Parse string return value and check equality // Parse string return value and check equality
newParsed, err := ParseDigest(digest.String()) newParsed, err := Parse(digest.String())
if err != nil { if err != nil {
t.Fatalf("unexpected error parsing input %q: %v", testcase.input, err) t.Fatalf("unexpected error parsing input %q: %v", testcase.input, err)

View File

@ -75,7 +75,7 @@ func (dst *Set) Lookup(d string) (Digest, error) {
alg Algorithm alg Algorithm
hex string hex string
) )
dgst, err := ParseDigest(d) dgst, err := Parse(d)
if err == ErrDigestInvalidFormat { if err == ErrDigestInvalidFormat {
hex = d hex = d
searchFunc = func(i int) bool { searchFunc = func(i int) bool {

View File

@ -170,7 +170,7 @@ func Parse(s string) (Reference, error) {
} }
if matches[3] != "" { if matches[3] != "" {
var err error var err error
ref.digest, err = digest.ParseDigest(matches[3]) ref.digest, err = digest.Parse(matches[3])
if err != nil { if err != nil {
return nil, err return nil, err
} }

View File

@ -268,7 +268,7 @@ func descriptorFromResponse(response *http.Response) (distribution.Descriptor, e
return desc, nil return desc, nil
} }
dgst, err := digest.ParseDigest(digestHeader) dgst, err := digest.Parse(digestHeader)
if err != nil { if err != nil {
return distribution.Descriptor{}, err return distribution.Descriptor{}, err
} }
@ -475,7 +475,7 @@ func (ms *manifests) Get(ctx context.Context, dgst digest.Digest, options ...dis
return nil, distribution.ErrManifestNotModified return nil, distribution.ErrManifestNotModified
} else if SuccessStatus(resp.StatusCode) { } else if SuccessStatus(resp.StatusCode) {
if contentDgst != nil { if contentDgst != nil {
dgst, err := digest.ParseDigest(resp.Header.Get("Docker-Content-Digest")) dgst, err := digest.Parse(resp.Header.Get("Docker-Content-Digest"))
if err == nil { if err == nil {
*contentDgst = dgst *contentDgst = dgst
} }
@ -553,7 +553,7 @@ func (ms *manifests) Put(ctx context.Context, m distribution.Manifest, options .
if SuccessStatus(resp.StatusCode) { if SuccessStatus(resp.StatusCode) {
dgstHeader := resp.Header.Get("Docker-Content-Digest") dgstHeader := resp.Header.Get("Docker-Content-Digest")
dgst, err := digest.ParseDigest(dgstHeader) dgst, err := digest.Parse(dgstHeader)
if err != nil { if err != nil {
return "", err return "", err
} }

View File

@ -211,7 +211,7 @@ func (buh *blobUploadHandler) PutBlobUploadComplete(w http.ResponseWriter, r *ht
return return
} }
dgst, err := digest.ParseDigest(dgstStr) dgst, err := digest.Parse(dgstStr)
if err != nil { if err != nil {
// no digest? return error, but allow retry. // no digest? return error, but allow retry.
buh.Errors = append(buh.Errors, v2.ErrorCodeDigestInvalid.WithDetail("digest parsing failed")) buh.Errors = append(buh.Errors, v2.ErrorCodeDigestInvalid.WithDetail("digest parsing failed"))
@ -329,7 +329,7 @@ func (buh *blobUploadHandler) blobUploadResponse(w http.ResponseWriter, r *http.
// successful, the blob is linked into the blob store and 201 Created is // successful, the blob is linked into the blob store and 201 Created is
// returned with the canonical url of the blob. // returned with the canonical url of the blob.
func (buh *blobUploadHandler) createBlobMountOption(fromRepo, mountDigest string) (distribution.BlobCreateOption, error) { func (buh *blobUploadHandler) createBlobMountOption(fromRepo, mountDigest string) (distribution.BlobCreateOption, error) {
dgst, err := digest.ParseDigest(mountDigest) dgst, err := digest.Parse(mountDigest)
if err != nil { if err != nil {
return nil, err return nil, err
} }

View File

@ -62,7 +62,7 @@ func getDigest(ctx context.Context) (dgst digest.Digest, err error) {
return "", errDigestNotAvailable return "", errDigestNotAvailable
} }
d, err := digest.ParseDigest(dgstStr) d, err := digest.Parse(dgstStr)
if err != nil { if err != nil {
ctxu.GetLogger(ctx).Errorf("error parsing digest=%q: %v", dgstStr, err) ctxu.GetLogger(ctx).Errorf("error parsing digest=%q: %v", dgstStr, err)
return "", err return "", err

View File

@ -33,7 +33,7 @@ func imageManifestDispatcher(ctx *Context, r *http.Request) http.Handler {
Context: ctx, Context: ctx,
} }
reference := getReference(ctx) reference := getReference(ctx)
dgst, err := digest.ParseDigest(reference) dgst, err := digest.Parse(reference)
if err != nil { if err != nil {
// We just have a tag // We just have a tag
imageManifestHandler.Tag = reference imageManifestHandler.Tag = reference

View File

@ -145,7 +145,7 @@ func (bs *blobStore) readlink(ctx context.Context, path string) (digest.Digest,
return "", err return "", err
} }
linked, err := digest.ParseDigest(string(content)) linked, err := digest.Parse(string(content))
if err != nil { if err != nil {
return "", err return "", err
} }

View File

@ -29,7 +29,7 @@ type Vacuum struct {
// RemoveBlob removes a blob from the filesystem // RemoveBlob removes a blob from the filesystem
func (v Vacuum) RemoveBlob(dgst string) error { func (v Vacuum) RemoveBlob(dgst string) error {
d, err := digest.ParseDigest(dgst) d, err := digest.Parse(dgst)
if err != nil { if err != nil {
return err return err
} }