mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-10-27 08:14:30 -04:00
* add dependency injection for get_repositories * convert events api to controller * update generic typing * add abstract controllers * update test naming * migrate admin services to controllers * add additional admin route tests * remove print * add public shared dependencies * add types * fix typo * add static variables for recipe json keys * add coverage gutters config * update controller routers * add generic success response * add category/tag/tool tests * add token refresh test * add coverage utilities * covert comments to controller * add todo * add helper properties * delete old service * update test notes * add unit test for pretty_stats * remove dead code from post_webhooks * update group routes to use controllers * add additional group test coverage * abstract common permission checks * convert ingredient parser to controller * update recipe crud to use controller * remove dead-code * add class lifespan tracker for debugging * convert bulk export to controller * migrate tools router to controller * update recipe share to controller * move customer router to _base * ignore prints in flake8 * convert units and foods to new controllers * migrate user routes to controllers * centralize error handling * fix invalid ref * reorder fields * update routers to share common handling * update tests * remove prints * fix cookbooks delete * fix cookbook get * add controller for mealplanner * cover report routes to controller * remove __future__ imports * remove dead code * remove all base_http children and remove dead code
116 lines
3.4 KiB
Makefile
116 lines
3.4 KiB
Makefile
define BROWSER_PYSCRIPT
|
|
import os, webbrowser, sys
|
|
|
|
from urllib.request import pathname2url
|
|
|
|
webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
|
|
endef
|
|
export BROWSER_PYSCRIPT
|
|
|
|
define PRINT_HELP_PYSCRIPT
|
|
import re, sys
|
|
|
|
for line in sys.stdin:
|
|
match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
|
|
if match:
|
|
target, help = match.groups()
|
|
print("%-20s %s" % (target, help))
|
|
endef
|
|
export PRINT_HELP_PYSCRIPT
|
|
|
|
BROWSER := python -c "$$BROWSER_PYSCRIPT"
|
|
|
|
help:
|
|
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
|
|
|
|
purge: clean ## ⚠️ Removes All Developer Data for a fresh server start
|
|
rm -r ./dev/data/recipes/
|
|
rm -r ./dev/data/users/
|
|
rm -f ./dev/data/mealie*.db
|
|
rm -f ./dev/data/mealie.log
|
|
rm -f ./dev/data/.secret
|
|
|
|
clean: clean-pyc clean-test ## 🧹 Remove all build, test, coverage and Python artifacts
|
|
|
|
clean-pyc: ## 🧹 Remove Python file artifacts
|
|
find ./mealie -name '*.pyc' -exec rm -f {} +
|
|
find ./mealie -name '*.pyo' -exec rm -f {} +
|
|
find ./mealie -name '*~' -exec rm -f {} +
|
|
find ./mealie -name '__pycache__' -exec rm -fr {} +
|
|
|
|
clean-test: ## 🧹 Remove test and coverage artifacts
|
|
rm -fr .tox/
|
|
rm -f .coverage
|
|
rm -fr htmlcov/
|
|
rm -fr .pytest_cache
|
|
|
|
test-all: lint-test test ## 🧪 Check Lint Format and Testing
|
|
|
|
test: ## 🧪 Run tests quickly with the default Python
|
|
poetry run pytest
|
|
|
|
lint-test:
|
|
poetry run black . --check
|
|
poetry run isort . --check-only
|
|
poetry run flake8 mealie tests
|
|
|
|
lint: ## 🧺 Format, Check and Flake8
|
|
poetry run isort .
|
|
poetry run black .
|
|
poetry run flake8 mealie tests
|
|
|
|
coverage: ## ☂️ Check code coverage quickly with the default Python
|
|
poetry run pytest
|
|
poetry run coverage report -m
|
|
poetry run coveragepy-lcov
|
|
poetry run coverage html
|
|
$(BROWSER) htmlcov/index.html
|
|
|
|
.PHONY: setup
|
|
setup: ## 🏗 Setup Development Instance
|
|
poetry install && \
|
|
cd frontend && \
|
|
yarn install && \
|
|
cd ..
|
|
|
|
@echo Be sure to copy the template.env files
|
|
@echo Testing the Natural Languuage Processor? Try `make setup-model` to get the most recent model
|
|
|
|
setup-model: ## 🤖 Get the latest NLP CRF++ Model
|
|
@echo Fetching NLP Model - CRF++ is still Required
|
|
curl -L0 https://github.com/mealie-recipes/nlp-model/releases/download/v1.0.0/model.crfmodel --output ./mealie/services/parser_services/crfpp/model.crfmodel
|
|
|
|
backend: ## 🎬 Start Mealie Backend Development Server
|
|
poetry run python mealie/db/init_db.py && \
|
|
poetry run python mealie/services/image/minify.py && \
|
|
poetry run python mealie/app.py
|
|
|
|
.PHONY: frontend
|
|
frontend: ## 🎬 Start Mealie Frontend Development Server
|
|
cd frontend && yarn run dev
|
|
|
|
frontend-build: ## 🏗 Build Frontend in frontend/dist
|
|
cd frontend && yarn run build
|
|
|
|
frontend-generate: ## 🏗 Generate Code for Frontend
|
|
poetry run python dev/code-generation/gen_frontend_types.py
|
|
|
|
frontend-lint: ## 🧺 Run yarn lint
|
|
cd frontend && yarn lint
|
|
|
|
.PHONY: docs
|
|
docs: ## 📄 Start Mkdocs Development Server
|
|
poetry run python dev/scripts/api_docs_gen.py && \
|
|
cd docs && poetry run python -m mkdocs serve
|
|
|
|
docker-dev: ## 🐳 Build and Start Docker Development Stack
|
|
docker-compose -f docker-compose.dev.yml -p dev-mealie down && \
|
|
docker-compose -f docker-compose.dev.yml -p dev-mealie up --build
|
|
|
|
docker-prod: ## 🐳 Build and Start Docker Production Stack
|
|
docker-compose -f docker-compose.yml -p mealie up --build
|
|
|
|
code-gen: ## 🤖 Run Code-Gen Scripts
|
|
poetry run python dev/scripts/app_routes_gen.py
|
|
|