Optimize the new registry data model to avoid unnecessary queries
This commit is contained in:
		
							parent
							
								
									46edebe6b0
								
							
						
					
					
						commit
						a96c5a7f64
					
				
					 4 changed files with 41 additions and 19 deletions
				
			
		|  | @ -2,9 +2,12 @@ from datetime import datetime, timedelta | |||
| 
 | ||||
| import pytest | ||||
| 
 | ||||
| from playhouse.test_utils import assert_query_count | ||||
| 
 | ||||
| from data import model | ||||
| from data.registry_model.registry_pre_oci_model import PreOCIModel | ||||
| from data.registry_model.datatypes import RepositoryReference | ||||
| 
 | ||||
| from test.fixtures import * | ||||
| 
 | ||||
| @pytest.fixture() | ||||
|  | @ -95,8 +98,11 @@ def test_legacy_images(repo_namespace, repo_name, pre_oci_model): | |||
|     found_image = pre_oci_model.get_legacy_image(repository_ref, image.docker_image_id, | ||||
|                                                  include_parents=True) | ||||
| 
 | ||||
|     assert found_image.docker_image_id == image.docker_image_id | ||||
|     assert found_image.parents == image.parents | ||||
|     with assert_query_count(4 if found_image.parents else 3): | ||||
|       found_image = pre_oci_model.get_legacy_image(repository_ref, image.docker_image_id, | ||||
|                                                    include_parents=True) | ||||
|       assert found_image.docker_image_id == image.docker_image_id | ||||
|       assert found_image.parents == image.parents | ||||
| 
 | ||||
|     # Check that the tags list can be retrieved. | ||||
|     assert image.tags is not None | ||||
|  | @ -157,26 +163,32 @@ def test_manifest_labels(pre_oci_model): | |||
| ]) | ||||
| def test_repository_tags(repo_namespace, repo_name, pre_oci_model): | ||||
|   repository_ref = pre_oci_model.lookup_repository(repo_namespace, repo_name) | ||||
|   tags = pre_oci_model.list_repository_tags(repository_ref) | ||||
|   assert len(tags) | ||||
| 
 | ||||
|   with assert_query_count(1): | ||||
|     tags = pre_oci_model.list_repository_tags(repository_ref, include_legacy_images=True) | ||||
|     assert len(tags) | ||||
| 
 | ||||
|   for tag in tags: | ||||
|     found_tag = pre_oci_model.get_repo_tag(repository_ref, tag.name, include_legacy_image=True) | ||||
|     assert found_tag == tag | ||||
|     with assert_query_count(2): | ||||
|       found_tag = pre_oci_model.get_repo_tag(repository_ref, tag.name, include_legacy_image=True) | ||||
|       assert found_tag == tag | ||||
| 
 | ||||
|     if found_tag.legacy_image is None: | ||||
|       continue | ||||
| 
 | ||||
|     found_image = pre_oci_model.get_legacy_image(repository_ref, | ||||
|                                                  found_tag.legacy_image.docker_image_id) | ||||
|     assert found_image == found_tag.legacy_image | ||||
|     with assert_query_count(2): | ||||
|       found_image = pre_oci_model.get_legacy_image(repository_ref, | ||||
|                                                    found_tag.legacy_image.docker_image_id) | ||||
|       assert found_image == found_tag.legacy_image | ||||
| 
 | ||||
| 
 | ||||
| def test_repository_tag_history(pre_oci_model): | ||||
|   repository_ref = pre_oci_model.lookup_repository('devtable', 'history') | ||||
|   history, has_more = pre_oci_model.list_repository_tag_history(repository_ref) | ||||
|   assert not has_more | ||||
|   assert len(history) == 2 | ||||
| 
 | ||||
|   with assert_query_count(2): | ||||
|     history, has_more = pre_oci_model.list_repository_tag_history(repository_ref) | ||||
|     assert not has_more | ||||
|     assert len(history) == 2 | ||||
| 
 | ||||
| 
 | ||||
| @pytest.mark.parametrize('repo_namespace, repo_name', [ | ||||
|  | @ -199,8 +211,9 @@ def test_delete_tags(repo_namespace, repo_name, pre_oci_model): | |||
|     assert pre_oci_model.delete_tag(repository_ref, tag.name) | ||||
| 
 | ||||
|     # Make sure the tag is no longer found. | ||||
|     found_tag = pre_oci_model.get_repo_tag(repository_ref, tag.name, include_legacy_image=True) | ||||
|     assert found_tag is None | ||||
|     with assert_query_count(1): | ||||
|       found_tag = pre_oci_model.get_repo_tag(repository_ref, tag.name, include_legacy_image=True) | ||||
|       assert found_tag is None | ||||
| 
 | ||||
|   # Ensure all tags have been deleted. | ||||
|   tags = pre_oci_model.list_repository_tags(repository_ref) | ||||
|  |  | |||
		Reference in a new issue