-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmakefile
More file actions
75 lines (55 loc) · 1.75 KB
/
makefile
File metadata and controls
75 lines (55 loc) · 1.75 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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
include .env
.PHONY: run build test lint clean env dev logs logs-api logs-db migrate-up migrate-down migrate-force migrate-version migrate-create docs
.ALL: run
APP_NAME=GoBudget
CMD_DIR=cmd/server
ENV_FILE=.env
OUT_DIR=bin
# Dev Commands
run:
@echo ">> Running $(APP_NAME)..."
@ENV_FILE=$(ENV_FILE) go run $(CMD_DIR)/main.go
build:
@echo ">> Building $(APP_NAME)..."
@go build -o $(OUT_DIR)/$(APP_NAME) $(CMD_DIR)/main.go
docs:
@echo ">> Generating docs..."
@swag init -g $(CMD_DIR)/main.go -o internal/docs
test:
@echo ">> Running tests..."
@go test ./...
lint:
@echo ">> Linting code..."
@go vet ./...
clean:
@echo ">> Cleaning build artifacts..."
@rm -f $(APP_NAME)
env:
@echo ">> Showing environment variables from $(ENV_FILE)"
@cat $(ENV_FILE)
dev:
@echo ">> Starting development environment with Docker Compose..."
@docker-compose up --build --remove-orphans --force-recreate -d
logs:
@echo ">> Tailing logs from docker-compose (press Ctrl+C to exit)"
@docker-compose logs -f
logs-api:
@echo ">> Tailing logs from API service (Ctrl+C to exit)"
@docker-compose logs -f api
logs-db:
@echo ">> Tailing logs from DB service (Ctrl+C to exit)"
@docker-compose logs -f postgres
# Migrations
MIGRATE=migrate
MIGRATIONS_DIR=db/migrations
DATABASE_URL=postgres://$(DB_USER):$(DB_PASSWORD)@localhost:$(DB_PORT)/$(DB_NAME)?sslmode=disable
migrate-up:
$(MIGRATE) -path $(MIGRATIONS_DIR) -database "$(DATABASE_URL)" up
migrate-down:
$(MIGRATE) -path $(MIGRATIONS_DIR) -database "$(DATABASE_URL)" down
migrate-force:
$(MIGRATE) -path $(MIGRATIONS_DIR) -database "$(DATABASE_URL)" force $(v)
migrate-version:
$(MIGRATE) -path $(MIGRATIONS_DIR) -database "$(DATABASE_URL)" version
migrate-create:
$(MIGRATE) create -ext sql -dir $(MIGRATIONS_DIR) -seq $(name)