|
| 1 | +# Build configuration |
| 2 | +BINARY_NAME := flashduty-mcp-server |
| 3 | +BUILD_DIR := bin |
| 4 | +GOLANGCI_LINT_VERSION := v2.2.1 |
| 5 | +GOLANGCI_LINT := $(BUILD_DIR)/golangci-lint |
| 6 | +GCI_VERSION := v0.13.5 |
| 7 | +GCI := $(BUILD_DIR)/gci |
| 8 | + |
| 9 | +# Go parameters |
| 10 | +GOCMD := go |
| 11 | +GOBUILD := $(GOCMD) build |
| 12 | +GOTEST := $(GOCMD) test |
| 13 | +GOFMT := gofmt |
| 14 | +MODULE := $(shell go list -m) |
| 15 | + |
| 16 | +# Default target |
| 17 | +.PHONY: all |
| 18 | +all: check |
| 19 | + |
| 20 | +# ============================================================================ |
| 21 | +# Development targets |
| 22 | +# ============================================================================ |
| 23 | + |
| 24 | +.PHONY: build |
| 25 | +build: ## Build the binary |
| 26 | + $(GOBUILD) -v -o $(BUILD_DIR)/$(BINARY_NAME) ./cmd/$(BINARY_NAME) |
| 27 | + |
| 28 | +.PHONY: run |
| 29 | +run: build ## Build and run the server |
| 30 | + ./$(BUILD_DIR)/$(BINARY_NAME) |
| 31 | + |
| 32 | +# ============================================================================ |
| 33 | +# Quality assurance targets |
| 34 | +# ============================================================================ |
| 35 | + |
| 36 | +# Directories to format (excludes openspec which contains reference code) |
| 37 | +FMT_DIRS := cmd pkg internal e2e |
| 38 | + |
| 39 | +.PHONY: fmt |
| 40 | +fmt: $(GCI) ## Format Go source code and sort imports |
| 41 | + $(GOFMT) -s -w $(FMT_DIRS) |
| 42 | + $(GCI) write --skip-generated -s standard -s default -s "prefix($(MODULE))" $(FMT_DIRS) |
| 43 | + |
| 44 | +.PHONY: gci |
| 45 | +gci: $(GCI) ## Sort imports using gci |
| 46 | + $(GCI) write --skip-generated -s standard -s default -s "prefix($(MODULE))" $(FMT_DIRS) |
| 47 | + |
| 48 | +.PHONY: lint |
| 49 | +lint: $(GOLANGCI_LINT) ## Run golangci-lint |
| 50 | + $(GOLANGCI_LINT) run |
| 51 | + |
| 52 | +.PHONY: lint-fix |
| 53 | +lint-fix: $(GOLANGCI_LINT) ## Run golangci-lint with auto-fix |
| 54 | + $(GOLANGCI_LINT) run --fix |
| 55 | + |
| 56 | +.PHONY: test |
| 57 | +test: ## Run unit tests |
| 58 | + $(GOTEST) -race ./... |
| 59 | + |
| 60 | +.PHONY: test-v |
| 61 | +test-v: ## Run unit tests with verbose output |
| 62 | + $(GOTEST) -race -v ./... |
| 63 | + |
| 64 | +.PHONY: e2e |
| 65 | +e2e: ## Run E2E tests (requires FLASHDUTY_E2E_APP_KEY and FLASHDUTY_E2E_BASE_URL) |
| 66 | + @if [ -z "$$FLASHDUTY_E2E_APP_KEY" ]; then \ |
| 67 | + echo "Error: FLASHDUTY_E2E_APP_KEY environment variable is not set"; \ |
| 68 | + exit 1; \ |
| 69 | + fi |
| 70 | + $(GOTEST) -v --tags e2e ./e2e/... -timeout 10m |
| 71 | + |
| 72 | +.PHONY: e2e-debug |
| 73 | +e2e-debug: ## Run E2E tests in debug mode (in-process, no Docker) |
| 74 | + @if [ -z "$$FLASHDUTY_E2E_APP_KEY" ]; then \ |
| 75 | + echo "Error: FLASHDUTY_E2E_APP_KEY environment variable is not set"; \ |
| 76 | + exit 1; \ |
| 77 | + fi |
| 78 | + FLASHDUTY_E2E_DEBUG=true $(GOTEST) -v --tags e2e ./e2e/... -timeout 10m |
| 79 | + |
| 80 | +# ============================================================================ |
| 81 | +# Pre-push check (recommended before pushing) |
| 82 | +# ============================================================================ |
| 83 | + |
| 84 | +.PHONY: check |
| 85 | +check: fmt lint test build ## Run all checks (fmt, lint, test, build) - recommended before pushing |
| 86 | + |
| 87 | +.PHONY: ci |
| 88 | +ci: check ## Alias for check |
| 89 | + |
| 90 | +# ============================================================================ |
| 91 | +# Docker targets |
| 92 | +# ============================================================================ |
| 93 | + |
| 94 | +.PHONY: docker-build |
| 95 | +docker-build: ## Build Docker image |
| 96 | + docker build -t flashcat/flashduty-mcp-server . |
| 97 | + |
| 98 | +.PHONY: docker-e2e |
| 99 | +docker-e2e: docker-build ## Build Docker image and run E2E tests |
| 100 | + @if [ -z "$$FLASHDUTY_E2E_APP_KEY" ]; then \ |
| 101 | + echo "Error: FLASHDUTY_E2E_APP_KEY environment variable is not set"; \ |
| 102 | + exit 1; \ |
| 103 | + fi |
| 104 | + $(GOTEST) -v --tags e2e ./e2e/... -timeout 10m |
| 105 | + |
| 106 | +# ============================================================================ |
| 107 | +# Dependency management |
| 108 | +# ============================================================================ |
| 109 | + |
| 110 | +.PHONY: deps |
| 111 | +deps: ## Download Go dependencies |
| 112 | + $(GOCMD) mod download |
| 113 | + |
| 114 | +.PHONY: deps-tidy |
| 115 | +deps-tidy: ## Tidy Go modules |
| 116 | + $(GOCMD) mod tidy |
| 117 | + |
| 118 | +.PHONY: deps-verify |
| 119 | +deps-verify: ## Verify Go dependencies |
| 120 | + $(GOCMD) mod verify |
| 121 | + |
| 122 | +# ============================================================================ |
| 123 | +# Tools installation |
| 124 | +# ============================================================================ |
| 125 | + |
| 126 | +$(BUILD_DIR): |
| 127 | + mkdir -p $(BUILD_DIR) |
| 128 | + |
| 129 | +$(GOLANGCI_LINT): $(BUILD_DIR) |
| 130 | + @if [ ! -f "$(GOLANGCI_LINT)" ]; then \ |
| 131 | + echo "Installing golangci-lint $(GOLANGCI_LINT_VERSION)..."; \ |
| 132 | + curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s $(GOLANGCI_LINT_VERSION); \ |
| 133 | + fi |
| 134 | + |
| 135 | +$(GCI): $(BUILD_DIR) |
| 136 | + @if [ ! -f "$(GCI)" ]; then \ |
| 137 | + echo "Installing gci $(GCI_VERSION)..."; \ |
| 138 | + GOBIN=$(CURDIR)/$(BUILD_DIR) $(GOCMD) install github.com/daixiang0/gci@$(GCI_VERSION); \ |
| 139 | + fi |
| 140 | + |
| 141 | +.PHONY: tools |
| 142 | +tools: $(GOLANGCI_LINT) $(GCI) ## Install required tools |
| 143 | + |
| 144 | +# ============================================================================ |
| 145 | +# Cleanup |
| 146 | +# ============================================================================ |
| 147 | + |
| 148 | +.PHONY: clean |
| 149 | +clean: ## Remove build artifacts |
| 150 | + rm -rf $(BUILD_DIR) |
| 151 | + |
| 152 | +# ============================================================================ |
| 153 | +# Help |
| 154 | +# ============================================================================ |
| 155 | + |
| 156 | +.PHONY: help |
| 157 | +help: ## Display this help message |
| 158 | + @echo "Available targets:" |
| 159 | + @echo "" |
| 160 | + @grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf " \033[36m%-15s\033[0m %s\n", $$1, $$2}' |
| 161 | + @echo "" |
| 162 | + @echo "Quick start:" |
| 163 | + @echo " make check - Run all pre-push checks (recommended before pushing)" |
| 164 | + @echo " make lint - Run linter only" |
| 165 | + @echo " make test - Run unit tests only" |
| 166 | + @echo " make e2e - Run E2E tests (requires env vars)" |
0 commit comments