More changes for registry-v2 in python.
Implement the minimal changes to the local filesystem storage driver and feed them through the distributed storage driver. Create a digest package which contains digest_tools and checksums. Fix the tests to use the new v1 endpoint locations. Fix repository.delete_instance to properly filter the generated queries to avoid most subquery deletes, but still generate them when not explicitly filtered.
This commit is contained in:
		
							parent
							
								
									acbcc2e206
								
							
						
					
					
						commit
						bea8b9ac53
					
				
					 23 changed files with 397 additions and 179 deletions
				
			
		|  | @ -6,9 +6,7 @@ from flask.blueprints import Blueprint | |||
| from flask.ext.testing import LiveServerTestCase | ||||
| 
 | ||||
| from app import app | ||||
| from endpoints.registry import registry | ||||
| from endpoints.index import index | ||||
| from endpoints.tags import tags | ||||
| from endpoints.v1 import v1_bp | ||||
| from endpoints.api import api_bp | ||||
| from initdb import wipe_database, initialize_database, populate_database | ||||
| from endpoints.csrf import generate_csrf_token | ||||
|  | @ -23,9 +21,7 @@ from cStringIO import StringIO | |||
| from util.checksums import compute_simple | ||||
| 
 | ||||
| try: | ||||
|   app.register_blueprint(index, url_prefix='/v1') | ||||
|   app.register_blueprint(tags, url_prefix='/v1') | ||||
|   app.register_blueprint(registry, url_prefix='/v1') | ||||
|   app.register_blueprint(v1_bp, url_prefix='/v1') | ||||
|   app.register_blueprint(api_bp, url_prefix='/api') | ||||
| except ValueError: | ||||
|   # Blueprint was already registered | ||||
|  |  | |||
|  | @ -112,123 +112,123 @@ class IndexTestSpec(object): | |||
| 
 | ||||
