mirror of
https://gitlab.archlinux.org/archlinux/aurweb.git
synced 2025-02-03 10:43:03 +01:00
housekeep(fastapi): rewrite test_package_base with fixtures
Signed-off-by: Kevin Morris <kevr@0cost.org>
This commit is contained in:
parent
93bc91cce2
commit
171b347dad
1 changed files with 21 additions and 36 deletions
|
@ -2,35 +2,36 @@ import pytest
|
||||||
|
|
||||||
from sqlalchemy.exc import IntegrityError
|
from sqlalchemy.exc import IntegrityError
|
||||||
|
|
||||||
import aurweb.config
|
|
||||||
|
|
||||||
from aurweb import db
|
from aurweb import db
|
||||||
from aurweb.models.account_type import AccountType
|
from aurweb.models.account_type import USER_ID
|
||||||
from aurweb.models.package_base import PackageBase
|
from aurweb.models.package_base import PackageBase
|
||||||
from aurweb.models.user import User
|
from aurweb.models.user import User
|
||||||
|
|
||||||
user = None
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(autouse=True)
|
@pytest.fixture(autouse=True)
|
||||||
def setup(db_test):
|
def setup(db_test):
|
||||||
global user
|
return
|
||||||
|
|
||||||
account_type = db.query(AccountType,
|
|
||||||
AccountType.AccountType == "User").first()
|
@pytest.fixture
|
||||||
|
def user() -> User:
|
||||||
with db.begin():
|
with db.begin():
|
||||||
user = db.create(User, Username="test", Email="test@example.org",
|
user = db.create(User, Username="test", Email="test@example.org",
|
||||||
RealName="Test User", Passwd="testPassword",
|
RealName="Test User", Passwd="testPassword",
|
||||||
AccountType=account_type)
|
AccountTypeID=USER_ID)
|
||||||
|
yield user
|
||||||
|
|
||||||
|
|
||||||
def test_package_base():
|
@pytest.fixture
|
||||||
|
def pkgbase(user: User) -> PackageBase:
|
||||||
with db.begin():
|
with db.begin():
|
||||||
pkgbase = db.create(PackageBase,
|
pkgbase = db.create(PackageBase, Name="beautiful-package",
|
||||||
Name="beautiful-package",
|
|
||||||
Maintainer=user)
|
Maintainer=user)
|
||||||
assert pkgbase in user.maintained_bases
|
yield pkgbase
|
||||||
|
|
||||||
|
|
||||||
|
def test_package_base(user: User, pkgbase: PackageBase):
|
||||||
|
assert pkgbase in user.maintained_bases
|
||||||
assert not pkgbase.OutOfDateTS
|
assert not pkgbase.OutOfDateTS
|
||||||
assert pkgbase.SubmittedTS > 0
|
assert pkgbase.SubmittedTS > 0
|
||||||
assert pkgbase.ModifiedTS > 0
|
assert pkgbase.ModifiedTS > 0
|
||||||
|
@ -42,33 +43,19 @@ def test_package_base():
|
||||||
assert pkgbase.Popularity == 0.0
|
assert pkgbase.Popularity == 0.0
|
||||||
|
|
||||||
|
|
||||||
def test_package_base_ci():
|
def test_package_base_ci(user: User, pkgbase: PackageBase):
|
||||||
""" Test case insensitivity of the database table. """
|
""" Test case insensitivity of the database table. """
|
||||||
if aurweb.config.get("database", "backend") == "sqlite":
|
|
||||||
return None # SQLite doesn't seem handle this.
|
|
||||||
|
|
||||||
with db.begin():
|
|
||||||
pkgbase = db.create(PackageBase,
|
|
||||||
Name="beautiful-package",
|
|
||||||
Maintainer=user)
|
|
||||||
assert bool(pkgbase.ID)
|
|
||||||
|
|
||||||
with pytest.raises(IntegrityError):
|
with pytest.raises(IntegrityError):
|
||||||
with db.begin():
|
with db.begin():
|
||||||
db.create(PackageBase,
|
db.create(PackageBase, Name=pkgbase.Name.upper(), Maintainer=user)
|
||||||
Name="Beautiful-Package",
|
|
||||||
Maintainer=user)
|
|
||||||
db.rollback()
|
db.rollback()
|
||||||
|
|
||||||
|
|
||||||
def test_package_base_relationships():
|
def test_package_base_relationships(user: User, pkgbase: PackageBase):
|
||||||
with db.begin():
|
with db.begin():
|
||||||
pkgbase = db.create(PackageBase,
|
pkgbase.Flagger = user
|
||||||
Name="beautiful-package",
|
pkgbase.Submitter = user
|
||||||
Flagger=user,
|
pkgbase.Packager = user
|
||||||
Maintainer=user,
|
|
||||||
Submitter=user,
|
|
||||||
Packager=user)
|
|
||||||
assert pkgbase in user.flagged_bases
|
assert pkgbase in user.flagged_bases
|
||||||
assert pkgbase in user.maintained_bases
|
assert pkgbase in user.maintained_bases
|
||||||
assert pkgbase in user.submitted_bases
|
assert pkgbase in user.submitted_bases
|
||||||
|
@ -77,6 +64,4 @@ def test_package_base_relationships():
|
||||||
|
|
||||||
def test_package_base_null_name_raises_exception():
|
def test_package_base_null_name_raises_exception():
|
||||||
with pytest.raises(IntegrityError):
|
with pytest.raises(IntegrityError):
|
||||||
with db.begin():
|
PackageBase()
|
||||||
db.create(PackageBase)
|
|
||||||
db.rollback()
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue