forked from gitea/go-sdk
Gusted
8fab37e740
- Enforce [gofumpt](https://github.com/mvdan/gofumpt) to enforce a more idiomatic go style. - Enforce golangci-lint a bunch of linters! Which were able to detect a few issues in the current codebase and have been fixed by this PR. - Updated the Makefile to use `go install ....` instead of the old deprecated way of `go get` Reviewed-on: gitea/go-sdk#587 Reviewed-by: John Olheiser <john.olheiser@gmail.com> Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: Gusted <williamzijl7@hotmail.com> Co-committed-by: Gusted <williamzijl7@hotmail.com>
124 lines
4.1 KiB
Makefile
124 lines
4.1 KiB
Makefile
GO ?= go
|
|
|
|
WORK_DIR := $(shell pwd)
|
|
|
|
GITEA_SDK_TEST_URL ?= http://localhost:3000
|
|
GITEA_SDK_TEST_USERNAME ?= test01
|
|
GITEA_SDK_TEST_PASSWORD ?= test01
|
|
|
|
PACKAGE := code.gitea.io/sdk/gitea
|
|
|
|
GITEA_DL := https://dl.gitea.io/gitea/main/gitea-main-
|
|
UNAME_S := $(shell uname -s)
|
|
ifeq ($(UNAME_S),Linux)
|
|
GITEA_DL := $(GITEA_DL)linux-
|
|
|
|
UNAME_P := $(shell uname -p)
|
|
ifeq ($(UNAME_P),unknown)
|
|
GITEA_DL := $(GITEA_DL)amd64
|
|
endif
|
|
ifeq ($(UNAME_P),x86_64)
|
|
GITEA_DL := $(GITEA_DL)amd64
|
|
endif
|
|
ifneq ($(filter %86,$(UNAME_P)),)
|
|
GITEA_DL := $(GITEA_DL)386
|
|
endif
|
|
ifneq ($(filter arm%,$(UNAME_P)),)
|
|
GITEA_DL := $(GITEA_DL)arm-5
|
|
endif
|
|
endif
|
|
ifeq ($(UNAME_S),Darwin)
|
|
GITEA_DL := $(GITEA_DL)darwin-10.12-amd64
|
|
endif
|
|
|
|
.PHONY: all
|
|
all: clean test build
|
|
|
|
.PHONY: help
|
|
help:
|
|
@echo "Make Routines:"
|
|
@echo " - \"\" run \"make clean test build\""
|
|
@echo " - build build sdk"
|
|
@echo " - clean clean"
|
|
@echo " - fmt format the code"
|
|
@echo " - lint run golint"
|
|
@echo " - vet examines Go source code and reports"
|
|
@echo " - test run unit tests (need a running gitea)"
|
|
@echo " - test-instance start a gitea instance for test"
|
|
|
|
|
|
.PHONY: clean
|
|
clean:
|
|
rm -r -f test
|
|
cd gitea && $(GO) clean -i ./...
|
|
|
|
.PHONY: fmt
|
|
fmt:
|
|
find . -name "*.go" -type f | xargs gofmt -s -w; \
|
|
$(GO) run mvdan.cc/gofumpt@latest -extra -w ./gitea
|
|
|
|
.PHONY: vet
|
|
vet:
|
|
# Default vet
|
|
cd gitea && $(GO) vet $(PACKAGE)
|
|
# Custom vet
|
|
cd gitea && $(GO) get code.gitea.io/gitea-vet
|
|
cd gitea && $(GO) build code.gitea.io/gitea-vet
|
|
cd gitea && $(GO) vet -vettool=gitea-vet $(PACKAGE)
|
|
|
|
.PHONY: ci-lint
|
|
ci-lint:
|
|
cd gitea/; \
|
|
$(GO) run github.com/mgechev/revive@latest -config ../.revive.toml .; \
|
|
if [ $$? -eq 1 ]; then \
|
|
echo "Doesn't pass revive"; \
|
|
exit 1; \
|
|
fi; \
|
|
diff=$$($(GO) run mvdan.cc/gofumpt@latest -extra -l .); \
|
|
if [ -n "$$diff" ]; then \
|
|
echo "Not gofumpt-ed"; \
|
|
exit 1; \
|
|
fi; \
|
|
$(GO) run github.com/golangci/golangci-lint/cmd/golangci-lint@v1.44.2 run --timeout 5m; \
|
|
if [ $$? -eq 1 ]; then \
|
|
echo "Doesn't pass golangci-lint"; \
|
|
exit 1; \
|
|
fi; \
|
|
cd -; \
|
|
|
|
.PHONY: test
|
|
test:
|
|
@export GITEA_SDK_TEST_URL=${GITEA_SDK_TEST_URL}; export GITEA_SDK_TEST_USERNAME=${GITEA_SDK_TEST_USERNAME}; export GITEA_SDK_TEST_PASSWORD=${GITEA_SDK_TEST_PASSWORD}; \
|
|
if [ -z "$(shell curl --noproxy "*" "${GITEA_SDK_TEST_URL}/api/v1/version" 2> /dev/null)" ]; then \echo "No test-instance detected!"; exit 1; else \
|
|
cd gitea && $(GO) test -race -cover -coverprofile coverage.out; \
|
|
fi
|
|
|
|
.PHONY: test-instance
|
|
test-instance:
|
|
rm -f -r ${WORK_DIR}/test 2> /dev/null; \
|
|
mkdir -p ${WORK_DIR}/test/conf/ ${WORK_DIR}/test/data/
|
|
wget ${GITEA_DL} -O ${WORK_DIR}/test/gitea-main; \
|
|
chmod +x ${WORK_DIR}/test/gitea-main; \
|
|
echo "[security]" > ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "INTERNAL_TOKEN = eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYmYiOjE1NTg4MzY4ODB9.LoKQyK5TN_0kMJFVHWUW0uDAyoGjDP6Mkup4ps2VJN4" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "INSTALL_LOCK = true" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "SECRET_KEY = 2crAW4UANgvLipDS6U5obRcFosjSJHQANll6MNfX7P0G3se3fKcCwwK3szPyGcbo" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "PASSWORD_COMPLEXITY = off" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "[database]" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "DB_TYPE = sqlite3" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "[repository]" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "ROOT = ${WORK_DIR}/test/data/" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "[server]" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
echo "ROOT_URL = ${GITEA_SDK_TEST_URL}" >> ${WORK_DIR}/test/conf/app.ini; \
|
|
${WORK_DIR}/test/gitea-main migrate -c ${WORK_DIR}/test/conf/app.ini; \
|
|
${WORK_DIR}/test/gitea-main admin user create --username=${GITEA_SDK_TEST_USERNAME} --password=${GITEA_SDK_TEST_PASSWORD} --email=test01@gitea.io --admin=true --must-change-password=false --access-token -c ${WORK_DIR}/test/conf/app.ini; \
|
|
${WORK_DIR}/test/gitea-main web -c ${WORK_DIR}/test/conf/app.ini
|
|
|
|
.PHONY: bench
|
|
bench:
|
|
cd gitea && $(GO) test -run=XXXXXX -benchtime=10s -bench=. || exit 1
|
|
|
|
.PHONY: build
|
|
build:
|
|
cd gitea && $(GO) build
|