| def build_index_specs(): | ||||
|   return [ | ||||
|     IndexTestSpec(url_for('registry.get_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.get_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|                   PUBLIC_REPO, 404, 404, 404, 404), | ||||
|     IndexTestSpec(url_for('registry.get_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.get_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|                   PRIVATE_REPO, 403, 403, 404, 404), | ||||
|     IndexTestSpec(url_for('registry.get_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.get_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|                   ORG_REPO, 403, 403, 404, 404), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('registry.put_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.put_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|                   PUBLIC_REPO, 403, 403, 403, 403).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('registry.put_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.put_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|                   PRIVATE_REPO, 403, 403, 403, 404).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('registry.put_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.put_image_layer', image_id=FAKE_IMAGE_ID), | ||||
|                   ORG_REPO, 403, 403, 403, 404).set_method('PUT'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('registry.put_image_checksum', | ||||
|     IndexTestSpec(url_for('v1.put_image_checksum', | ||||
|                           image_id=FAKE_IMAGE_ID), | ||||
|                   PUBLIC_REPO, 403, 403, 403, 403).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('registry.put_image_checksum', | ||||
|     IndexTestSpec(url_for('v1.put_image_checksum', | ||||
|                           image_id=FAKE_IMAGE_ID), | ||||
|                   PRIVATE_REPO, 403, 403, 403, 400).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('registry.put_image_checksum', | ||||
|     IndexTestSpec(url_for('v1.put_image_checksum', | ||||
|                           image_id=FAKE_IMAGE_ID), | ||||
|                   ORG_REPO, 403, 403, 403, 400).set_method('PUT'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('registry.get_image_json', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.get_image_json', image_id=FAKE_IMAGE_ID), | ||||
|                   PUBLIC_REPO, 404, 404, 404, 404), | ||||
|     IndexTestSpec(url_for('registry.get_image_json', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.get_image_json', image_id=FAKE_IMAGE_ID), | ||||
|                   PRIVATE_REPO, 403, 403, 404, 404), | ||||
|     IndexTestSpec(url_for('registry.get_image_json', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.get_image_json', image_id=FAKE_IMAGE_ID), | ||||
|                   ORG_REPO, 403, 403, 404, 404), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('registry.get_image_ancestry', | ||||
|     IndexTestSpec(url_for('v1.get_image_ancestry', | ||||
|                           image_id=FAKE_IMAGE_ID), | ||||
|                   PUBLIC_REPO, 404, 404, 404, 404), | ||||
|     IndexTestSpec(url_for('registry.get_image_ancestry', | ||||
|     IndexTestSpec(url_for('v1.get_image_ancestry', | ||||
|                           image_id=FAKE_IMAGE_ID), | ||||
|                   PRIVATE_REPO, 403, 403, 404, 404), | ||||
|     IndexTestSpec(url_for('registry.get_image_ancestry', | ||||
|     IndexTestSpec(url_for('v1.get_image_ancestry', | ||||
|                           image_id=FAKE_IMAGE_ID), | ||||
|                   ORG_REPO, 403, 403, 404, 404), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('registry.put_image_json', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.put_image_json', image_id=FAKE_IMAGE_ID), | ||||
|                   PUBLIC_REPO, 403, 403, 403, 403).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('registry.put_image_json', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.put_image_json', image_id=FAKE_IMAGE_ID), | ||||
|                   PRIVATE_REPO, 403, 403, 403, 400).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('registry.put_image_json', image_id=FAKE_IMAGE_ID), | ||||
|     IndexTestSpec(url_for('v1.put_image_json', image_id=FAKE_IMAGE_ID), | ||||
|                   ORG_REPO, 403, 403, 403, 400).set_method('PUT'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.create_user'), NO_REPO, 400, 400, 400, | ||||
|     IndexTestSpec(url_for('v1.create_user'), NO_REPO, 400, 400, 400, | ||||
|                   400).set_method('POST').set_data_from_obj(NEW_USER_DETAILS), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.get_user'), NO_REPO, 404, 200, 200, 200), | ||||
|     IndexTestSpec(url_for('v1.get_user'), NO_REPO, 404, 200, 200, 200), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.update_user', username=FAKE_USERNAME), | ||||
|     IndexTestSpec(url_for('v1.update_user', username=FAKE_USERNAME), | ||||
|                   NO_REPO, 403, 403, 403, 403).set_method('PUT'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.create_repository', repository=PUBLIC_REPO), | ||||
|     IndexTestSpec(url_for('v1.create_repository', repository=PUBLIC_REPO), | ||||
|                   NO_REPO, 403, 403, 403, 403).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('index.create_repository', repository=PRIVATE_REPO), | ||||
|     IndexTestSpec(url_for('v1.create_repository', repository=PRIVATE_REPO), | ||||
|                   NO_REPO, 403, 403, 403, 201).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('index.create_repository', repository=ORG_REPO), | ||||
|     IndexTestSpec(url_for('v1.create_repository', repository=ORG_REPO), | ||||
|                   NO_REPO, 403, 403, 403, 201).set_method('PUT'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.update_images', repository=PUBLIC_REPO), | ||||
|     IndexTestSpec(url_for('v1.update_images', repository=PUBLIC_REPO), | ||||
|                   NO_REPO, 403, 403, 403, 403).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('index.update_images', repository=PRIVATE_REPO), | ||||
|     IndexTestSpec(url_for('v1.update_images', repository=PRIVATE_REPO), | ||||
|                   NO_REPO, 403, 403, 403, 204).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('index.update_images', repository=ORG_REPO), NO_REPO, | ||||
|     IndexTestSpec(url_for('v1.update_images', repository=ORG_REPO), NO_REPO, | ||||
|                   403, 403, 403, 204).set_method('PUT'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.get_repository_images', | ||||
|     IndexTestSpec(url_for('v1.get_repository_images', | ||||
|                           repository=PUBLIC_REPO), | ||||
|                   NO_REPO, 200, 200, 200, 200), | ||||
|     IndexTestSpec(url_for('index.get_repository_images', | ||||
|     IndexTestSpec(url_for('v1.get_repository_images', | ||||
|                           repository=PRIVATE_REPO)), | ||||
|     IndexTestSpec(url_for('index.get_repository_images', repository=ORG_REPO)), | ||||
|     IndexTestSpec(url_for('v1.get_repository_images', repository=ORG_REPO)), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.delete_repository_images', | ||||
|     IndexTestSpec(url_for('v1.delete_repository_images', | ||||
|                           repository=PUBLIC_REPO), | ||||
|                   NO_REPO, 501, 501, 501, 501).set_method('DELETE'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.put_repository_auth', repository=PUBLIC_REPO), | ||||
|     IndexTestSpec(url_for('v1.put_repository_auth', repository=PUBLIC_REPO), | ||||
|                   NO_REPO, 501, 501, 501, 501).set_method('PUT'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.get_search'), NO_REPO, 200, 200, 200, 200), | ||||
|     IndexTestSpec(url_for('v1.get_search'), NO_REPO, 200, 200, 200, 200), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('index.ping'), NO_REPO, 200, 200, 200, 200), | ||||
|     IndexTestSpec(url_for('v1.ping'), NO_REPO, 200, 200, 200, 200), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('tags.get_tags', repository=PUBLIC_REPO), NO_REPO, | ||||
|     IndexTestSpec(url_for('v1.get_tags', repository=PUBLIC_REPO), NO_REPO, | ||||
|                   200, 200, 200, 200), | ||||
|     IndexTestSpec(url_for('tags.get_tags', repository=PRIVATE_REPO)), | ||||
|     IndexTestSpec(url_for('tags.get_tags', repository=ORG_REPO)), | ||||
|     IndexTestSpec(url_for('v1.get_tags', repository=PRIVATE_REPO)), | ||||
|     IndexTestSpec(url_for('v1.get_tags', repository=ORG_REPO)), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('tags.get_tag', repository=PUBLIC_REPO, | ||||
|     IndexTestSpec(url_for('v1.get_tag', repository=PUBLIC_REPO, | ||||
|                           tag=FAKE_TAG_NAME), NO_REPO, 400, 400, 400, 400), | ||||
|     IndexTestSpec(url_for('tags.get_tag', repository=PRIVATE_REPO, | ||||
|     IndexTestSpec(url_for('v1.get_tag', repository=PRIVATE_REPO, | ||||
|                           tag=FAKE_TAG_NAME), NO_REPO, 403, 403, 400, 400), | ||||
|     IndexTestSpec(url_for('tags.get_tag', repository=ORG_REPO, | ||||
|     IndexTestSpec(url_for('v1.get_tag', repository=ORG_REPO, | ||||
|                           tag=FAKE_TAG_NAME), NO_REPO, 403, 403, 400, 400), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('tags.put_tag', repository=PUBLIC_REPO, | ||||
|     IndexTestSpec(url_for('v1.put_tag', repository=PUBLIC_REPO, | ||||
|                           tag=FAKE_TAG_NAME), | ||||
|                   NO_REPO, 403, 403, 403, 403).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('tags.put_tag', repository=PRIVATE_REPO, | ||||
|     IndexTestSpec(url_for('v1.put_tag', repository=PRIVATE_REPO, | ||||
|                           tag=FAKE_TAG_NAME), | ||||
|                   NO_REPO, 403, 403, 403, 400).set_method('PUT'), | ||||
|     IndexTestSpec(url_for('tags.put_tag', repository=ORG_REPO, | ||||
|     IndexTestSpec(url_for('v1.put_tag', repository=ORG_REPO, | ||||
|                           tag=FAKE_TAG_NAME), | ||||
|                   NO_REPO, 403, 403, 403, 400).set_method('PUT'), | ||||
| 
 | ||||
|     IndexTestSpec(url_for('tags.delete_tag', repository=PUBLIC_REPO, | ||||
|     IndexTestSpec(url_for('v1.delete_tag', repository=PUBLIC_REPO, | ||||
|                           tag=FAKE_TAG_NAME), | ||||
|                   NO_REPO, 403, 403, 403, 403).set_method('DELETE'), | ||||
|     IndexTestSpec(url_for('tags.delete_tag', repository=PRIVATE_REPO, | ||||
|     IndexTestSpec(url_for('v1.delete_tag', repository=PRIVATE_REPO, | ||||
|                           tag=FAKE_TAG_NAME), | ||||
|                   NO_REPO, 403, 403, 403, 400).set_method('DELETE'), | ||||
|     IndexTestSpec(url_for('tags.delete_tag', repository=ORG_REPO, | ||||
|     IndexTestSpec(url_for('v1.delete_tag', repository=ORG_REPO, | ||||
|                           tag=FAKE_TAG_NAME), | ||||
|                   NO_REPO, 403, 403, 403, 400).set_method('DELETE'), | ||||
|   ] | ||||
|  |  | |||
|  | @ -1,8 +1,6 @@ | |||
| import unittest | ||||
| 
 | ||||
| from endpoints.tags import tags | ||||
| from endpoints.registry import registry | ||||
| from endpoints.index import index | ||||
| from endpoints.v1 import v1_bp | ||||
| from endpoints.verbs import verbs | ||||
| 
 | ||||
| 
 | ||||
|  | @ -23,9 +21,7 @@ class TestAnonymousAccessChecked(unittest.TestCase): | |||
|       deferred_function(Checker(self)) | ||||
| 
 | ||||
|   def test_anonymous_access_checked(self): | ||||
|     self.verifyBlueprint(tags) | ||||
|     self.verifyBlueprint(registry) | ||||
|     self.verifyBlueprint(index) | ||||
|     self.verifyBlueprint(v1_bp) | ||||
|     self.verifyBlueprint(verbs) | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| import unittest | ||||
| 
 | ||||
| from endpoints.v2.digest_tools import parse_digest, content_path, InvalidDigestException | ||||
| from digest.digest_tools import parse_digest, content_path, InvalidDigestException | ||||
| 
 | ||||
| class TestParseDigest(unittest.TestCase): | ||||
|   def test_parse_good(self): | ||||
|  |  | |||
|  | @ -4,14 +4,10 @@ from app import app | |||
| from util.names import parse_namespace_repository | ||||
| from initdb import setup_database_for_testing, finished_database_for_testing | ||||
| from specs import build_index_specs | ||||
| from endpoints.registry import registry | ||||
| from endpoints.index import index | ||||
| from endpoints.tags import tags | ||||
| from endpoints.v1 import v1_bp | ||||
| 
 | ||||
| 
 | ||||
| app.register_blueprint(index, url_prefix='/v1') | ||||
| app.register_blueprint(tags, url_prefix='/v1') | ||||
| app.register_blueprint(registry, url_prefix='/v1') | ||||
| app.register_blueprint(v1_bp, url_prefix='/v1') | ||||
| 
 | ||||
| 
 | ||||
| NO_ACCESS_USER = 'freshuser' | ||||
|  |  | |||
		Reference in a new issue