-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathMakefile
More file actions
58 lines (49 loc) · 1.85 KB
/
Makefile
File metadata and controls
58 lines (49 loc) · 1.85 KB
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
SHELL := /bin/bash
.PHONY: swag-init
swag-init:
swag init -g internal/routes/routes.go --output "cmd/api/docs"
swag fmt
.PHONY: start-web-app
start-web-app:
@$(MAKE) LOG MSG_TYPE=info LOG_MESSAGE="Starting web app..."
@$(MAKE) start-database
@$(MAKE) LOG MSG_TYPE=success LOG_MESSAGE="Started database"
@go run cmd/api/main.go
.PHONY: stop-web-app
stop-web-app:
@$(MAKE) LOG MSG_TYPE=info LOG_MESSAGE="Stopping web app..."
@$(MAKE) stop-database
@$(MAKE) LOG MSG_TYPE=success LOG_MESSAGE="Stopped database"
.PHONY: start-database
start-database:
@$(MAKE) LOG MSG_TYPE=info LOG_MESSAGE="Starting database..."
@docker compose up -d
.PHONY: stop-database
stop-database:
@$(MAKE) LOG MSG_TYPE=info LOG_MESSAGE="Stopping database..."
@docker compose down
run-unit-test:
go test -cover ./internal/service ./internal/config ./internal/database ./internal/routes ./cmd/api
.PHONY: check-coverage
check-coverage:
@$(MAKE) LOG MSG_TYPE=info LOG_MESSAGE="Running unit tests and generating coverage report..."
go test -coverprofile=coverage.out ./internal/service ./internal/config ./internal/database ./cmd/routes ./cmd/api
go tool cover -html=coverage.out -o coverage.html
@$(MAKE) LOG MSG_TYPE=warn LOG_MESSAGE="Link to coverage report file: file://$$(PWD)/coverage.html"
.PHONY: view-coverage
view-coverage:
@open -a "Google Chrome" file://$$(PWD)/coverage.html
LOG:
@if [ "$(MSG_TYPE)" = "debug" ]; then \
echo -e "\033[0;37m$(LOG_MESSAGE)\033[0m"; \
elif [ "$(MSG_TYPE)" = "info" ]; then \
echo -e "\033[0;36m$(LOG_MESSAGE)\033[0m"; \
elif [ "$(MSG_TYPE)" = "warn" ]; then \
echo -e "\033[0;33m$(LOG_MESSAGE)\033[0m"; \
elif [ "$(MSG_TYPE)" = "success" ]; then \
echo -e "\033[0;32m$(LOG_MESSAGE)\033[0m✓"; \
elif [ "$(MSG_TYPE)" = "failure" ]; then \
echo -e "\033[0;31m$(LOG_MESSAGE)\033[0m"; \
else \
echo -e "\033[0;37m$(LOG_MESSAGE)\033[0m"; \
fi