forked from cerc-io/ipld-eth-server
85 lines
2.0 KiB
Makefile
85 lines
2.0 KiB
Makefile
BIN = $(GOPATH)/bin
|
|
BASE = $(GOPATH)/src/$(PACKAGE)
|
|
PKGS = go list ./... | grep -v "^vendor/"
|
|
|
|
#Tools
|
|
DEP = $(BIN)/dep
|
|
$(BIN)/dep:
|
|
go get -u github.com/golang/dep/cmd/dep
|
|
|
|
GINKGO = $(BIN)/ginkgo
|
|
$(BIN)/ginkgo:
|
|
go get -u github.com/onsi/ginkgo/ginkgo
|
|
|
|
MIGRATE = $(BIN)/migrate
|
|
$(BIN)/migrate:
|
|
go get -u -d github.com/mattes/migrate/cli github.com/lib/pq
|
|
go build -tags 'postgres' -o $(BIN)/migrate github.com/mattes/migrate/cli
|
|
|
|
LINT = $(BIN)/golint
|
|
$(BIN)/golint:
|
|
go get github.com/golang/lint/golint
|
|
|
|
METALINT = $(BIN)/gometalinter.v2
|
|
$(BIN)/gometalinter.v2:
|
|
go get -u gopkg.in/alecthomas/gometalinter.v2
|
|
$(METALINT) --install
|
|
|
|
.PHONY: installtools
|
|
installtools: | $(LINT) $(MIGRATE) $(GINKGO) $(DEP)
|
|
echo "Installing tools"
|
|
|
|
.PHONY: metalint
|
|
metalint: | $(METALINT)
|
|
$(METALINT) ./... --vendor \
|
|
--fast \
|
|
--exclude="exported (function)|(var)|(method)|(type).*should have comment or be unexported" \
|
|
--format="{{.Path.Abs}}:{{.Line}}:{{if .Col}}{{.Col}}{{end}}:{{.Severity}}: {{.Message}} ({{.Linter}})"
|
|
|
|
.PHONY: lint
|
|
lint:
|
|
$(LINT) $$($(PKGS)) | grep -v -E "exported (function)|(var)|(method)|(type).*should have comment or be unexported"
|
|
|
|
.PHONY: test
|
|
test: | $(GINKGO) $(LINT)
|
|
go vet ./...
|
|
go fmt ./...
|
|
$(GINKGO) -r
|
|
|
|
.PHONY: dep
|
|
dep: | $(DEP)
|
|
$(DEP) ensure
|
|
|
|
build: dep
|
|
go fmt ./...
|
|
go build
|
|
|
|
#Database
|
|
HOST_NAME = localhost
|
|
PORT = 5432
|
|
NAME =
|
|
CONNECT_STRING=postgresql://$(HOST_NAME):$(PORT)/$(NAME)?sslmode=disable
|
|
|
|
.PHONY: checkdbvars
|
|
checkdbvars:
|
|
test -n "$(HOST_NAME)" # $$HOST_NAME
|
|
test -n "$(PORT)" # $$PORT
|
|
test -n "$(NAME)" # $$NAME
|
|
@echo $(CONNECT_STRING)
|
|
|
|
|
|
.PHONY: rollback
|
|
rollback: $(MIGRATE) checkdbvars
|
|
$(MIGRATE) -database $(CONNECT_STRING) -path ./db/migrations down 1
|
|
pg_dump -O -s $(CONNECT_STRING) > db/schema.sql
|
|
|
|
.PHONY: migrate
|
|
migrate: $(MIGRATE) checkdbvars
|
|
$(MIGRATE) -database $(CONNECT_STRING) -path ./db/migrations up
|
|
pg_dump -O -s $(CONNECT_STRING) > db/schema.sql
|
|
|
|
.PHONY: import
|
|
import:
|
|
test -n "$(NAME)" # $$NAME
|
|
psql $(NAME) < db/schema.sql
|