TTime/backend/Makefile

63 lines
1.2 KiB
Makefile
Raw Normal View History

2024-02-12 12:40:49 +01:00
# Go parameters
GOCMD = go
GOBUILD = $(GOCMD) build
GOCLEAN = $(GOCMD) clean
GOTEST = $(GOCMD) test
GOGET = $(GOCMD) get
# SQLite database filename
DB_FILE = db.sqlite3
# Directory containing migration SQL scripts
MIGRATIONS_DIR = migrations
# Build target
build:
$(GOBUILD) -o bin/server cmd/*.go
# Run target
run: build
./bin/server
2024-02-20 15:42:45 +01:00
watch: build
watchexec -w . -r make run
2024-02-12 12:40:49 +01:00
# Clean target
clean:
$(GOCLEAN)
2024-02-12 13:11:25 +01:00
rm -rf bin
2024-02-12 12:40:49 +01:00
rm -f db.sqlite3
# Test target
test: db.sqlite3
$(GOTEST) ./... -count=1 -v
2024-02-12 12:40:49 +01:00
# Get dependencies target
deps:
$(GOGET) -v ./...
# Update dependencies target
update:
$(GOGET) -u -v ./...
$(GOCMD) mod tidy
# Migration target
migrate:
@echo "Migrating database $(DB_FILE) using SQL scripts in $(MIGRATIONS_DIR)"
@for file in $(wildcard $(MIGRATIONS_DIR)/*.sql); do \
echo "Applying migration: $$file"; \
sqlite3 $(DB_FILE) < $$file; \
done
# Target added primarily for CI/CD to ensure that the database is created before running tests
db.sqlite3:
make migrate
2024-02-27 07:43:20 +01:00
backup:
sqlite3 $(DB_FILE) .dump | gzip -9 > BACKUP_$(DB_FILE)_$(shell date +"%Y-%m-%d_%H:%M:%S").sql.gz
# Restore with:
# gzip -cd BACKUP_$(DB_FILE)_*.sql.gz | sqlite3 $(DB_FILE)
2024-02-12 12:40:49 +01:00
# Default target
default: build