Fetch source projects of requests

We do not care for current devel project, but for the projects we saw
requests from
This commit is contained in:
Stephan Kulow 2022-11-02 08:50:54 +01:00
parent 8a863498db
commit bbf1bc2fda
4 changed files with 38 additions and 19 deletions

View File

@ -6,8 +6,8 @@ import pathlib
import sys import sys
import osc.core import osc.core
from lib.git_exporter import GitExporter
from lib.git_exporter import GitExporter
from lib.importer import Importer from lib.importer import Importer
from lib.test_exporter import TestExporter from lib.test_exporter import TestExporter

View File

@ -1,13 +1,16 @@
import logging import logging
import os import os
from lib.binary import is_binary_or_large
import yaml import yaml
from lib.binary import is_binary_or_large
from lib.db import DB from lib.db import DB
from lib.git import Git from lib.git import Git
from lib.obs import OBS from lib.obs import OBS
from lib.proxy_sha256 import ProxySHA256, md5 from lib.proxy_sha256 import ProxySHA256, md5
from lib.tree_builder import TreeBuilder from lib.tree_builder import TreeBuilder
class GitExporter: class GitExporter:
def __init__(self, api_url, project, package, repodir): def __init__(self, api_url, project, package, repodir):
self.obs = OBS() self.obs = OBS()
@ -24,7 +27,6 @@ class GitExporter:
self.state_file = os.path.join(self.git.path, ".git", "_flat_state.yaml") self.state_file = os.path.join(self.git.path, ".git", "_flat_state.yaml")
self.gc_interval = 200 self.gc_interval = 200
def download(self, revision): def download(self, revision):
obs_files = self.obs.files(revision.project, revision.package, revision.srcmd5) obs_files = self.obs.files(revision.project, revision.package, revision.srcmd5)
git_files = { git_files = {

View File

@ -5,9 +5,9 @@ from lib.db import DB
from lib.db_revision import DBRevision from lib.db_revision import DBRevision
from lib.obs import OBS from lib.obs import OBS
from lib.obs_revision import OBSRevision from lib.obs_revision import OBSRevision
from lib.user import User from lib.user import User
class Importer: class Importer:
def __init__(self, api_url, project, package): def __init__(self, api_url, project, package):
# Import a Factory package into the database # Import a Factory package into the database
@ -17,7 +17,8 @@ class Importer:
self.obs = OBS() self.obs = OBS()
assert project == "openSUSE:Factory" assert project == "openSUSE:Factory"
self.obs.change_url(api_url) self.obs.change_url(api_url)
self.refreshed_packages = set()
def update_db_package(self, db, project, package): def update_db_package(self, db, project, package):
root = self.obs._history(project, package) root = self.obs._history(project, package)
if root is None: if root is None:
@ -149,21 +150,9 @@ class Importer:
) )
return [DBRevision(row) for row in cur.fetchall()] return [DBRevision(row) for row in cur.fetchall()]
def fill_file_lists(self, db):
def import_into_db(self):
db = DB()
self.update_db_package(db, self.project, self.package)
self.fetch_all_linked_packages(db, self.project, self.package)
# all remaining, no filtering here
self.find_linked_revs(db) self.find_linked_revs(db)
missing_users = User.missing_users(db)
for userid in missing_users:
missing_user = self.obs.user(userid)
if missing_user:
missing_user.import_into_db(db)
self.find_fake_revisions(db) self.find_fake_revisions(db)
for rev in self.revisions_without_files(db): for rev in self.revisions_without_files(db):
with db.cursor() as cur: with db.cursor() as cur:
@ -189,7 +178,35 @@ class Importer:
else: else:
rev.set_broken(db) rev.set_broken(db)
def refresh_package(self, db, project, package):
key = f"{project}/{package}"
if key in self.refreshed_packages:
# refreshing once is good enough
return
self.refreshed_packages.add(key)
self.update_db_package(db, project, package)
self.fetch_all_linked_packages(db, project, package)
def import_into_db(self):
db = DB()
self.refresh_package(db, self.project, self.package)
for number in DBRevision.requests_to_fetch(db): for number in DBRevision.requests_to_fetch(db):
self.obs.request(number).import_into_db(db) self.obs.request(number).import_into_db(db)
with db.cursor() as cur:
cur.execute(
"""SELECT DISTINCT source_project,source_package FROM requests
WHERE id IN (SELECT request_id FROM revisions WHERE project=%s and package=%s);""",
(self.project, self.package),
)
for project, package in cur.fetchall():
self.refresh_package(db, project, package)
missing_users = User.missing_users(db)
for userid in missing_users:
missing_user = self.obs.user(userid)
if missing_user:
missing_user.import_into_db(db)
self.fill_file_lists(db)
db.conn.commit() db.conn.commit()

View File

@ -19,7 +19,7 @@ class TestTreeMethods(unittest.TestCase):
for rev in data["revisions"]: for rev in data["revisions"]:
DBRevision.import_fixture_dict(self.db, rev) DBRevision.import_fixture_dict(self.db, rev)
revisions = TreeBuilder(self.db).build(package) revisions = TreeBuilder(self.db).build("openSUSE:Factory", package)
path = os.path.join( path = os.path.join(
os.path.dirname(__file__), f"fixtures/{package}-expected-tree.yaml" os.path.dirname(__file__), f"fixtures/{package}-expected-tree.yaml"
) )