Split Revision into OBS and DB

This commit is contained in:
Stephan Kulow 2022-10-18 12:17:43 +02:00
parent c534fb028e
commit 25b45c5073
6 changed files with 54 additions and 15 deletions

View File

@ -54,11 +54,12 @@ class DB:
) )
""", """,
"INSERT INTO scheme (version) VALUES(1)", "INSERT INTO scheme (version) VALUES(1)",
""" DROP TABLE IF EXISTS revisions""",
""" CREATE TABLE revisions ( """ CREATE TABLE revisions (
id SERIAL PRIMARY KEY, id SERIAL PRIMARY KEY,
project VARCHAR(255) NOT NULL, project VARCHAR(255) NOT NULL,
package VARCHAR(255) NOT NULL, package VARCHAR(255) NOT NULL,
rev VARCHAR(255) NOT NULL, rev INTEGER NOT NULL,
unexpanded_srcmd5 VARCHAR(255) NOT NULL, unexpanded_srcmd5 VARCHAR(255) NOT NULL,
commit_time timestamp NOT NULL, commit_time timestamp NOT NULL,
userid VARCHAR(255) NOT NULL, userid VARCHAR(255) NOT NULL,
@ -66,6 +67,9 @@ class DB:
requestid INTEGER requestid INTEGER
) )
""", """,
"""
CREATE UNIQUE INDEX ppr ON revisions (project, package, rev);
"""
) )
if self.schema_version() > 0: if self.schema_version() > 0:
@ -84,9 +88,11 @@ class DB:
self.close() self.close()
raise error raise error
def cursor(self):
return self.conn.cursor()
def import_rev(self, revision): def import_rev(self, revision):
cur = self.conn.cursor() cur = self.conn.cursor()
print(revision)
cur.execute( cur.execute(
"""INSERT INTO revisions (project, package, rev, unexpanded_srcmd5, commit_time, userid, comment, requestid) """INSERT INTO revisions (project, package, rev, unexpanded_srcmd5, commit_time, userid, comment, requestid)
VALUES(%s, %s, %s, %s, %s, %s, %s, %s)""", VALUES(%s, %s, %s, %s, %s, %s, %s, %s)""",

22
lib/db_revision.py Normal file
View File

@ -0,0 +1,22 @@
class DBRevision:
def __init__(self, row):
(self.dbid, self.project, self.package, self.rev, self.unexpanded_srcmd5, self.commit_time, self.userid, self.comment, self.requestid) = row
@classmethod
def fetch_revision(cls, db, project, package, rev):
cur = db.cursor()
cur.execute("SELECT * FROM revisions where project=%s and package=%s and rev=%s", (project, package, rev))
row = cur.fetchone()
cur.close()
return DBRevision(row)
@classmethod
def latest_revision(cls, db, project, package):
cur = db.cursor()
cur.execute("SELECT MAX(rev) FROM revisions where project=%s and package=%s", (project, package))
max = cur.fetchone()[0]
cur.close()
if max:
return DBRevision.fetch_revision(db, project, package, int(max))
return None

View File

@ -2,7 +2,7 @@ import itertools
import logging import logging
import re import re
from lib.revision import Revision from lib.obs_revision import OBSRevision
class History: class History:
@ -33,7 +33,7 @@ class History:
root = self.obs._history(project, self.package, **params) root = self.obs._history(project, self.package, **params)
if root is not None: if root is not None:
return [ return [
Revision(self.obs, self, project, self.package).parse(r) OBSRevision(self.obs, self, project, self.package).parse(r)
for r in root.findall("revision") for r in root.findall("revision")
] ]

View File

@ -6,6 +6,8 @@ from lib.db import DB
from lib.git import Git from lib.git import Git
from lib.history import History from lib.history import History
from lib.obs import OBS from lib.obs import OBS
from lib.obs_revision import OBSRevision
from lib.db_revision import DBRevision
from lib.proxy_sha256 import ProxySHA256, md5, sha256 from lib.proxy_sha256 import ProxySHA256, md5, sha256
@ -121,14 +123,23 @@ class Importer:
print(f"Remove {name}") print(f"Remove {name}")
self.git.remove(name) self.git.remove(name)
def import_into_db(self): def update_db_package(self, db, project, package):
db = DB() root = self.obs._history(project, package)
self.history.fetch_all_revisions(self.projects) if root is None:
for project, _, _ in self.projects: return
for rev in self.history[project]: latest = DBRevision.latest_revision(db, project, self.package)
for r in root.findall("revision"):
rev = OBSRevision(self.obs, self, project, self.package).parse(r)
if not latest or rev.rev > latest.rev:
db.import_rev(rev) db.import_rev(rev)
db.conn.commit() db.conn.commit()
def import_into_db(self):
db = DB()
for project, _, api_url in self.projects:
self.obs.change_url(api_url)
self.update_db_package(db, project, self.package)
def import_all_revisions(self, gc): def import_all_revisions(self, gc):
# Fetch all the requests and sort them. Ideally we should # Fetch all the requests and sort them. Ideally we should
# build the graph here, to avoid new commits before the merge. # build the graph here, to avoid new commits before the merge.

View File

@ -5,7 +5,7 @@ import xml.etree.ElementTree as ET
from urllib.error import HTTPError from urllib.error import HTTPError
class Revision: class OBSRevision:
def __init__(self, obs, history, project, package): def __init__(self, obs, history, project, package):
self.obs = obs self.obs = obs
self.history = history self.history = history

View File

@ -4,7 +4,7 @@ import xml.etree.ElementTree as ET
from lib.db import DB from lib.db import DB
from lib.history import History from lib.history import History
from lib.obs import OBS from lib.obs import OBS
from lib.revision import Revision from lib.obs_revision import OBSRevision
class TestDBMethods(unittest.TestCase): class TestDBMethods(unittest.TestCase):
@ -14,7 +14,7 @@ class TestDBMethods(unittest.TestCase):
self.history = History(self.obs, "xz") self.history = History(self.obs, "xz")
def test_import(self): def test_import(self):
test_rev = Revision(self.obs, self.history, "openSUSE:Factory", "xz") test_rev = OBSRevision(self.obs, self.history, "openSUSE:Factory", "xz")
test_rev.parse( test_rev.parse(
ET.fromstring( ET.fromstring(
"""<revision rev="70" vrev="1"> """<revision rev="70" vrev="1">