mirror of
				https://github.com/distribution/distribution.git
				synced 2025-10-25 05:39:33 +00:00 
			
		
		
		
	tarsum is not actually used by the registry. Remove support for it. Convert numerous uses in unit tests to SHA256. Update docs to remove mentions of tarsums (which were often inaccurate). Remove tarsum dependency. Signed-off-by: Aaron Lehmann <aaron.lehmann@docker.com>
		
			
				
	
	
		
			123 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package storage
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| )
 | |
| 
 | |
| func TestPathMapper(t *testing.T) {
 | |
| 	for _, testcase := range []struct {
 | |
| 		spec     pathSpec
 | |
| 		expected string
 | |
| 		err      error
 | |
| 	}{
 | |
| 		{
 | |
| 			spec: manifestRevisionPathSpec{
 | |
| 				name:     "foo/bar",
 | |
| 				revision: "sha256:abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/revisions/sha256/abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestRevisionLinkPathSpec{
 | |
| 				name:     "foo/bar",
 | |
| 				revision: "sha256:abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/revisions/sha256/abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789/link",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestSignatureLinkPathSpec{
 | |
| 				name:      "foo/bar",
 | |
| 				revision:  "sha256:abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 				signature: "sha256:abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/revisions/sha256/abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789/signatures/sha256/abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789/link",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestSignaturesPathSpec{
 | |
| 				name:     "foo/bar",
 | |
| 				revision: "sha256:abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/revisions/sha256/abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789/signatures",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestTagsPathSpec{
 | |
| 				name: "foo/bar",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/tags",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestTagPathSpec{
 | |
| 				name: "foo/bar",
 | |
| 				tag:  "thetag",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/tags/thetag",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestTagCurrentPathSpec{
 | |
| 				name: "foo/bar",
 | |
| 				tag:  "thetag",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/tags/thetag/current/link",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestTagIndexPathSpec{
 | |
| 				name: "foo/bar",
 | |
| 				tag:  "thetag",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/tags/thetag/index",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestTagIndexEntryPathSpec{
 | |
| 				name:     "foo/bar",
 | |
| 				tag:      "thetag",
 | |
| 				revision: "sha256:abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/tags/thetag/index/sha256/abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: manifestTagIndexEntryLinkPathSpec{
 | |
| 				name:     "foo/bar",
 | |
| 				tag:      "thetag",
 | |
| 				revision: "sha256:abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_manifests/tags/thetag/index/sha256/abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789/link",
 | |
| 		},
 | |
| 
 | |
| 		{
 | |
| 			spec: uploadDataPathSpec{
 | |
| 				name: "foo/bar",
 | |
| 				id:   "asdf-asdf-asdf-adsf",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_uploads/asdf-asdf-asdf-adsf/data",
 | |
| 		},
 | |
| 		{
 | |
| 			spec: uploadStartedAtPathSpec{
 | |
| 				name: "foo/bar",
 | |
| 				id:   "asdf-asdf-asdf-adsf",
 | |
| 			},
 | |
| 			expected: "/docker/registry/v2/repositories/foo/bar/_uploads/asdf-asdf-asdf-adsf/startedat",
 | |
| 		},
 | |
| 	} {
 | |
| 		p, err := pathFor(testcase.spec)
 | |
| 		if err != nil {
 | |
| 			t.Fatalf("unexpected generating path (%T): %v", testcase.spec, err)
 | |
| 		}
 | |
| 
 | |
| 		if p != testcase.expected {
 | |
| 			t.Fatalf("unexpected path generated (%T): %q != %q", testcase.spec, p, testcase.expected)
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// Add a few test cases to ensure we cover some errors
 | |
| 
 | |
| 	// Specify a path that requires a revision and get a digest validation error.
 | |
| 	badpath, err := pathFor(manifestSignaturesPathSpec{
 | |
| 		name: "foo/bar",
 | |
| 	})
 | |
| 
 | |
| 	if err == nil {
 | |
| 		t.Fatalf("expected an error when mapping an invalid revision: %s", badpath)
 | |
| 	}
 | |
| 
 | |
| }
 |