Add tests for package release filtering

This commit is contained in:
rubenwardy 2021-05-03 18:27:20 +01:00
parent dcc34570d5
commit d64463235c
6 changed files with 255 additions and 62 deletions

@ -22,7 +22,7 @@ from app import csrf
from app.utils.markdown import render_markdown from app.utils.markdown import render_markdown
from app.models import Tag, PackageState, PackageType, Package, db, PackageRelease, Permission, ForumTopic, MinetestRelease, APIToken, PackageScreenshot, License, ContentWarning, User from app.models import Tag, PackageState, PackageType, Package, db, PackageRelease, Permission, ForumTopic, MinetestRelease, APIToken, PackageScreenshot, License, ContentWarning, User
from app.querybuilder import QueryBuilder from app.querybuilder import QueryBuilder
from app.utils import is_package_page from app.utils import is_package_page, get_int_or_abort
from . import bp from . import bp
from .auth import is_api_authd from .auth import is_api_authd
from .support import error, api_create_vcs_release, api_create_zip_release, api_create_screenshot, api_order_screenshots, api_edit_package from .support import error, api_create_vcs_release, api_create_zip_release, api_create_screenshot, api_order_screenshots, api_edit_package
@ -390,5 +390,14 @@ def homepage():
@bp.route("/api/minetest_versions/") @bp.route("/api/minetest_versions/")
def versions(): def versions():
protocol_version = request.args.get("protocol_version")
engine_version = request.args.get("engine_version")
if protocol_version or engine_version:
rel = MinetestRelease.get(engine_version, get_int_or_abort(protocol_version))
if rel is None:
error(404, "No releases found")
return jsonify(rel.getAsDictionary())
return jsonify([rel.getAsDictionary() \ return jsonify([rel.getAsDictionary() \
for rel in MinetestRelease.query.all() if rel.getActual() is not None]) for rel in MinetestRelease.query.all() if rel.getActual() is not None])

