-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathMakefile
95 lines (71 loc) · 3.7 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
DJANGO_SETTINGS_MODULE = hypha.settings.dev
JS_VENDOR_DIR = ./hypha/static_src/javascript/vendor
JS_ESM_DIR = ./hypha/static_src/javascript/esm
# Check if uv is installed then use it, else fallback to pip
PIP := $(shell (command -v uv > /dev/null 2>&1 && echo "uv pip") || (command -v pip > /dev/null 2>&1 && echo "pip"))
UV_RUN := $(shell (command -v uv > /dev/null 2>&1 && echo "uv run ") || echo "")
.PHONY: help
help: ## Show this help menu with a list of available commands and their descriptions
@echo "\nSpecify a command. The choices are:\n"
@grep -E '^[0-9a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf " \033[0;36m%-12s\033[m %s\n", $$1, $$2}'
@echo ""
.PHONY: serve
serve: .cache/tandem .cache/py-packages .cache/dev-build-fe ## Run Django server, docs preview, and watch frontend changes
@.cache/tandem \
'${UV_RUN}python manage.py runserver_plus --settings=$(DJANGO_SETTINGS_MODULE)' \
'npm:watch:*' \
'${UV_RUN}mkdocs serve'
.PHONY: test
test: lint py-test cov-html ## Run all tests (linting, Python tests) and generate coverage report
.PHONY: fmt
fmt: .cache/dev-build-fe ## Run code formatters on all code using pre-commit
${UV_RUN}pre-commit run --all-files
.PHONY: lint
lint: .cache/dev-build-fe ## Run all linters
@echo "Running linters"
${UV_RUN}pre-commit run --all-files
.PHONY: py-test
py-test: .cache/py-packages ## Run Python tests with pytest, including coverage report
@echo "Running python tests"
${UV_RUN}pytest --reuse-db --cov --cov-report term:skip-covered
@echo "Removing test files generated during test"
@find media/ -iname 'test_*.pdf' -o -iname 'test_image*' -o -iname '*.dat' -delete
@find media/ -type d -empty -delete
@rm -rf media/temp_uploads/*
.PHONY: cov-html
cov-html: ## Generate HTML coverage report from previous test run
ifneq ("$(wildcard .coverage)","")
@rm -rf htmlcov
@echo "Generate html coverage report…"
${UV_RUN}coverage html
@echo "Open 'htmlcov/index.html' in your browser to see the report."
else
$(error Unable to generate html coverage report, please run 'make test' or 'make py-test')
endif
.PHONY: download-esm-modules
download-esm-modules: ## Download ECMAScript modules for the project
$(PIP) install download-esm
download-esm @github/relative-time-element $(JS_ESM_DIR)
download-esm @github/filter-input-element $(JS_ESM_DIR)
download-esm choices.js $(JS_ESM_DIR)
.cache/tandem: ## Install tandem, a tool for running multiple commands in parallel
@mkdir -p $$(dirname $@)
@curl -fsSL https://raw.githubusercontent.com/rosszurowski/tandem/524b1e0379efca55bcf9ad2a9fe5453a117eb0a4/install.sh | bash -s -- --dest="$$(dirname $@)"
.cache/dev-build-fe: .cache/npm-packages $(shell find hypha/static_src) ## Build frontend resources for development
@mkdir -p $$(dirname $@)
@.cache/tandem 'npm:dev:build:*'
@touch $@
.cache/py-packages: requirements/dev.txt requirements/docs.txt ## Install Python packages for development and documentation
@mkdir -p $$(dirname $@)
$(PIP) install --no-deps -r requirements/dev.txt -r requirements/docs.txt
@touch $@
.cache/npm-packages: package.json ## Install Node.js packages and copy JavaScript files to vendor directory
@mkdir -p $$(dirname $@)
NODE_ENV=development npm install
cp node_modules/htmx.org/dist/htmx.min.js $(JS_VENDOR_DIR)/htmx.min.js
cp node_modules/htmx.org/dist/ext/multi-swap.js $(JS_VENDOR_DIR)/htmx-ext-multi-swap.min.js
cp node_modules/alpinejs/dist/cdn.min.js $(JS_VENDOR_DIR)/alpine.min.js
cp node_modules/@alpinejs/focus/dist/cdn.min.js $(JS_VENDOR_DIR)/alpine-focus.min.js
cp node_modules/daterangepicker/moment.min.js $(JS_VENDOR_DIR)/moment.min.js
cp node_modules/daterangepicker/daterangepicker.js $(JS_VENDOR_DIR)/daterangepicker.min.js
@touch $@