Change V1 to use the manifest builder and new registry data model
This commit is contained in:
		
							parent
							
								
									65d5be23c7
								
							
						
					
					
						commit
						4520f9e842
					
				
					 12 changed files with 291 additions and 689 deletions
				
			
		|  | @ -3,7 +3,7 @@ import json | |||
| from cStringIO import StringIO | ||||
| from enum import Enum, unique | ||||
| 
 | ||||
| from digest.checksums import compute_simple | ||||
| from digest.checksums import compute_simple, compute_tarsum | ||||
| from test.registry.protocols import (RegistryProtocol, Failures, ProtocolOptions, PushResult, | ||||
|                                      PullResult) | ||||
| 
 | ||||
|  | @ -31,7 +31,7 @@ class V1Protocol(RegistryProtocol): | |||
|     V1ProtocolSteps.GET_IMAGES: { | ||||
|       Failures.UNAUTHENTICATED: 403, | ||||
|       Failures.UNAUTHORIZED: 403, | ||||
|       Failures.APP_REPOSITORY: 405, | ||||
|       Failures.APP_REPOSITORY: 404, | ||||
|       Failures.ANONYMOUS_NOT_ALLOWED: 401, | ||||
|       Failures.DISALLOWED_LIBRARY_NAMESPACE: 400, | ||||
|       Failures.NAMESPACE_DISABLED: 400, | ||||
|  | @ -93,7 +93,7 @@ class V1Protocol(RegistryProtocol): | |||
| 
 | ||||
|     # GET /v1/repositories/{namespace}/{repository}/tags | ||||
|     image_ids = self.conduct(session, 'GET', prefix + 'tags', headers=headers).json() | ||||
|     assert len(image_ids.values()) == len(tag_names) | ||||
|     assert len(image_ids.values()) >= len(tag_names) | ||||
| 
 | ||||
|     for tag_name in tag_names: | ||||
|       if tag_name not in image_ids: | ||||
|  | @ -165,13 +165,21 @@ class V1Protocol(RegistryProtocol): | |||
|                               expected_status=(200, expected_failure, | ||||
|                                                V1ProtocolSteps.PUT_IMAGE_JSON)) | ||||
|       if response.status_code != 200: | ||||
|         break | ||||
|         return | ||||
| 
 | ||||
|       # PUT /v1/images/{imageID}/checksum (old style) | ||||
|       old_checksum = compute_tarsum(StringIO(image.bytes), json.dumps(image_json_data)) | ||||
|       checksum_headers = {'X-Docker-Checksum': old_checksum} | ||||
|       checksum_headers.update(headers) | ||||
| 
 | ||||
|       self.conduct(session, 'PUT', '/v1/images/%s/checksum' % image.id, | ||||
|                    headers=checksum_headers) | ||||
| 
 | ||||
|       # PUT /v1/images/{imageID}/layer | ||||
|       self.conduct(session, 'PUT', '/v1/images/%s/layer' % image.id, | ||||
|                    data=StringIO(image.bytes), headers=headers) | ||||
| 
 | ||||
|       # PUT /v1/images/{imageID}/checksum | ||||
|       # PUT /v1/images/{imageID}/checksum (new style) | ||||
|       checksum = compute_simple(StringIO(image.bytes), json.dumps(image_json_data)) | ||||
|       checksum_headers = {'X-Docker-Checksum-Payload': checksum} | ||||
|       checksum_headers.update(headers) | ||||
|  | @ -208,3 +216,12 @@ class V1Protocol(RegistryProtocol): | |||
|                    '/v1/repositories/%s/tags/%s' % (self.repo_name(namespace, repo_name), tag_name), | ||||
|                    auth=auth, | ||||
|                    expected_status=(200, expected_failure, V1ProtocolSteps.DELETE_TAG)) | ||||
| 
 | ||||
|   def tag(self, session, namespace, repo_name, tag_name, image, credentials=None, | ||||
|           expected_failure=None, options=None): | ||||
|     auth = self._auth_for_credentials(credentials) | ||||
|     self.conduct(session, 'PUT', | ||||
|                  '/v1/repositories/%s/tags/%s' % (self.repo_name(namespace, repo_name), tag_name), | ||||
|                  data='"%s"' % image.id, | ||||
|                  auth=auth, | ||||
|                  expected_status=(200, expected_failure, V1ProtocolSteps.PUT_TAG)) | ||||
|  |  | |||
		Reference in a new issue