mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 04:04:21 +01:00
98 lines
2.8 KiB
Makefile
Executable File
98 lines
2.8 KiB
Makefile
Executable File
.PHONY: build clean cov help intergrationtest lint run test vet proto proto-lint
|
|
|
|
## build: build for all platforms
|
|
build:
|
|
@echo "Building arkd binary..."
|
|
@bash ./scripts/build
|
|
|
|
## clean: cleans the binary
|
|
clean:
|
|
@echo "Cleaning..."
|
|
@go clean
|
|
|
|
## cov: generates coverage report
|
|
cov:
|
|
@echo "Coverage..."
|
|
@go test -cover ./...
|
|
|
|
## help: prints this help message
|
|
help:
|
|
@echo "Usage: \n"
|
|
@sed -n 's/^##//p' ${MAKEFILE_LIST} | column -t -s ':' | sed -e 's/^/ /'
|
|
|
|
## intergrationtest: runs integration tests
|
|
integrationtest:
|
|
@echo "Running integration tests..."
|
|
@go test -v -count=1 -race -timeout 200s github.com/ark-network/ark/server/test/e2e/...
|
|
|
|
## lint: lint codebase
|
|
lint:
|
|
@echo "Linting code..."
|
|
@golangci-lint run --fix
|
|
|
|
## run: run in dev mode
|
|
run: clean
|
|
@echo "Running arkd in dev mode..."
|
|
@export ARK_NEUTRINO_PEER=localhost:18444; \
|
|
export ARK_ROUND_INTERVAL=10; \
|
|
export ARK_LOG_LEVEL=5; \
|
|
export ARK_NETWORK=regtest; \
|
|
export ARK_PORT=7070; \
|
|
export ARK_NO_TLS=true; \
|
|
export ARK_NO_MACAROONS=true; \
|
|
export ARK_TX_BUILDER_TYPE=covenantless; \
|
|
export ARK_ESPLORA_URL=http://localhost:3000; \
|
|
export ARK_MIN_RELAY_FEE=200; \
|
|
go run ./cmd/arkd
|
|
|
|
## test: runs unit and component tests
|
|
test:
|
|
@echo "Running unit tests..."
|
|
@go test -v -count=1 -race ./internal/...
|
|
@find ./pkg -name go.mod -execdir go test -v -count=1 -race ./... \;
|
|
|
|
## vet: code analysis
|
|
vet:
|
|
@echo "Running code analysis..."
|
|
@go vet ./...
|
|
|
|
## proto: compile proto stubs
|
|
proto: proto-lint
|
|
@echo "Compiling stubs..."
|
|
@docker run --rm --volume "$(shell pwd):/workspace" --workdir /workspace buf generate buf.build/vulpemventures/ocean
|
|
@docker run --rm --volume "$(shell pwd):/workspace" --workdir /workspace buf generate
|
|
|
|
## proto-lint: lint protos
|
|
proto-lint:
|
|
@echo "Linting protos..."
|
|
@docker build -q -t buf -f buf.Dockerfile . &> /dev/null
|
|
@docker run --rm --volume "$(shell pwd):/workspace" --workdir /workspace buf lint
|
|
|
|
|
|
## mig_file: creates pg migration file(eg. make FILE=init mig_file)
|
|
mig_file:
|
|
@migrate create -ext sql -dir ./internal/infrastructure/db/sqlite/migration/ $(FILE)
|
|
|
|
## mig_up: creates db schema for provided db path
|
|
mig_up:
|
|
@echo "creating db schema..."
|
|
@migrate -database "sqlite://$(DB_PATH)/sqlite.db" -path ./internal/infrastructure/db/sqlite/migration/ up
|
|
|
|
## mig_down: apply down migration
|
|
mig_down:
|
|
@echo "migration down..."
|
|
@migrate -database "sqlite://$(DB_PATH)/sqlite.db" -path ./internal/infrastructure/db/sqlite/migration/ down
|
|
|
|
## mig_down_yes: apply down migration without prompt
|
|
mig_down_yes:
|
|
@echo "migration down..."
|
|
@"yes" | migrate -database "sqlite://path/to/database" -path ./internal/infrastructure/db/sqlite/migration/ down
|
|
|
|
## vet_db: check if mig_up and mig_down are ok
|
|
vet_db: recreatedb mig_up mig_down_yes
|
|
@echo "vet db migration scripts..."
|
|
|
|
## sqlc: gen sql
|
|
sqlc:
|
|
@echo "gen sql..."
|
|
cd ./internal/infrastructure/db/sqlite; sqlc generate
|