mirror of
https://gitlab.archlinux.org/archlinux/aurweb.git
synced 2025-02-03 10:43:03 +01:00
change(packages.util): handle queried record links via .is_official
This removes an unneeded query from our path. Signed-off-by: Kevin Morris <kevr@0cost.org>
This commit is contained in:
parent
fc229d755b
commit
6fdaeee026
4 changed files with 25 additions and 16 deletions
|
@ -11,6 +11,9 @@ class OfficialProvider(Base):
|
||||||
__tablename__ = __table__.name
|
__tablename__ = __table__.name
|
||||||
__mapper_args__ = {"primary_key": [__table__.c.ID]}
|
__mapper_args__ = {"primary_key": [__table__.c.ID]}
|
||||||
|
|
||||||
|
# OfficialProvider instances are official packages.
|
||||||
|
is_official = True
|
||||||
|
|
||||||
def __init__(self, **kwargs):
|
def __init__(self, **kwargs):
|
||||||
super().__init__(**kwargs)
|
super().__init__(**kwargs)
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,9 @@ class Package(Base):
|
||||||
cascade="all, delete"),
|
cascade="all, delete"),
|
||||||
foreign_keys=[__table__.c.PackageBaseID])
|
foreign_keys=[__table__.c.PackageBaseID])
|
||||||
|
|
||||||
|
# No Package instances are official packages.
|
||||||
|
is_official = False
|
||||||
|
|
||||||
def __init__(self, **kwargs):
|
def __init__(self, **kwargs):
|
||||||
super().__init__(**kwargs)
|
super().__init__(**kwargs)
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ from sqlalchemy import and_, orm
|
||||||
|
|
||||||
from aurweb import db, l10n, models, util
|
from aurweb import db, l10n, models, util
|
||||||
from aurweb.models import Package, PackageBase, User
|
from aurweb.models import Package, PackageBase, User
|
||||||
from aurweb.models.official_provider import OFFICIAL_BASE
|
from aurweb.models.official_provider import OFFICIAL_BASE, OfficialProvider
|
||||||
from aurweb.models.package_comaintainer import PackageComaintainer
|
from aurweb.models.package_comaintainer import PackageComaintainer
|
||||||
from aurweb.models.package_dependency import PackageDependency
|
from aurweb.models.package_dependency import PackageDependency
|
||||||
from aurweb.models.relation_type import PROVIDES_ID
|
from aurweb.models.relation_type import PROVIDES_ID
|
||||||
|
@ -61,20 +61,18 @@ def dep_extra_desc(dep: models.PackageDependency) -> str:
|
||||||
|
|
||||||
@register_filter("pkgname_link")
|
@register_filter("pkgname_link")
|
||||||
def pkgname_link(pkgname: str) -> str:
|
def pkgname_link(pkgname: str) -> str:
|
||||||
base = "/".join([OFFICIAL_BASE, "packages"])
|
official = db.query(OfficialProvider).filter(
|
||||||
official = db.query(models.OfficialProvider).filter(
|
OfficialProvider.Name == pkgname).exists()
|
||||||
models.OfficialProvider.Name == pkgname).exists()
|
|
||||||
if db.query(official).scalar():
|
if db.query(official).scalar():
|
||||||
|
base = "/".join([OFFICIAL_BASE, "packages"])
|
||||||
return f"{base}/?q={pkgname}"
|
return f"{base}/?q={pkgname}"
|
||||||
return f"/packages/{pkgname}"
|
return f"/packages/{pkgname}"
|
||||||
|
|
||||||
|
|
||||||
@register_filter("package_link")
|
@register_filter("package_link")
|
||||||
def package_link(package: models.Package) -> str:
|
def package_link(package: Union[Package, OfficialProvider]) -> str:
|
||||||
base = "/".join([OFFICIAL_BASE, "packages"])
|
if package.is_official:
|
||||||
official = db.query(models.OfficialProvider).filter(
|
base = "/".join([OFFICIAL_BASE, "packages"])
|
||||||
models.OfficialProvider.Name == package.Name).exists()
|
|
||||||
if db.query(official).scalar():
|
|
||||||
return f"{base}/?q={package.Name}"
|
return f"{base}/?q={package.Name}"
|
||||||
return f"/packages/{package.Name}"
|
return f"/packages/{package.Name}"
|
||||||
|
|
||||||
|
|
|
@ -46,16 +46,21 @@ def client() -> TestClient:
|
||||||
yield TestClient(app=asgi.app)
|
yield TestClient(app=asgi.app)
|
||||||
|
|
||||||
|
|
||||||
def test_package_link(client: TestClient, maintainer: User, package: Package):
|
def test_package_link(client: TestClient, package: Package):
|
||||||
with db.begin():
|
expected = f"/packages/{package.Name}"
|
||||||
db.create(OfficialProvider,
|
|
||||||
Name=package.Name,
|
|
||||||
Repo="core",
|
|
||||||
Provides=package.Name)
|
|
||||||
expected = f"{OFFICIAL_BASE}/packages/?q={package.Name}"
|
|
||||||
assert util.package_link(package) == expected
|
assert util.package_link(package) == expected
|
||||||
|
|
||||||
|
|
||||||
|
def test_official_package_link(client: TestClient, package: Package):
|
||||||
|
with db.begin():
|
||||||
|
provider = db.create(OfficialProvider,
|
||||||
|
Name=package.Name,
|
||||||
|
Repo="core",
|
||||||
|
Provides=package.Name)
|
||||||
|
expected = f"{OFFICIAL_BASE}/packages/?q={package.Name}"
|
||||||
|
assert util.package_link(provider) == expected
|
||||||
|
|
||||||
|
|
||||||
def test_updated_packages(maintainer: User, package: Package):
|
def test_updated_packages(maintainer: User, package: Package):
|
||||||
expected = {
|
expected = {
|
||||||
"Name": package.Name,
|
"Name": package.Name,
|
||||||
|
|
Loading…
Add table
Reference in a new issue