Fix lookup of manifests referenced solely by a manifest list
We need to ensure we can find them if there is an active tag pointing to the parent list
This commit is contained in:
		
							parent
							
								
									54904cfd6e
								
							
						
					
					
						commit
						e972e4088b
					
				
					 5 changed files with 97 additions and 13 deletions
				
			
		|  | @ -5,9 +5,10 @@ from playhouse.test_utils import assert_query_count | |||
| from app import docker_v2_signing_key, storage | ||||
| 
 | ||||
| from digest.digest_tools import sha256_digest | ||||
| from data.database import Tag, ManifestBlob, ImageStorageLocation, ManifestChild, get_epoch_timestamp_ms | ||||
| from data.database import (Tag, ManifestBlob, ImageStorageLocation, ManifestChild, | ||||
|                            get_epoch_timestamp_ms) | ||||
| from data.model.oci.manifest import lookup_manifest, get_or_create_manifest | ||||
| from data.model.oci.tag import filter_to_alive_tags, get_tag | ||||
| from data.model.oci.tag import filter_to_alive_tags, get_tag, create_temporary_tag | ||||
| from data.model.oci.shared import get_legacy_image_for_manifest | ||||
| from data.model.oci.label import list_manifest_labels | ||||
| from data.model.repository import get_repository, create_repository | ||||
|  | @ -47,6 +48,53 @@ def test_lookup_manifest_dead_tag(initialized_db): | |||
|           dead_tag.manifest) | ||||
| 
 | ||||
| 
 | ||||
| def test_lookup_manifest_child_tag(initialized_db): | ||||
|   repository = create_repository('devtable', 'newrepo', None) | ||||
| 
 | ||||
|   # Populate a manifest. | ||||
|   layer_json = json.dumps({ | ||||
|     'config': {}, | ||||
|     "rootfs": { | ||||
|       "type": "layers", | ||||
|       "diff_ids": [] | ||||
|     }, | ||||
|     "history": [], | ||||
|   }) | ||||
| 
 | ||||
|   # Add a blob containing the config. | ||||
|   _, config_digest = _populate_blob(layer_json) | ||||
| 
 | ||||
|   remote_digest = sha256_digest('something') | ||||
|   builder = DockerSchema2ManifestBuilder() | ||||
|   builder.set_config_digest(config_digest, len(layer_json)) | ||||
|   builder.add_layer(remote_digest, 1234, urls=['http://hello/world']) | ||||
|   manifest = builder.build() | ||||
| 
 | ||||
|   assert get_or_create_manifest(repository, manifest, storage) | ||||
| 
 | ||||
|   # Ensure the manifest cannot currently be looked up, as it is pointed to by an alive tag. | ||||
|   assert lookup_manifest(repository, manifest.digest) is None | ||||
|   assert lookup_manifest(repository, manifest.digest, allow_dead=True) is not None | ||||
| 
 | ||||
|   # Populate a manifest list. | ||||
|   list_builder = DockerSchema2ManifestListBuilder() | ||||
|   list_builder.add_manifest(manifest, 'amd64', 'linux') | ||||
|   manifest_list = list_builder.build() | ||||
| 
 | ||||
|   # Write the manifest list, which should also write the manifests themselves. | ||||
|   created_tuple = get_or_create_manifest(repository, manifest_list, storage) | ||||
|   assert created_tuple is not None | ||||
| 
 | ||||
|   assert lookup_manifest(repository, manifest.digest) is None | ||||
|   assert lookup_manifest(repository, manifest_list.digest) is None | ||||
| 
 | ||||
|   # Point a tag at the manifest list. This should make it and its child manifest visible. | ||||
|   create_temporary_tag(created_tuple.manifest, 1000) | ||||
| 
 | ||||
|   assert lookup_manifest(repository, manifest.digest) is not None | ||||
|   assert lookup_manifest(repository, manifest_list.digest) is not None | ||||
| 
 | ||||
| 
 | ||||
| def _populate_blob(content): | ||||
|   digest = str(sha256_digest(content)) | ||||
|   location = ImageStorageLocation.get(name='local_us') | ||||
|  |  | |||
		Reference in a new issue