You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Makefile 9.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. IMPORT := xorm.io/xorm
  2. export GO111MODULE=on
  3. GO ?= go
  4. GOFMT ?= gofmt -s
  5. TAGS ?=
  6. SED_INPLACE := sed -i
  7. GOFILES := $(shell find . -name "*.go" -type f)
  8. INTEGRATION_PACKAGES := xorm.io/xorm/integrations
  9. PACKAGES ?= $(filter-out $(INTEGRATION_PACKAGES),$(shell $(GO) list ./...))
  10. TEST_COCKROACH_HOST ?= cockroach:26257
  11. TEST_COCKROACH_SCHEMA ?=
  12. TEST_COCKROACH_DBNAME ?= xorm_test
  13. TEST_COCKROACH_USERNAME ?= postgres
  14. TEST_COCKROACH_PASSWORD ?=
  15. TEST_MSSQL_HOST ?= mssql:1433
  16. TEST_MSSQL_DBNAME ?= gitea
  17. TEST_MSSQL_USERNAME ?= sa
  18. TEST_MSSQL_PASSWORD ?= MwantsaSecurePassword1
  19. TEST_MSSQL_DEFAULT_VARCHAR ?= varchar
  20. TEST_MSSQL_DEFAULT_CHAR ?= char
  21. TEST_MSSQL_DO_NVARCHAR_OVERRIDE_TEST ?= true
  22. TEST_MYSQL_HOST ?= mysql:3306
  23. TEST_MYSQL_CHARSET ?= utf8
  24. TEST_MYSQL_DBNAME ?= xorm_test
  25. TEST_MYSQL_USERNAME ?= root
  26. TEST_MYSQL_PASSWORD ?=
  27. TEST_PGSQL_HOST ?= pgsql:5432
  28. TEST_PGSQL_SCHEMA ?=
  29. TEST_PGSQL_DBNAME ?= xorm_test
  30. TEST_PGSQL_USERNAME ?= postgres
  31. TEST_PGSQL_PASSWORD ?= mysecretpassword
  32. TEST_TIDB_HOST ?= tidb:4000
  33. TEST_TIDB_DBNAME ?= xorm_test
  34. TEST_TIDB_USERNAME ?= root
  35. TEST_TIDB_PASSWORD ?=
  36. TEST_CACHE_ENABLE ?= false
  37. TEST_QUOTE_POLICY ?= always
  38. .PHONY: all
  39. all: build
  40. .PHONY: build
  41. build: go-check $(GO_SOURCES)
  42. $(GO) build $(PACKAGES)
  43. .PHONY: clean
  44. clean:
  45. $(GO) clean -i ./...
  46. rm -rf *.sql *.log test.db *coverage.out coverage.all integrations/*.sql
  47. .PHONY: coverage
  48. coverage:
  49. @hash gocovmerge > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
  50. $(GO) get -u github.com/wadey/gocovmerge; \
  51. fi
  52. gocovmerge $(shell find . -type f -name "coverage.out") > coverage.all;\
  53. .PHONY: fmt
  54. fmt:
  55. $(GOFMT) -w $(GOFILES)
  56. .PHONY: fmt-check
  57. fmt-check:
  58. # get all go files and run go fmt on them
  59. @diff=$$($(GOFMT) -d $(GOFILES)); \
  60. if [ -n "$$diff" ]; then \
  61. echo "Please run 'make fmt' and commit the result:"; \
  62. echo "$${diff}"; \
  63. exit 1; \
  64. fi;
  65. .PHONY: go-check
  66. go-check:
  67. $(eval GO_VERSION := $(shell printf "%03d%03d%03d" $(shell go version | grep -Eo '[0-9]+\.?[0-9]+?\.?[0-9]?\s' | tr '.' ' ');))
  68. @if [ "$(GO_VERSION)" -lt "001011000" ]; then \
  69. echo "Gitea requires Go 1.11.0 or greater to build. You can get it at https://golang.org/dl/"; \
  70. exit 1; \
  71. fi
  72. .PHONY: help
  73. help:
  74. @echo "Make Routines:"
  75. @echo " - equivalent to \"build\""
  76. @echo " - build creates the entire project"
  77. @echo " - clean delete integration files and build files but not css and js files"
  78. @echo " - fmt format the code"
  79. @echo " - lint run code linter revive"
  80. @echo " - misspell check if a word is written wrong"
  81. @echo " - test run default unit test"
  82. @echo " - test-cockroach run integration tests for cockroach"
  83. @echo " - test-mysql run integration tests for mysql"
  84. @echo " - test-mssql run integration tests for mssql"
  85. @echo " - test-postgres run integration tests for postgres"
  86. @echo " - test-sqlite run integration tests for sqlite"
  87. @echo " - test-tidb run integration tests for tidb"
  88. @echo " - vet examines Go source code and reports suspicious constructs"
  89. .PHONY: lint
  90. lint: revive
  91. .PHONY: revive
  92. revive:
  93. @hash revive > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
  94. $(GO) get -u github.com/mgechev/revive; \
  95. fi
  96. revive -config .revive.toml -exclude=./vendor/... ./... || exit 1
  97. .PHONY: misspell
  98. misspell:
  99. @hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
  100. $(GO) get -u github.com/client9/misspell/cmd/misspell; \
  101. fi
  102. misspell -w -i unknwon $(GOFILES)
  103. .PHONY: misspell-check
  104. misspell-check:
  105. @hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
  106. $(GO) get -u github.com/client9/misspell/cmd/misspell; \
  107. fi
  108. misspell -error -i unknwon,destory $(GOFILES)
  109. .PHONY: test
  110. test: go-check
  111. $(GO) test $(PACKAGES)
  112. .PNONY: test-cockroach
  113. test-cockroach: go-check
  114. $(GO) test $(INTEGRATION_PACKAGES) -v -race -db=postgres -schema='$(TEST_COCKROACH_SCHEMA)' -cache=$(TEST_CACHE_ENABLE) \
  115. -conn_str="postgres://$(TEST_COCKROACH_USERNAME):$(TEST_COCKROACH_PASSWORD)@$(TEST_COCKROACH_HOST)/$(TEST_COCKROACH_DBNAME)?sslmode=disable&experimental_serial_normalization=sql_sequence" \
  116. -ignore_update_limit=true -coverprofile=cockroach.$(TEST_COCKROACH_SCHEMA).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  117. .PHONY: test-cockroach\#%
  118. test-cockroach\#%: go-check
  119. $(GO) test $(INTEGRATION_PACKAGES) -v -race -run $* -db=postgres -schema='$(TEST_COCKROACH_SCHEMA)' -cache=$(TEST_CACHE_ENABLE) \
  120. -conn_str="postgres://$(TEST_COCKROACH_USERNAME):$(TEST_COCKROACH_PASSWORD)@$(TEST_COCKROACH_HOST)/$(TEST_COCKROACH_DBNAME)?sslmode=disable&experimental_serial_normalization=sql_sequence" \
  121. -ignore_update_limit=true -coverprofile=cockroach.$(TEST_COCKROACH_SCHEMA).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  122. .PNONY: test-mssql
  123. test-mssql: go-check
  124. $(GO) test $(INTEGRATION_PACKAGES) -v -race -db=mssql -cache=$(TEST_CACHE_ENABLE) -quote=$(TEST_QUOTE_POLICY) \
  125. -conn_str="server=$(TEST_MSSQL_HOST);user id=$(TEST_MSSQL_USERNAME);password=$(TEST_MSSQL_PASSWORD);database=$(TEST_MSSQL_DBNAME)" \
  126. -default_varchar=$(TEST_MSSQL_DEFAULT_VARCHAR) -default_char=$(TEST_MSSQL_DEFAULT_CHAR) \
  127. -do_nvarchar_override_test=$(TEST_MSSQL_DO_NVARCHAR_OVERRIDE_TEST) \
  128. -coverprofile=mssql.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  129. .PNONY: test-mssql\#%
  130. test-mssql\#%: go-check
  131. $(GO) test $(INTEGRATION_PACKAGES) -v -race -run $* -db=mssql -cache=$(TEST_CACHE_ENABLE) -quote=$(TEST_QUOTE_POLICY) \
  132. -conn_str="server=$(TEST_MSSQL_HOST);user id=$(TEST_MSSQL_USERNAME);password=$(TEST_MSSQL_PASSWORD);database=$(TEST_MSSQL_DBNAME)" \
  133. -default_varchar=$(TEST_MSSQL_DEFAULT_VARCHAR) -default_char=$(TEST_MSSQL_DEFAULT_CHAR) \
  134. -do_nvarchar_override_test=$(TEST_MSSQL_DO_NVARCHAR_OVERRIDE_TEST) \
  135. -coverprofile=mssql.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  136. .PNONY: test-mymysql
  137. test-mymysql: go-check
  138. $(GO) test $(INTEGRATION_PACKAGES) -v -race -db=mymysql -cache=$(TEST_CACHE_ENABLE) -quote=$(TEST_QUOTE_POLICY) \
  139. -conn_str="tcp:$(TEST_MYSQL_HOST)*$(TEST_MYSQL_DBNAME)/$(TEST_MYSQL_USERNAME)/$(TEST_MYSQL_PASSWORD)" \
  140. -coverprofile=mymysql.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  141. .PNONY: test-mymysql\#%
  142. test-mymysql\#%: go-check
  143. $(GO) test $(INTEGRATION_PACKAGES) -v -race -run $* -db=mymysql -cache=$(TEST_CACHE_ENABLE) -quote=$(TEST_QUOTE_POLICY) \
  144. -conn_str="tcp:$(TEST_MYSQL_HOST)*$(TEST_MYSQL_DBNAME)/$(TEST_MYSQL_USERNAME)/$(TEST_MYSQL_PASSWORD)" \
  145. -coverprofile=mymysql.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  146. .PNONY: test-mysql
  147. test-mysql: go-check
  148. $(GO) test $(INTEGRATION_PACKAGES) -v -race -db=mysql -cache=$(TEST_CACHE_ENABLE) -quote=$(TEST_QUOTE_POLICY) \
  149. -conn_str="$(TEST_MYSQL_USERNAME):$(TEST_MYSQL_PASSWORD)@tcp($(TEST_MYSQL_HOST))/$(TEST_MYSQL_DBNAME)?charset=$(TEST_MYSQL_CHARSET)" \
  150. -coverprofile=mysql.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  151. .PHONY: test-mysql\#%
  152. test-mysql\#%: go-check
  153. $(GO) test $(INTEGRATION_PACKAGES) -v -race -run $* -db=mysql -cache=$(TEST_CACHE_ENABLE) -quote=$(TEST_QUOTE_POLICY) \
  154. -conn_str="$(TEST_MYSQL_USERNAME):$(TEST_MYSQL_PASSWORD)@tcp($(TEST_MYSQL_HOST))/$(TEST_MYSQL_DBNAME)?charset=$(TEST_MYSQL_CHARSET)" \
  155. -coverprofile=mysql.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  156. .PNONY: test-postgres
  157. test-postgres: go-check
  158. $(GO) test $(INTEGRATION_PACKAGES) -v -race -db=postgres -schema='$(TEST_PGSQL_SCHEMA)' -cache=$(TEST_CACHE_ENABLE) \
  159. -conn_str="postgres://$(TEST_PGSQL_USERNAME):$(TEST_PGSQL_PASSWORD)@$(TEST_PGSQL_HOST)/$(TEST_PGSQL_DBNAME)?sslmode=disable" \
  160. -quote=$(TEST_QUOTE_POLICY) -coverprofile=postgres.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  161. .PHONY: test-postgres\#%
  162. test-postgres\#%: go-check
  163. $(GO) test $(INTEGRATION_PACKAGES) -v -race -run $* -db=postgres -schema='$(TEST_PGSQL_SCHEMA)' -cache=$(TEST_CACHE_ENABLE) \
  164. -conn_str="postgres://$(TEST_PGSQL_USERNAME):$(TEST_PGSQL_PASSWORD)@$(TEST_PGSQL_HOST)/$(TEST_PGSQL_DBNAME)?sslmode=disable" \
  165. -quote=$(TEST_QUOTE_POLICY) -coverprofile=postgres.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  166. .PHONY: test-sqlite
  167. test-sqlite: go-check
  168. $(GO) test $(INTEGRATION_PACKAGES) -v -race -cache=$(TEST_CACHE_ENABLE) -db=sqlite3 -conn_str="./test.db?cache=shared&mode=rwc" \
  169. -quote=$(TEST_QUOTE_POLICY) -coverprofile=sqlite.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  170. .PHONY: test-sqlite-schema
  171. test-sqlite-schema: go-check
  172. $(GO) test $(INTEGRATION_PACKAGES) -v -race -schema=xorm -cache=$(TEST_CACHE_ENABLE) -db=sqlite3 -conn_str="./test.db?cache=shared&mode=rwc" \
  173. -quote=$(TEST_QUOTE_POLICY) -coverprofile=sqlite.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  174. .PHONY: test-sqlite\#%
  175. test-sqlite\#%: go-check
  176. $(GO) test $(INTEGRATION_PACKAGES) -v -race -run $* -cache=$(TEST_CACHE_ENABLE) -db=sqlite3 -conn_str="./test.db?cache=shared&mode=rwc" \
  177. -quote=$(TEST_QUOTE_POLICY) -coverprofile=sqlite.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  178. .PNONY: test-tidb
  179. test-tidb: go-check
  180. $(GO) test $(INTEGRATION_PACKAGES) -v -race -db=mysql -cache=$(TEST_CACHE_ENABLE) -ignore_select_update=true \
  181. -conn_str="$(TEST_TIDB_USERNAME):$(TEST_TIDB_PASSWORD)@tcp($(TEST_TIDB_HOST))/$(TEST_TIDB_DBNAME)" \
  182. -quote=$(TEST_QUOTE_POLICY) -coverprofile=tidb.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  183. .PHONY: test-tidb\#%
  184. test-tidb\#%: go-check
  185. $(GO) test $(INTEGRATION_PACKAGES) -v -race -run $* -db=mysql -cache=$(TEST_CACHE_ENABLE) -ignore_select_update=true \
  186. -conn_str="$(TEST_TIDB_USERNAME):$(TEST_TIDB_PASSWORD)@tcp($(TEST_TIDB_HOST))/$(TEST_TIDB_DBNAME)" \
  187. -quote=$(TEST_QUOTE_POLICY) -coverprofile=tidb.$(TEST_QUOTE_POLICY).$(TEST_CACHE_ENABLE).coverage.out -covermode=atomic
  188. .PHONY: vet
  189. vet:
  190. $(GO) vet $(shell $(GO) list ./...)