Fix registry tests to not terminate prematurely when looking for errors
Also reorders a check in the V1 protocol to have better error messaging for the users
This commit is contained in:
		
							parent
							
								
									1f04b3ea03
								
							
						
					
					
						commit
						701eac5466
					
				
					 4 changed files with 42 additions and 20 deletions
				
			
		|  | @ -437,6 +437,13 @@ def put_image_json(namespace, repository, image_id): | |||
|     abort(404, 'Repository does not exist: %(namespace)s/%(repository)s', issue='no-repo', | ||||
|           namespace=namespace, repository=repository) | ||||
| 
 | ||||
|   parent_id = data.get('parent', None) | ||||
|   if parent_id: | ||||
|     logger.debug('Looking up parent image') | ||||
|     if model.docker_v1_metadata(namespace, repository, parent_id) is None: | ||||
|       abort(400, 'Image %(image_id)s depends on non existing parent image %(parent_id)s', | ||||
|             issue='invalid-request', image_id=image_id, parent_id=parent_id) | ||||
| 
 | ||||
|   v1_metadata = model.docker_v1_metadata(namespace, repository, image_id) | ||||
|   if v1_metadata is None: | ||||
|     username = get_authenticated_user() and get_authenticated_user().username | ||||
|  | @ -451,13 +458,6 @@ def put_image_json(namespace, repository, image_id): | |||
|   model.create_temp_hidden_tag(namespace, repository, image_id, | ||||
|                                app.config['PUSH_TEMP_TAG_EXPIRATION_SEC']) | ||||
| 
 | ||||
|   parent_id = data.get('parent', None) | ||||
|   if parent_id: | ||||
|     logger.debug('Looking up parent image') | ||||
|     if model.docker_v1_metadata(namespace, repository, parent_id) is None: | ||||
|       abort(400, 'Image %(image_id)s depends on non existing parent image %(parent_id)s', | ||||
|             issue='invalid-request', image_id=image_id, parent_id=parent_id) | ||||
| 
 | ||||
|   logger.debug('Checking if image already exists') | ||||
|   if v1_metadata and not model.is_image_uploading(namespace, repository, image_id): | ||||
|     exact_abort(409, 'Image already exists') | ||||
|  |  | |||
		Reference in a new issue