Fix bug in V1 delete tag code and add a test
This commit is contained in:
		
							parent
							
								
									077c3908e4
								
							
						
					
					
						commit
						7567808a10
					
				
					 3 changed files with 26 additions and 7 deletions
				
			
		|  | @ -98,6 +98,9 @@ def delete_tag(namespace_name, repo_name, tag): | |||
| 
 | ||||
|   if permission.can(): | ||||
|     repo = model.get_repository(namespace_name, repo_name) | ||||
|     if repo is None: | ||||
|       abort(403) | ||||
| 
 | ||||
|     if repo.kind != 'image': | ||||
|       msg = 'This repository is for managing %s resources and not container images.' % repo.kind | ||||
|       abort(405, message=msg, namespace=namespace_name) | ||||
|  |  | |||
|  | @ -14,6 +14,7 @@ class V1ProtocolSteps(Enum): | |||
|   GET_IMAGES = 'get-images' | ||||
|   PUT_TAG = 'put-tag' | ||||
|   PUT_IMAGE_JSON = 'put-image-json' | ||||
|   DELETE_TAG = 'delete-tag' | ||||
| 
 | ||||
| 
 | ||||
| class V1Protocol(RegistryProtocol): | ||||
|  | @ -192,3 +193,18 @@ class V1Protocol(RegistryProtocol): | |||
|                  expected_status=204, headers=headers) | ||||
| 
 | ||||
|     return PushResult(checksums=None, manifests=None, headers=headers) | ||||
| 
 | ||||
|   def delete(self, session, namespace, repo_name, tag_names, credentials=None, | ||||
|              expected_failure=None, options=None): | ||||
|     auth = self._auth_for_credentials(credentials) | ||||
|     tag_names = [tag_names] if isinstance(tag_names, str) else tag_names | ||||
| 
 | ||||
|     # Ping! | ||||
|     self.ping(session) | ||||
| 
 | ||||
|     for tag_name in tag_names: | ||||
|       # DELETE /v1/repositories/{namespace}/{repository}/tags/{tag} | ||||
|       self.conduct(session, 'DELETE', | ||||
|                    '/v1/repositories/%s/tags/%s' % (self.repo_name(namespace, repo_name), tag_name), | ||||
|                    auth=auth, | ||||
|                    expected_status=(200, expected_failure, V1ProtocolSteps.DELETE_TAG)) | ||||
|  |  | |||
|  | @ -601,19 +601,19 @@ def test_invalid_blob_reference(manifest_protocol, basic_images, liveserver_sess | |||
|                          expected_failure=Failures.INVALID_BLOB) | ||||
| 
 | ||||
| 
 | ||||
| def test_delete_tag(manifest_protocol, puller, basic_images, liveserver_session, | ||||
| def test_delete_tag(pusher, puller, basic_images, liveserver_session, | ||||
|                     app_reloader): | ||||
|   """ Test: Push a repository, delete a tag, and attempt to pull. """ | ||||
|   credentials = ('devtable', 'password') | ||||
| 
 | ||||
|   # Push the tags. | ||||
|   result = manifest_protocol.push(liveserver_session, 'devtable', 'newrepo', ['one', 'two'], | ||||
|                                   basic_images, credentials=credentials) | ||||
|   result = pusher.push(liveserver_session, 'devtable', 'newrepo', ['one', 'two'], | ||||
|                        basic_images, credentials=credentials) | ||||
| 
 | ||||
|   # Delete tag `one` by digest. | ||||
|   manifest_protocol.delete(liveserver_session, 'devtable', 'newrepo', | ||||
|                            result.manifests['one'].digest, | ||||
|                            credentials=credentials) | ||||
|   # Delete tag `one` by digest or tag. | ||||
|   pusher.delete(liveserver_session, 'devtable', 'newrepo', | ||||
|                 result.manifests['one'].digest if result.manifests else 'one', | ||||
|                 credentials=credentials) | ||||
| 
 | ||||
|   # Attempt to pull tag `one` and ensure it doesn't work. | ||||
|   puller.pull(liveserver_session, 'devtable', 'newrepo', 'one', basic_images, | ||||
|  |  | |||
		Reference in a new issue