mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-07-24 15:49:42 +02:00
* refactor(backend): ♻️ cleanup duplicate code in http services * refactor(backend): ♻️ refactor database away from singleton design removed the database single and instead injected the session into a new Database class that is created during each request life-cycle. Now sessions no longer need to be passed into each method on the database All tests pass, but there are likely some hidden breaking changes that were not discovered. * fix venv * disable venv cache * fix install script * bump poetry version * postgres fixes * revert install * fix db initialization for postgres * add postgres to docker * refactor(backend): ♻️ cleanup unused and duplicate code in http services * refactor(backend): remove sessions from arguments * refactor(backend): ♻️ convert units and ingredients to use http service class * test(backend): ✅ add unit and food tests * lint * update tags * re-enable cache * fix missing fraction in db * fix lint Co-authored-by: hay-kot <hay-kot@pm.me>
84 lines
2.7 KiB
Python
84 lines
2.7 KiB
Python
import pytest
|
|
from fastapi.testclient import TestClient
|
|
|
|
from mealie.schema.recipe.recipe_ingredient import CreateIngredientUnit
|
|
from tests.utils.factories import random_bool, random_string
|
|
from tests.utils.fixture_schemas import TestUser
|
|
|
|
|
|
class Routes:
|
|
base = "/api/units"
|
|
|
|
def item(item_id: int) -> str:
|
|
return f"{Routes.base}/{item_id}"
|
|
|
|
|
|
@pytest.fixture(scope="function")
|
|
def unit(api_client: TestClient, unique_user: TestUser) -> dict:
|
|
data = CreateIngredientUnit(
|
|
name=random_string(10),
|
|
description=random_string(10),
|
|
fraction=random_bool(),
|
|
abbreviation=random_string(3) + ".",
|
|
).dict(by_alias=True)
|
|
|
|
response = api_client.post(Routes.base, json=data, headers=unique_user.token)
|
|
|
|
assert response.status_code == 201
|
|
|
|
yield response.json()
|
|
|
|
response = api_client.delete(Routes.item(response.json()["id"]), headers=unique_user.token)
|
|
|
|
|
|
def test_create_unit(api_client: TestClient, unique_user: TestUser):
|
|
data = CreateIngredientUnit(
|
|
name=random_string(10),
|
|
description=random_string(10),
|
|
).dict(by_alias=True)
|
|
|
|
response = api_client.post(Routes.base, json=data, headers=unique_user.token)
|
|
assert response.status_code == 201
|
|
|
|
|
|
def test_read_unit(api_client: TestClient, unit: dict, unique_user: TestUser):
|
|
response = api_client.get(Routes.item(unit["id"]), headers=unique_user.token)
|
|
assert response.status_code == 200
|
|
|
|
as_json = response.json()
|
|
|
|
assert as_json["id"] == unit["id"]
|
|
assert as_json["name"] == unit["name"]
|
|
assert as_json["description"] == unit["description"]
|
|
assert as_json["fraction"] == unit["fraction"]
|
|
assert as_json["abbreviation"] == unit["abbreviation"]
|
|
|
|
|
|
def test_update_unit(api_client: TestClient, unit: dict, unique_user: TestUser):
|
|
update_data = {
|
|
"id": unit["id"],
|
|
"name": random_string(10),
|
|
"description": random_string(10),
|
|
"fraction": not unit["fraction"],
|
|
"abbreviation": random_string(3) + ".",
|
|
}
|
|
response = api_client.put(Routes.item(unit["id"]), json=update_data, headers=unique_user.token)
|
|
assert response.status_code == 200
|
|
as_json = response.json()
|
|
|
|
assert as_json["id"] == unit["id"]
|
|
assert as_json["name"] == update_data["name"]
|
|
assert as_json["description"] == update_data["description"]
|
|
assert as_json["fraction"] == update_data["fraction"]
|
|
assert as_json["abbreviation"] == update_data["abbreviation"]
|
|
|
|
|
|
def test_delete_unit(api_client: TestClient, unit: dict, unique_user: TestUser):
|
|
id = unit["id"]
|
|
|
|
response = api_client.delete(Routes.item(id), headers=unique_user.token)
|
|
|
|
assert response.status_code == 200
|
|
|
|
response = api_client.get(Routes.item(id), headers=unique_user.token)
|
|
assert response.status_code == 404
|