Merge pull request #3333 from quay/additional-tag-backfill-tests

Additional tag backfill tests, config and logs
This commit is contained in:
Joseph Schorr 2019-01-16 13:12:44 -05:00 committed by GitHub
commit c60e3e0341
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 34 additions and 8 deletions

View file

@ -8,11 +8,13 @@ from peewee import JOIN, fn, IntegrityError
from app import app from app import app
from data.database import (UseThenDisconnect, TagToRepositoryTag, RepositoryTag, from data.database import (UseThenDisconnect, TagToRepositoryTag, RepositoryTag,
TagManifestToManifest, Tag, TagManifest, TagManifestToManifest, Image, TagManifestToManifest, Tag, TagManifest, TagManifestToManifest, Image,
Manifest, TagManifestLabel, ManifestLabel, TagManifestLabelMap, db_transaction) Manifest, TagManifestLabel, ManifestLabel, TagManifestLabelMap,
Repository, db_transaction)
from data.model import DataModelException from data.model import DataModelException
from data.model.image import get_parent_images from data.model.image import get_parent_images
from data.model.tag import populate_manifest from data.model.tag import populate_manifest
from data.model.blob import get_repo_blob_by_digest, BlobDoesNotExist from data.model.blob import get_repo_blob_by_digest, BlobDoesNotExist
from data.model.user import get_namespace_user
from data.registry_model import pre_oci_model from data.registry_model import pre_oci_model
from data.registry_model.datatypes import Tag as TagDataType from data.registry_model.datatypes import Tag as TagDataType
from image.docker.schema1 import (DockerSchema1Manifest, ManifestException, ManifestInterface, from image.docker.schema1 import (DockerSchema1Manifest, ManifestException, ManifestInterface,
@ -109,19 +111,30 @@ class BrokenManifest(ManifestInterface):
class TagBackfillWorker(Worker): class TagBackfillWorker(Worker):
def __init__(self): def __init__(self, namespace_filter=None):
super(TagBackfillWorker, self).__init__() super(TagBackfillWorker, self).__init__()
self._namespace_filter = namespace_filter
self.add_operation(self._backfill_tags, WORKER_TIMEOUT) self.add_operation(self._backfill_tags, WORKER_TIMEOUT)
def _filter(self, query):
if self._namespace_filter:
logger.info('Filtering by namespace `%s`', self._namespace_filter)
namespace_user = get_namespace_user(self._namespace_filter)
query = query.join(Repository).where(Repository.namespace_user == namespace_user)
return query
def _candidates_to_backfill(self): def _candidates_to_backfill(self):
def missing_tmt_query(): def missing_tmt_query():
return (RepositoryTag return (self._filter(RepositoryTag.select())
.select()
.join(TagToRepositoryTag, JOIN.LEFT_OUTER) .join(TagToRepositoryTag, JOIN.LEFT_OUTER)
.where(TagToRepositoryTag.id >> None, RepositoryTag.hidden == False)) .where(TagToRepositoryTag.id >> None, RepositoryTag.hidden == False))
min_id = (RepositoryTag.select(fn.Min(RepositoryTag.id)).scalar()) min_id = (self._filter(RepositoryTag.select(fn.Min(RepositoryTag.id))).scalar())
max_id = RepositoryTag.select(fn.Max(RepositoryTag.id)).scalar() max_id = self._filter(RepositoryTag.select(fn.Max(RepositoryTag.id))).scalar()
logger.info('Found candidate range %s-%s', min_id, max_id)
iterator = yield_random_entries( iterator = yield_random_entries(
missing_tmt_query, missing_tmt_query,
@ -368,5 +381,5 @@ if __name__ == "__main__":
while True: while True:
time.sleep(100000) time.sleep(100000)
worker = TagBackfillWorker() worker = TagBackfillWorker(app.config.get('BACKFILL_TAGS_NAMESPACE'))
worker.start() worker.start()

View file

@ -2,7 +2,7 @@ from app import docker_v2_signing_key
from data import model from data import model
from data.database import (TagManifestLabelMap, TagManifestToManifest, Manifest, ManifestBlob, from data.database import (TagManifestLabelMap, TagManifestToManifest, Manifest, ManifestBlob,
ManifestLegacyImage, ManifestLabel, TagManifest, RepositoryTag, Image, ManifestLegacyImage, ManifestLabel, TagManifest, RepositoryTag, Image,
TagManifestLabel, Tag, TagToRepositoryTag) TagManifestLabel, Tag, TagToRepositoryTag, Repository)
from image.docker.schema1 import DockerSchema1ManifestBuilder from image.docker.schema1 import DockerSchema1ManifestBuilder
from workers.tagbackfillworker import backfill_tag, _backfill_manifest from workers.tagbackfillworker import backfill_tag, _backfill_manifest
@ -39,6 +39,8 @@ def test_tagbackfillworker(clear_all_rows, initialized_db):
TagManifestToManifest.delete().execute() TagManifestToManifest.delete().execute()
Manifest.delete().execute() Manifest.delete().execute()
found_dead_tag = False
for repository_tag in list(RepositoryTag.select()): for repository_tag in list(RepositoryTag.select()):
# Backfill the tag. # Backfill the tag.
assert backfill_tag(repository_tag) assert backfill_tag(repository_tag)
@ -63,6 +65,7 @@ def test_tagbackfillworker(clear_all_rows, initialized_db):
assert tag.lifetime_end_ms is None assert tag.lifetime_end_ms is None
else: else:
assert tag.lifetime_end_ms == (repository_tag.lifetime_end_ts * 1000) assert tag.lifetime_end_ms == (repository_tag.lifetime_end_ts * 1000)
found_dead_tag = True
assert tag.manifest assert tag.manifest
@ -100,6 +103,16 @@ def test_tagbackfillworker(clear_all_rows, initialized_db):
in ManifestLabel.select().where(ManifestLabel.manifest == manifest_row)} in ManifestLabel.select().where(ManifestLabel.manifest == manifest_row)}
assert found_labels == expected_labels assert found_labels == expected_labels
# Verify at the repository level.
for repository in list(Repository.select()):
tags = RepositoryTag.select().where(RepositoryTag.repository == repository,
RepositoryTag.hidden == False)
oci_tags = Tag.select().where(Tag.repository == repository)
assert len(tags) == len(oci_tags)
assert {t.name for t in tags} == {t.name for t in oci_tags}
assert found_dead_tag
def test_manifestbackfillworker_broken_manifest(clear_rows, initialized_db): def test_manifestbackfillworker_broken_manifest(clear_rows, initialized_db):
# Delete existing tag manifest so we can reuse the tag. # Delete existing tag manifest so we can reuse the tag.