@ -15,6 +15,8 @@ def populate(session):
session.add(MinetestRelease("0.4.16/17", 32)) session.add(MinetestRelease("0.4.16/17", 32))
session.add(MinetestRelease("5.0", 37)) session.add(MinetestRelease("5.0", 37))
session.add(MinetestRelease("5.1", 38)) session.add(MinetestRelease("5.1", 38))
session.add(MinetestRelease("5.2", 39))
session.add(MinetestRelease("5.3", 39))
tags = {} tags = {}
for tag in ["Inventory", "Mapgen", "Building", for tag in ["Inventory", "Mapgen", "Building",

@ -796,7 +796,8 @@ class MinetestRelease(db.Model):
if protocol_num: if protocol_num:
# Find the closest matching release # Find the closest matching release
return MinetestRelease.query.order_by(db.desc(MinetestRelease.protocol)) \ return MinetestRelease.query.order_by(db.desc(MinetestRelease.protocol),
db.desc(MinetestRelease.id)) \
.filter(MinetestRelease.protocol <= protocol_num).first() .filter(MinetestRelease.protocol <= protocol_num).first()
return None return None

@ -1,31 +1,9 @@
from app.default_data import populate_test_data from app.default_data import populate_test_data
from app.models import db, Package, PackageState from app.models import db, Package, PackageState
from .utils import is_str, is_int, is_optional, parse_json from .utils import parse_json, validate_package_list
from .utils import client # noqa from .utils import client # noqa
def validate_package_list(packages, strict=False):
valid_keys = {
"author", "name", "release",
"short_description", "thumbnail",
"title", "type"
}
for package in packages:
assert set(package.keys()).issubset(valid_keys)
assert is_str(package.get("author"))
assert is_str(package.get("name"))
if strict:
assert is_int(package.get("release"))
else:
assert is_optional(int, package.get("release"))
assert is_str(package.get("short_description"))
assert is_optional(str, package.get("thumbnail"))
assert is_str(package.get("title"))
assert is_str(package.get("type"))
def test_packages_empty(client): def test_packages_empty(client):
"""Start with a blank database.""" """Start with a blank database."""
@ -66,40 +44,3 @@ def test_packages_with_query(client):
assert (packages[0]["name"] == "food" and packages[1]["name"] == "food_sweet") or \ assert (packages[0]["name"] == "food" and packages[1]["name"] == "food_sweet") or \
(packages[1]["name"] == "food" and packages[0]["name"] == "food_sweet") (packages[1]["name"] == "food" and packages[0]["name"] == "food_sweet")
def test_packages_with_protocol_high(client):
"""Start with a test database."""
populate_test_data(db.session)
db.session.commit()
rv = client.get("/api/packages/?protocol_version=100")
packages = parse_json(rv.data)
for package in packages:
assert package["name"] != "mesecons"
assert package["name"] != "handholds"
assert len(packages) == 4
validate_package_list(packages, True)
def test_packages_with_protocol_low(client):
"""Start with a test database."""
populate_test_data(db.session)
db.session.commit()
rv = client.get("/api/packages/?protocol_version=20")
packages = parse_json(rv.data)
assert len(packages) == 4
for package in packages:
assert package["name"] != "awards"
validate_package_list(packages, True)

@ -0,0 +1,218 @@
from typing import List, Tuple, Optional
from app.default_data import populate_test_data
from app.models import db, License, PackageType, User, Package, PackageState, PackageRelease, MinetestRelease
from .utils import parse_json, validate_package_list
from .utils import client # noqa
def make_package(name: str, versions: List[Tuple[Optional[str], Optional[str]]]) -> List[int]:
license = License.query.filter_by(name="MIT").first()
author = User.query.first()
mod = Package()
mod.state = PackageState.APPROVED
mod.name = name.lower()
mod.title = name
mod.license = license
mod.media_license = license
mod.type = PackageType.MOD
mod.author = author
mod.short_desc = "The content library should not be used yet as it is still in alpha"
mod.desc = "This is the long desc"
db.session.add(mod)
rels = []
for (minv, maxv) in versions:
rel = PackageRelease()
rel.package = mod
rel.title = "test"
rel.url = "https://github.com/ezhh/handholds/archive/master.zip"
if minv:
rel.min_rel = MinetestRelease.query.filter_by(name=minv).first()
assert rel.min_rel
if maxv:
rel.max_rel = MinetestRelease.query.filter_by(name=maxv).first()
assert rel.max_rel
rel.approved = True
db.session.add(rel)
rels.append(rel)
db.session.flush()
return [rel.id for rel in rels]
def test_packages_with_protocol_multi_high(client):
"""Start with a test database."""
populate_test_data(db.session)
db.session.commit()
rv = client.get("/api/packages/?protocol_version=100")
packages = parse_json(rv.data)
for package in packages:
assert package["name"] != "mesecons"
assert package["name"] != "handholds"
assert len(packages) == 4
validate_package_list(packages, True)
def test_packages_with_protocol_multi_low(client):
"""Start with a test database."""
populate_test_data(db.session)
db.session.commit()
rv = client.get("/api/packages/?protocol_version=20")
packages = parse_json(rv.data)
assert len(packages) == 4
for package in packages:
assert package["name"] != "awards"
validate_package_list(packages, True)
def test_packages_with_protocol_max_ver(client):
"""Start with a blank database."""
make_package("Bob", [ (None, "5.0") ])
db.session.commit()
packages = parse_json(client.get("/api/packages/?protocol_version=20").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
packages = parse_json(client.get("/api/packages/?protocol_version=32").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
packages = parse_json(client.get("/api/packages/?protocol_version=37").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
packages = parse_json(client.get("/api/packages/?protocol_version=38").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=40").data)
assert len(packages) == 0
validate_package_list(packages, True)
def test_packages_with_protocol_min_ver(client):
"""Start with a blank database."""
make_package("Bob", [("5.0", None)])
db.session.commit()
packages = parse_json(client.get("/api/packages/?protocol_version=20").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=32").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=37").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
packages = parse_json(client.get("/api/packages/?protocol_version=38").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
packages = parse_json(client.get("/api/packages/?protocol_version=40").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
validate_package_list(packages, True)
def test_packages_with_protocol_engine_ver(client):
"""Start with a blank database."""
make_package("Bob", [("5.3", None)])
db.session.commit()
packages = parse_json(client.get("/api/packages/?protocol_version=20&engine_version=4.0").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=38&engine_version=5.1").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=39&engine_version=5.2").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=39&engine_version=5.3").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
packages = parse_json(client.get("/api/packages/?protocol_version=40&engine_version=5.6").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
validate_package_list(packages, True)
def test_packages_with_protocol_exact(client):
"""Start with a blank database."""
make_package("Bob", [("5.0", "5.0")])
db.session.commit()
packages = parse_json(client.get("/api/packages/?protocol_version=20").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=32").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=37").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
packages = parse_json(client.get("/api/packages/?protocol_version=38").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=40").data)
assert len(packages) == 0
validate_package_list(packages, True)
def test_packages_with_protocol_options(client):
"""Start with a blank database."""
rels = make_package("Bob", [(None, "0.4.16/17"), ("5.1", "5.1")])
db.session.commit()
packages = parse_json(client.get("/api/packages/?protocol_version=20").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
assert packages[0]["release"] == rels[0]
packages = parse_json(client.get("/api/packages/?protocol_version=32").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
assert packages[0]["release"] == rels[0]
packages = parse_json(client.get("/api/packages/?protocol_version=37").data)
assert len(packages) == 0
packages = parse_json(client.get("/api/packages/?protocol_version=38").data)
assert len(packages) == 1
assert packages[0]["name"] == "bob"
assert packages[0]["release"] == rels[1]
packages = parse_json(client.get("/api/packages/?protocol_version=40").data)
assert len(packages) == 0
validate_package_list(packages, True)

@ -43,3 +43,25 @@ def client():
yield client yield client
app.config["TESTING"] = False app.config["TESTING"] = False
def validate_package_list(packages, strict=False):
valid_keys = {
"author", "name", "release",
"short_description", "thumbnail",
"title", "type"
}
for package in packages:
assert set(package.keys()).issubset(valid_keys)
assert is_str(package.get("author"))
assert is_str(package.get("name"))
if strict:
assert is_int(package.get("release"))
else:
assert is_optional(int, package.get("release"))
assert is_str(package.get("short_description"))
assert is_optional(str, package.get("thumbnail"))
assert is_str(package.get("title"))
assert is_str(package.get("type"))