mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-10-28 00:34:47 -04:00
* fix links * actually fix #238 * Feature/mkdocs version bump (#240) * fix links (#239) Co-authored-by: hay-kot <hay-kot@pm.me> * fix #238 * bump mkdocs version * light/dark toggle * light/dark mode css * API_DOCS defaults to True * disable build on push for master Co-authored-by: hay-kot <hay-kot@pm.me> * Feature/recipe viewer (#244) * fix dialog placement * markdown support in ingredients * fix line render issue * fix tag rendering bug * change ingredients to text area * no slug error * add tag pages * remove console.logs Co-authored-by: hay-kot <hay-kot@pm.me> * changelog v0.4.1 * bug/backup-download (#245) * fix blocked download * + download blocked Co-authored-by: hay-kot <hay-kot@pm.me> * Feature/meal planner (#246) * fixes duplicate recipes in meal-plan #221 * add quick week option * scope css * add mealplanner info Co-authored-by: hay-kot <hay-kot@pm.me> * Nextcloud Import Bugs - #248 (#250) * parses datetime properly + clean category - #248 * add default credentials to docs Co-authored-by: hay-kot <hay-kot@pm.me> * Add bulk import examples to docs. (#252) * Add bulk import examples to docs. * Update api-usage.md * Add Python example for bulk import. * Change IP address in API example. * Refactor/app settings (#251) * fix env setup bugs * remove unused import * fix layout issues * changelog Co-authored-by: hay-kot <hay-kot@pm.me> * env setup fixes * Feature/about api (#253) * fix settings * app info cleanup Co-authored-by: hay-kot <hay-kot@pm.me> * Feature/image minify (#256) * fix settings * app info cleanup * bottom-bar experiment * remove dup key * type hints * add dependency * updated image with query parameters * read image options * add image minification * add image minification step * alt image routes * add image minification * set mobile bar to top Co-authored-by: hay-kot <hay-kot@pm.me> * Feature/additional endpoints (#257) * new recipe summary route * add categories to cards * add pillow * show tags instead of categories * additional debug info * add todays meal image url * about page * fix reactive tag * changelog + docs * bump version Co-authored-by: hay-kot <hay-kot@pm.me> * add pillow dependencies (#258) Co-authored-by: hay-kot <hay-kot@pm.me> * Feature/search page (#259) * add pillow dependencies * advanced search page * advanced search apge * remove extra dependencies * add pre-run script Co-authored-by: hay-kot <hay-kot@pm.me> * no image assignment * advanced search * fix docker dev build * Do not force theme settings on login form (#260) * Fix docker dev db persistence (#264) * Fix docker dev db persistence * Make run.sh the only startup script for prod + dev Credits to @hay-kot for run.sh script logic * Restore dev backend initialization in non-docker setup * Make run.sh POSIX-friendly * Allow dev backend to auto-reload in Docker * Frontend Refactor + Bug Fixes * merge category and tag selector * unifiy category selector * add hint * spacing * fix nextcloud migration * simplify email validator #261 * formatting * cleanup * auto-gen * format * update run script * unified category/tag selector * rename component * Add advanced search link * remove old code * convert keywords to tags * add proper behavior on rename * proper image name association on rename * fix test cleanup * changelog * set docker comppand * minify on migration Co-authored-by: hay-kot <hay-kot@pm.me> * bug-fixes/category-tag-creator (#266) * fix category labels * set loader for migration * v0.4.1 Co-authored-by: hay-kot <hay-kot@pm.me> Co-authored-by: hay-kot <hay-kot@pm.me> Co-authored-by: Nat <nathanynath@yahoo.fr> Co-authored-by: sephrat <34862846+sephrat@users.noreply.github.com>
100 lines
3.2 KiB
Python
100 lines
3.2 KiB
Python
import json
|
|
import re
|
|
|
|
import pytest
|
|
from mealie.services.scraper.cleaner import Cleaner
|
|
from mealie.services.scraper.scraper import extract_recipe_from_html
|
|
from tests.test_config import TEST_RAW_HTML, TEST_RAW_RECIPES
|
|
|
|
# https://github.com/django/django/blob/stable/1.3.x/django/core/validators.py#L45
|
|
url_validation_regex = re.compile(
|
|
r"^(?:http|ftp)s?://" # http:// or https://
|
|
r"(?:(?:[A-Z0-9](?:[A-Z0-9-]{0,61}[A-Z0-9])?\.)+(?:[A-Z]{2,6}\.?|[A-Z0-9-]{2,}\.?)|" # domain...
|
|
r"localhost|" # localhost...
|
|
r"\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})" # ...or ip
|
|
r"(?::\d+)?" # optional port
|
|
r"(?:/?|[/?]\S+)$",
|
|
re.IGNORECASE,
|
|
)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"json_file,num_steps",
|
|
[
|
|
("best-homemade-salsa-recipe.json", 2),
|
|
(
|
|
"blue-cheese-stuffed-turkey-meatballs-with-raspberry-balsamic-glaze-2.json",
|
|
3,
|
|
),
|
|
("bon_appetit.json", 8),
|
|
("chunky-apple-cake.json", 4),
|
|
("dairy-free-impossible-pumpkin-pie.json", 7),
|
|
("how-to-make-instant-pot-spaghetti.json", 8),
|
|
("instant-pot-chicken-and-potatoes.json", 4),
|
|
("instant-pot-kerala-vegetable-stew.json", 13),
|
|
("jalapeno-popper-dip.json", 4),
|
|
("microwave_sweet_potatoes_04783.json", 4),
|
|
("moroccan-skirt-steak-with-roasted-pepper-couscous.json", 4),
|
|
("Pizza-Knoblauch-Champignon-Paprika-vegan.html.json", 3),
|
|
],
|
|
)
|
|
def test_cleaner_clean(json_file, num_steps):
|
|
recipe_data = Cleaner.clean(json.load(open(TEST_RAW_RECIPES.joinpath(json_file))))
|
|
assert len(recipe_data["recipeInstructions"]) == num_steps
|
|
|
|
|
|
def test_clean_category():
|
|
assert Cleaner.category("my-category") == ["my-category"]
|
|
|
|
|
|
def test_clean_html():
|
|
assert Cleaner.html("<div>Hello World</div>") == "Hello World"
|
|
|
|
|
|
def test_clean_image():
|
|
assert Cleaner.image(None) == "no image"
|
|
assert Cleaner.image("https://my.image/path/") == "https://my.image/path/"
|
|
assert Cleaner.image({"url": "My URL!"}) == "My URL!"
|
|
assert Cleaner.image(["My URL!", "MY SECOND URL"]) == "My URL!"
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"instructions",
|
|
[
|
|
"A\n\nB\n\nC\n\n",
|
|
"A\nB\nC\n",
|
|
"A\r\n\r\nB\r\n\r\nC\r\n\r\n",
|
|
"A\r\nB\r\nC\r\n",
|
|
["A", "B", "C"],
|
|
[{"@type": "HowToStep", "text": x} for x in ["A", "B", "C"]],
|
|
],
|
|
)
|
|
def test_cleaner_instructions(instructions):
|
|
assert Cleaner.instructions(instructions) == [
|
|
{"text": "A"},
|
|
{"text": "B"},
|
|
{"text": "C"},
|
|
]
|
|
|
|
|
|
def test_html_with_recipe_data():
|
|
path = TEST_RAW_HTML.joinpath("healthy_pasta_bake_60759.html")
|
|
url = "https://www.bbc.co.uk/food/recipes/healthy_pasta_bake_60759"
|
|
recipe_data = extract_recipe_from_html(open(path).read(), url)
|
|
|
|
assert len(recipe_data["name"]) > 10
|
|
assert len(recipe_data["slug"]) > 10
|
|
assert recipe_data["orgURL"] == url
|
|
assert len(recipe_data["description"]) > 100
|
|
assert url_validation_regex.match(recipe_data["image"])
|
|
assert len(recipe_data["recipeIngredient"]) == 13
|
|
assert len(recipe_data["recipeInstructions"]) == 4
|
|
|
|
|
|
def test_time_cleaner():
|
|
|
|
my_time_delta = "PT2H30M"
|
|
return_delta = Cleaner.time(my_time_delta)
|
|
|
|
assert return_delta == "2 Hours 30 Minutes"
|