forked from rivenmedia/riven
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmakefile
127 lines (99 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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
.PHONY: help install run start start-dev stop restart logs logs-dev shell build push push-dev clean format check lint sort test coverage pr-ready
# Detect operating system
ifeq ($(OS),Windows_NT)
# For Windows
DATA_PATH := $(shell echo %cd%)\data
else
# For Linux
DATA_PATH := $(PWD)/data
endif
help:
@echo "Riven Local Development Environment"
@echo "-------------------------------------------------------------------------"
@echo "install : Install the required packages"
@echo "run : Run the Riven src"
@echo "start : Build and run the Riven container (requires Docker)"
@echo "start-dev : Build and run the Riven container in development mode (requires Docker)"
@echo "stop : Stop and remove the Riven container (requires Docker)"
@echo "logs : Show the logs of the Riven container (requires Docker)"
@echo "logs-dev : Show the logs of the Riven container in development mode (requires Docker)"
@echo "clean : Remove all the temporary files"
@echo "format : Format the code using isort"
@echo "lint : Lint the code using ruff and isort"
@echo "test : Run the tests using pytest"
@echo "coverage : Run the tests and generate coverage report"
@echo "pr-ready : Run the linter and tests"
@echo "-------------------------------------------------------------------------"
# Docker related commands
start: stop
@docker compose -f docker-compose.yml up --build -d --force-recreate --remove-orphans
@docker compose -f docker-compose.yml logs -f
start-dev: stop-dev
@docker compose -f docker-compose-dev.yml up --build -d --force-recreate --remove-orphans
@docker compose -f docker-compose-dev.yml logs -f
stop:
@docker compose -f docker-compose.yml down
stop-dev:
@docker compose -f docker-compose-dev.yml down
restart:
@docker restart riven
@docker logs -f riven
logs:
@docker logs -f riven
logs-dev:
@docker compose -f docker-compose-dev.yml logs -f
shell:
@docker exec -it riven fish
# Ensure the Buildx builder is set up
setup-builder:
@if ! docker buildx ls | grep -q "mybuilder"; then \
echo "Creating Buildx builder..."; \
docker buildx create --use --name mybuilder --driver docker-container; \
else \
echo "Using existing Buildx builder..."; \
fi
# Build multi-architecture image (local only, no push)
build: setup-builder
@docker buildx build --platform linux/amd64,linux/arm64 -t riven --load .
# Build and push multi-architecture release image
push: setup-builder
@echo "Building and pushing image to Docker Hub..."
@docker buildx build --platform linux/amd64,linux/arm64 -t spoked/riven:latest --push .
@echo "Image pushed to Docker Hub"
# Build and push multi-architecture dev image
push-dev: setup-builder
@echo "Building and pushing image to Docker Hub..."
@docker buildx build --platform linux/amd64,linux/arm64 -t spoked/riven:dev --push .
@echo "Image pushed to Docker Hub"
tidy:
@docker rmi $(docker images | awk '$1 == "<none>" || $1 == "riven" {print $3}') -f
# Poetry related commands
clean:
@find . -type f -name '*.pyc' -exec rm -f {} +
@find . -type d -name '__pycache__' -exec rm -rf {} +
@find . -type d -name '.pytest_cache' -exec rm -rf {} +
@find . -type d -name '.ruff_cache' -exec rm -rf {} +
hard_reset: clean
@rm -rf data/alembic/
@poetry run python src/main.py --hard_reset_db
install:
@poetry install --with dev
# Run the application
run:
@poetry run python src/main.py
# Code quality commands
format:
@poetry run isort src
check:
@poetry run pyright
lint:
@poetry run ruff check src
@poetry run isort --check-only src
sort:
@poetry run isort src
test:
@poetry run pytest src
coverage: clean
@poetry run pytest src --cov=src --cov-report=xml --cov-report=term
# Run the linter and tests
pr-ready: clean lint test