Makefile 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281
  1. # -*- coding: utf-8; mode: makefile-gmake -*-
  2. .DEFAULT_GOAL=help
  3. # START Makefile setup
  4. export GIT_URL=https://github.com/searx/searx
  5. export GIT_BRANCH=master
  6. export SEARX_URL=https://searx.me
  7. export DOCS_URL=https://searx.github.io/searx
  8. # END Makefile setup
  9. include utils/makefile.include
  10. PYOBJECTS = searx
  11. DOC = docs
  12. PY_SETUP_EXTRAS ?= \[test\]
  13. PYLINT_SEARX_DISABLE_OPTION := I,C,R,W0105,W0212,W0511,W0603,W0613,W0621,W0702,W0703,W1401
  14. PYLINT_ADDITIONAL_BUILTINS_FOR_ENGINES := supported_languages,language_aliases
  15. include utils/makefile.python
  16. include utils/makefile.sphinx
  17. all: clean install
  18. PHONY += help-min help-all help
  19. help: help-min
  20. @echo ''
  21. @echo 'to get more help: make help-all'
  22. help-min:
  23. @echo ' test - run developer tests'
  24. @echo ' docs - build documentation'
  25. @echo ' docs-live - autobuild HTML documentation while editing'
  26. @echo ' run - run developer instance'
  27. @echo ' install - developer install (./local)'
  28. @echo ' uninstall - uninstall (./local)'
  29. @echo ' gh-pages - build docs & deploy on gh-pages branch'
  30. @echo ' clean - drop builds and environments'
  31. @echo ' project - re-build generic files of the searx project'
  32. @echo ' buildenv - re-build environment files (aka brand)'
  33. @echo ' themes - re-build build the source of the themes'
  34. @echo ' docker - build Docker image'
  35. @echo ' node.env - download & install npm dependencies locally'
  36. @echo ''
  37. @echo 'environment'
  38. @echo ' SEARX_URL = $(SEARX_URL)'
  39. @echo ' GIT_URL = $(GIT_URL)'
  40. @echo ' DOCS_URL = $(DOCS_URL)'
  41. @echo ''
  42. @$(MAKE) -e -s make-help
  43. help-all: help-min
  44. @echo ''
  45. @$(MAKE) -e -s python-help
  46. @echo ''
  47. @$(MAKE) -e -s docs-help
  48. PHONY += install
  49. install: buildenv pyenvinstall
  50. PHONY += uninstall
  51. uninstall: pyenvuninstall
  52. PHONY += clean
  53. clean: pyclean docs-clean node.clean test.clean
  54. $(call cmd,common_clean)
  55. PHONY += run
  56. run: buildenv pyenvinstall
  57. $(Q) ( \
  58. sleep 2 ; \
  59. xdg-open http://127.0.0.1:8888/ ; \
  60. ) &
  61. SEARX_DEBUG=1 $(PY_ENV)/bin/python ./searx/webapp.py
  62. # docs
  63. # ----
  64. sphinx-doc-prebuilds:: buildenv pyenvinstall prebuild-includes
  65. PHONY += docs
  66. docs: sphinx-doc-prebuilds
  67. $(call cmd,sphinx,html,docs,docs)
  68. PHONY += docs-live
  69. docs-live: sphinx-doc-prebuilds
  70. $(call cmd,sphinx_autobuild,html,docs,docs)
  71. PHONY += prebuild-includes
  72. prebuild-includes:
  73. $(Q)mkdir -p $(DOCS_BUILD)/includes
  74. $(Q)./utils/searx.sh doc | cat > $(DOCS_BUILD)/includes/searx.rst
  75. $(Q)./utils/filtron.sh doc | cat > $(DOCS_BUILD)/includes/filtron.rst
  76. $(Q)./utils/morty.sh doc | cat > $(DOCS_BUILD)/includes/morty.rst
  77. $(GH_PAGES)::
  78. @echo "doc available at --> $(DOCS_URL)"
  79. # update project files
  80. # --------------------
  81. PHONY += project engines.languages useragents.update buildenv
  82. project: buildenv useragents.update engines.languages
  83. engines.languages: pyenvinstall
  84. $(Q)echo "fetch languages .."
  85. $(Q)$(PY_ENV_ACT); python utils/fetch_languages.py
  86. $(Q)echo "update searx/data/engines_languages.json"
  87. $(Q)mv engines_languages.json searx/data/engines_languages.json
  88. $(Q)echo "update searx/languages.py"
  89. $(Q)mv languages.py searx/languages.py
  90. useragents.update: pyenvinstall
  91. $(Q)echo "Update searx/data/useragents.json with the most recent versions of Firefox."
  92. $(Q)$(PY_ENV_ACT); python utils/fetch_firefox_version.py
  93. buildenv:
  94. $(Q)echo "build searx/brand.py"
  95. $(Q)echo "GIT_URL = '$(GIT_URL)'" > searx/brand.py
  96. $(Q)echo "GIT_BRANCH = '$(GIT_BRANCH)'" >> searx/brand.py
  97. $(Q)echo "ISSUE_URL = 'https://github.com/searx/searx/issues'" >> searx/brand.py
  98. $(Q)echo "SEARX_URL = '$(SEARX_URL)'" >> searx/brand.py
  99. $(Q)echo "DOCS_URL = '$(DOCS_URL)'" >> searx/brand.py
  100. $(Q)echo "PUBLIC_INSTANCES = 'https://searx.space'" >> searx/brand.py
  101. $(Q)echo "build utils/brand.env"
  102. $(Q)echo "export GIT_URL='$(GIT_URL)'" > utils/brand.env
  103. $(Q)echo "export GIT_BRANCH='$(GIT_BRANCH)'" >> utils/brand.env
  104. $(Q)echo "export ISSUE_URL='https://github.com/searx/searx/issues'" >> utils/brand.env
  105. $(Q)echo "export SEARX_URL='$(SEARX_URL)'" >> utils/brand.env
  106. $(Q)echo "export DOCS_URL='$(DOCS_URL)'" >> utils/brand.env
  107. $(Q)echo "export PUBLIC_INSTANCES='https://searx.space'" >> utils/brand.env
  108. # node / npm
  109. # ----------
  110. node.env: buildenv
  111. $(Q)./manage.sh npm_packages
  112. node.clean:
  113. $(Q)echo "CLEAN locally installed npm dependencies"
  114. $(Q)rm -rf \
  115. ./node_modules \
  116. ./package-lock.json \
  117. ./searx/static/themes/oscar/package-lock.json \
  118. ./searx/static/themes/oscar/node_modules \
  119. ./searx/static/themes/simple/package-lock.json \
  120. ./searx/static/themes/simple/node_modules
  121. # build themes
  122. # ------------
  123. PHONY += themes.bootstrap themes themes.oscar themes.simple themes.legacy themes.courgette themes.pixart
  124. themes: buildenv themes.bootstrap themes.oscar themes.simple themes.legacy themes.courgette themes.pixart
  125. quiet_cmd_lessc = LESSC $3
  126. cmd_lessc = PATH="$$(npm bin):$$PATH" \
  127. lessc --clean-css="--s1 --advanced --compatibility=ie9" "searx/static/$2" "searx/static/$3"
  128. quiet_cmd_grunt = GRUNT $2
  129. cmd_grunt = PATH="$$(npm bin):$$PATH" \
  130. grunt --gruntfile "$2"
  131. themes.oscar: node.env
  132. $(Q)echo '[!] build oscar theme'
  133. $(call cmd,grunt,searx/static/themes/oscar/gruntfile.js)
  134. themes.simple: node.env
  135. $(Q)echo '[!] build simple theme'
  136. $(call cmd,grunt,searx/static/themes/simple/gruntfile.js)
  137. themes.legacy: node.env
  138. $(Q)echo '[!] build legacy theme'
  139. $(call cmd,lessc,themes/legacy/less/style-rtl.less,themes/legacy/css/style-rtl.css)
  140. $(call cmd,lessc,themes/legacy/less/style.less,themes/legacy/css/style.css)
  141. themes.courgette: node.env
  142. $(Q)echo '[!] build courgette theme'
  143. $(call cmd,lessc,themes/courgette/less/style.less,themes/courgette/css/style.css)
  144. $(call cmd,lessc,themes/courgette/less/style-rtl.less,themes/courgette/css/style-rtl.css)
  145. themes.pixart: node.env
  146. $(Q)echo '[!] build pixart theme'
  147. $(call cmd,lessc,themes/pix-art/less/style.less,themes/pix-art/css/style.css)
  148. themes.bootstrap: node.env
  149. $(call cmd,lessc,less/bootstrap/bootstrap.less,css/bootstrap.min.css)
  150. # docker
  151. # ------
  152. PHONY += docker
  153. docker: buildenv
  154. $(Q)./manage.sh docker_build
  155. docker.push: buildenv
  156. $(Q)./manage.sh docker_build push
  157. # gecko
  158. # -----
  159. PHONY += gecko.driver
  160. gecko.driver:
  161. $(PY_ENV_ACT); ./manage.sh install_geckodriver
  162. # test
  163. # ----
  164. PHONY += test test.sh test.pylint test.pep8 test.unit test.coverage test.robot
  165. test: buildenv test.pylint test.pep8 test.unit gecko.driver test.robot
  166. PYLINT_FILES=\
  167. searx/preferences.py \
  168. searx/testing.py \
  169. searx/engines/gigablast.py \
  170. searx/engines/deviantart.py \
  171. searx/engines/digg.py
  172. test.pylint: pyenvinstall
  173. $(call cmd,pylint,$(PYLINT_FILES))
  174. $(call cmd,pylint,\
  175. --disable=$(PYLINT_SEARX_DISABLE_OPTION) \
  176. --additional-builtins=$(PYLINT_ADDITIONAL_BUILTINS_FOR_ENGINES) \
  177. searx/engines \
  178. )
  179. $(call cmd,pylint,\
  180. --disable=$(PYLINT_SEARX_DISABLE_OPTION) \
  181. --ignore=searx/engines \
  182. searx tests \
  183. )
  184. # ignored rules:
  185. # E402 module level import not at top of file
  186. # W503 line break before binary operator
  187. # ubu1604: uses shellcheck v0.3.7 (from 04/2015), no longer supported!
  188. test.sh:
  189. shellcheck -x -s bash utils/brand.env
  190. shellcheck -x utils/lib.sh
  191. shellcheck -x utils/filtron.sh
  192. shellcheck -x utils/searx.sh
  193. shellcheck -x utils/morty.sh
  194. shellcheck -x utils/lxc.sh
  195. shellcheck -x utils/lxc-searx.env
  196. shellcheck -x .config.sh
  197. test.pep8: pyenvinstall
  198. @echo "TEST pycodestyle (formerly pep8)"
  199. $(Q)$(PY_ENV_ACT); pycodestyle --exclude='searx/static, searx/languages.py, $(foreach f,$(PYLINT_FILES),$(f),)' \
  200. --max-line-length=120 --ignore "E117,E252,E402,E722,E741,W503,W504,W605" searx tests
  201. test.unit: pyenvinstall
  202. @echo "TEST tests/unit"
  203. $(Q)$(PY_ENV_ACT); python -m nose2 -s tests/unit
  204. test.coverage: pyenvinstall
  205. @echo "TEST unit test coverage"
  206. $(Q)$(PY_ENV_ACT); \
  207. python -m nose2 -C --log-capture --with-coverage --coverage searx -s tests/unit \
  208. && coverage report \
  209. && coverage html \
  210. test.robot: pyenvinstall gecko.driver
  211. @echo "TEST robot"
  212. $(Q)$(PY_ENV_ACT); PYTHONPATH=. python searx/testing.py robot
  213. test.clean:
  214. @echo "CLEAN intermediate test stuff"
  215. $(Q)rm -rf geckodriver.log .coverage coverage/
  216. # travis
  217. # ------
  218. travis.codecov:
  219. $(Q)$(PY_ENV_BIN)/python -m pip install codecov
  220. .PHONY: $(PHONY)