.travis.yml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401
  1. # This script is used by Travis CI to run automatically Continuous test integration
  2. # from Dolibarr GitHub repository.
  3. # For syntax, see http://about.travis-ci.org/docs/user/languages/php/
  4. # We use dist: trusty to have php 5.4+ available
  5. dist: trusty
  6. sudo: required
  7. language: php
  8. # Start on every boot
  9. services:
  10. - memcached
  11. addons:
  12. mariadb: '10.0'
  13. postgresql: '9.3'
  14. apt:
  15. sources:
  16. # To use the last version of pgloader, we add repo of postgresql
  17. - postgresql
  18. - sourceline: 'deb http://apt.postgresql.org/pub/repos/apt/ trusty-pgdg main'
  19. - key_url: 'https://www.postgresql.org/media/keys/ACCC4CF8.asc'
  20. packages:
  21. # We need a webserver to test the webservices
  22. # Let's install Apache with.
  23. - apache2
  24. # mod_php is not supported by Travis. Add fcgi. We install FPM later on.
  25. - libapache2-mod-fastcgi
  26. # We need pgloader for import mysql database into pgsql
  27. - pgloader
  28. php:
  29. - '5.5'
  30. - '5.6'
  31. - '7.0'
  32. - '7.1'
  33. - '7.2'
  34. - '7.3'
  35. - nightly
  36. env:
  37. global:
  38. # Set to true for very verbose output
  39. - DEBUG=false
  40. matrix:
  41. # MariaDB overrides MySQL installation so it's not possible to test both yet
  42. #- DB=mysql
  43. - DB=mariadb
  44. - DB=postgresql
  45. # TODO
  46. #- DB=sqlite
  47. # See https://docs.travis-ci.com/user/languages/php/#Apache-%2B-PHP
  48. #- WS=apache
  49. # See https://github.com/DracoBlue/travis-ci-nginx-php-fpm-test
  50. #- WS=nginx
  51. matrix:
  52. fast_finish: true
  53. allow_failures:
  54. - php: nightly
  55. # We exclude some combinations not usefull to save Travis CPU
  56. exclude:
  57. - php: '5.6'
  58. env: DB=mariadb
  59. - php: '7.0'
  60. env: DB=mariadb
  61. - php: '7.1'
  62. env: DB=mariadb
  63. - php: '7.2'
  64. env: DB=mariadb
  65. - php: '5.6'
  66. env: DB=postgresql
  67. - php: '7.0'
  68. env: DB=postgresql
  69. - php: '7.1'
  70. env: DB=postgresql
  71. - php: '7.2'
  72. env: DB=postgresql
  73. - php: nightly
  74. env: DB=postgresql
  75. notifications:
  76. email:
  77. on_success: never # [always|never|change] default: change
  78. on_failure: never # [always|never|change] default: always
  79. irc:
  80. channels:
  81. - "chat.freenode.net#dolibarr"
  82. on_success: change
  83. on_failure: always
  84. use_notice: true
  85. before_install:
  86. - |
  87. echo "Disabling Xdebug for composer"
  88. export PHP_VERSION_NAME=$(phpenv version-name)
  89. cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/conf.d/xdebug.ini /tmp/xdebug.ini
  90. phpenv config-rm xdebug.ini
  91. echo
  92. - |
  93. if [ "$DB" = 'postgresql' ]; then
  94. echo "Check pgloader version"
  95. pgloader --version
  96. echo
  97. fi
  98. install:
  99. - |
  100. echo "Updating Composer"
  101. rm $TRAVIS_BUILD_DIR/composer.json
  102. rm $TRAVIS_BUILD_DIR/composer.lock
  103. composer self-update
  104. composer -n init
  105. composer -n config vendor-dir htdocs/includes
  106. echo
  107. - |
  108. echo "Installing Parallel Lint"
  109. composer -n require jakub-onderka/php-parallel-lint ^0
  110. composer -n require jakub-onderka/php-console-highlighter ^0
  111. echo
  112. - |
  113. echo "Installing PHP Unit"
  114. if [ "$TRAVIS_PHP_VERSION" = '5.4' ] || [ "$TRAVIS_PHP_VERSION" = '5.5' ]; then
  115. composer -n require phpunit/phpunit ^4
  116. fi
  117. if [ "$TRAVIS_PHP_VERSION" = '5.6' ] || [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = '7.1' ]; then
  118. composer -n require phpunit/phpunit ^5
  119. fi
  120. if [ "$TRAVIS_PHP_VERSION" = '7.2' ] || [ "$TRAVIS_PHP_VERSION" = '7.3' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
  121. composer -n require phpunit/phpunit ^5
  122. fi
  123. echo
  124. - |
  125. echo "Installing PHP CodeSniffer"
  126. composer -n require squizlabs/php_codesniffer ^3
  127. echo
  128. - |
  129. echo "Adding path of binaries tools installed by composer to the PATH"
  130. export PATH="$TRAVIS_BUILD_DIR/htdocs/includes/bin:$PATH"
  131. echo
  132. before_script:
  133. - |
  134. echo Start travis
  135. echo Current dir is `pwd`
  136. echo Home dir is `echo ~`
  137. echo TRAVIS_BUILD_DIR is $TRAVIS_BUILD_DIR
  138. - |
  139. echo "Re-enabling Xdebug for PHP CodeSniffer and PHP Unit"
  140. phpenv config-add /tmp/xdebug.ini
  141. echo
  142. - |
  143. echo "Setting up PHP"
  144. echo
  145. echo "Set timezone"
  146. echo 'date.timezone = "Europe/Paris"' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
  147. phpenv rehash
  148. echo
  149. - |
  150. echo "Versions information"
  151. # Check PHP
  152. echo "PHP version"
  153. php -i | head -
  154. # Check PHP CodeSniffer installation
  155. echo "PHPCS version"
  156. which phpcs
  157. phpcs --version | head -
  158. phpcs -i | head -
  159. # Check PHPUnit installation
  160. echo "PHPUnit version"
  161. which phpunit
  162. phpunit --version | head -
  163. # Check Apache version
  164. echo "Apache version"
  165. apache2 -v | head -
  166. # Check MariaDb
  167. echo "MariaDb version"
  168. mysql --version | head -
  169. mysql -e "SELECT VERSION();" | head -
  170. echo
  171. - |
  172. echo "Setting up database"
  173. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ] || [ "$DB" = 'postgresql' ]; then
  174. echo "MySQL"
  175. mysql -e 'DROP DATABASE IF EXISTS travis;'
  176. mysql -e 'CREATE DATABASE IF NOT EXISTS travis;'
  177. mysql -e 'GRANT ALL PRIVILEGES ON travis.* TO travis@127.0.0.1;'
  178. mysql -e 'FLUSH PRIVILEGES;'
  179. mysql -D travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  180. fi
  181. if [ "$DB" = 'postgresql' ]; then
  182. #pgloader mysql://root:pass@127.0.0.1/dolibarr_9 postgresql://dolibarrowner:dolibarrownerpass@127.0.0.1/dolibarr_dev
  183. echo pgloader mysql://root@127.0.0.1/travis postgresql:///travis
  184. pgloader mysql://root@127.0.0.1/travis postgresql:///travis
  185. echo 'ALTER SEQUENCE llx_accountingaccount_rowid_seq RENAME TO llx_accounting_account_rowid_seq' | psql travis
  186. echo 'ALTER SEQUENCE llx_accounting_account_rowid_seq RESTART WITH 1000001;' | psql travis
  187. #echo 'select * from INFORMATION_SCHEMA.COLUMNS where table_name = 'llx_accountingaccount' | psql travis
  188. #echo 'select * from information_schema.table_constraints;' | psql travis
  189. #echo 'ALTER TABLE "llx_accounting_account" DROP CONSTRAINT "idx_16390_primary"' | psql travis
  190. fi
  191. # TODO: SQLite
  192. echo
  193. - |
  194. export CONF_FILE=htdocs/conf/conf.php
  195. echo "Setting up Dolibarr $CONF_FILE"
  196. echo '<?php' > $CONF_FILE
  197. echo '$'dolibarr_main_url_root=\'http://127.0.0.1\'';' >> $CONF_FILE
  198. echo '$'dolibarr_main_document_root=\'$TRAVIS_BUILD_DIR/htdocs\'';' >> $CONF_FILE
  199. echo '$'dolibarr_main_data_root=\'$TRAVIS_BUILD_DIR/documents\'';' >> $CONF_FILE
  200. echo '$'dolibarr_main_db_host=\'127.0.0.1\'';' >> $CONF_FILE
  201. echo '$'dolibarr_main_db_name=\'travis\'';' >> $CONF_FILE
  202. echo '$'dolibarr_main_db_user=\'travis\'';' >> $CONF_FILE
  203. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
  204. echo '$'dolibarr_main_db_type=\'mysqli\'';' >> $CONF_FILE
  205. echo '$'dolibarr_main_db_port=\'3306\'';' >> $CONF_FILE
  206. fi
  207. if [ "$DB" = 'postgresql' ]; then
  208. echo '$'dolibarr_main_db_type=\'pgsql\'';' >> $CONF_FILE
  209. echo '$'dolibarr_main_db_port=\'5432\'';' >> $CONF_FILE
  210. fi
  211. # TODO: SQLite
  212. echo '$'dolibarr_main_authentication=\'dolibarr\'';' >> $CONF_FILE
  213. cat $CONF_FILE
  214. echo
  215. - |
  216. echo "Create documents directory and set permissions"
  217. # and admin/temp subdirectory needed for unit tests
  218. mkdir -p $TRAVIS_BUILD_DIR/documents/admin/temp
  219. sudo chmod -R a+rwx $TRAVIS_BUILD_DIR/documents
  220. echo "***** First line of dolibarr.log" > $TRAVIS_BUILD_DIR/documents/dolibarr.log
  221. echo
  222. - echo "Setting up Apache + FPM"
  223. - sudo apt-get update
  224. - sudo apt-get install apache2 libapache2-mod-fastcgi
  225. # enable php-fpm
  226. - sudo cp ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf.default ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf
  227. - |
  228. if [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = '7.1' ] || [ "$TRAVIS_PHP_VERSION" = '7.2' ] || [ "$TRAVIS_PHP_VERSION" = '7.3' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
  229. # Copy the included pool
  230. sudo cp ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.d/www.conf.default ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.d/www.conf
  231. fi
  232. - sudo a2enmod rewrite actions fastcgi alias
  233. - echo "cgi.fix_pathinfo = 1" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
  234. - sudo sed -i -e "s,www-data,travis,g" /etc/apache2/envvars
  235. - sudo chown -R travis:travis /var/lib/apache2/fastcgi
  236. - ~/.phpenv/versions/$(phpenv version-name)/sbin/php-fpm
  237. # configure apache virtual hosts for precise
  238. #- sudo sed -e "s?%TRAVIS_BUILD_DIR%?$(pwd)?g" --in-place /etc/apache2/sites-available/default
  239. #- sudo cat /etc/apache2/sites-available/default
  240. # configure apache virtual hosts for trusty
  241. - sudo cp -f build/travis-ci/apache.conf /etc/apache2/sites-available/000-default.conf
  242. - sudo sed -e "s?%TRAVIS_BUILD_DIR%?$(pwd)?g" --in-place /etc/apache2/sites-available/000-default.conf
  243. - sudo cat /etc/apache2/sites-available/000-default.conf
  244. - sudo service apache2 restart
  245. script:
  246. - |
  247. echo "Checking webserver availability by a wget -O - http://127.0.0.1"
  248. # Ensure we stop on error with set -e
  249. set +e
  250. # The wget should return a page with line '<meta name="generator" content="Dolibarr installer">
  251. wget -O - http://127.0.0.1 > test.html
  252. head test.html
  253. sudo cat /var/log/apache2/travis_error_log
  254. set +e
  255. echo
  256. - |
  257. echo "Checking PHP syntax errors"
  258. # Ensure we catch errors
  259. set -e
  260. #parallel-lint --exclude htdocs/includes --blame .
  261. parallel-lint --exclude htdocs/includes/sabre --exclude htdocs/includes/phpoffice/phpexcel/Classes/PHPExcel/Shared --exclude htdocs/includes/phpoffice/PhpSpreadsheet --exclude htdocs/includes/sebastian --exclude htdocs/includes/squizlabs/php_codesniffer/tests --exclude htdocs/includes/jakub-onderka/php-parallel-lint/tests --exclude htdocs/includes/mike42/escpos-php/example --exclude htdocs/includes/phpunit/php-token-stream/tests --exclude htdocs/includes/composer/autoload_static.php --blame .
  262. set +e
  263. echo
  264. - |
  265. echo "Checking coding style"
  266. # Ensure we catch errors
  267. set -e
  268. # Exclusions are defined in the ruleset.xml file
  269. #phpcs -s -n -p -d memory_limit=-1 --colors --tab-width=4 --standard=dev/setup/codesniffer/ruleset.xml --encoding=utf-8 .
  270. phpcs -s -p -d memory_limit=-1 --extensions=php --colors --tab-width=4 --standard=dev/setup/codesniffer/ruleset.xml --encoding=utf-8 --runtime-set ignore_warnings_on_exit true .
  271. set +e
  272. echo
  273. # TODO: Check Javascript (jshint?)
  274. # TODO: Check CSS (csslint?)
  275. - |
  276. echo "Upgrading Dolibarr"
  277. # Ensure we catch errors. Set this to +e if you want to go to the end to see log files.
  278. set +e
  279. cd htdocs/install
  280. php upgrade.php 3.5.0 3.6.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade350360.log
  281. php upgrade2.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-2.log
  282. php step5.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-3.log
  283. php upgrade.php 3.6.0 3.7.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade360370.log
  284. php upgrade2.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-2.log
  285. php step5.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-3.log
  286. php upgrade.php 3.7.0 3.8.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade370380.log
  287. php upgrade2.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-2.log
  288. php step5.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-3.log
  289. php upgrade.php 3.8.0 3.9.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade380390.log
  290. php upgrade2.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-2.log
  291. php step5.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-3.log
  292. php upgrade.php 3.9.0 4.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade390400.log
  293. php upgrade2.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-2.log
  294. php step5.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-3.log
  295. php upgrade.php 4.0.0 5.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade400500.log
  296. php upgrade2.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-2.log
  297. php step5.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-3.log
  298. php upgrade.php 5.0.0 6.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade500600.log
  299. php upgrade2.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-2.log
  300. php step5.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-3.log
  301. php upgrade.php 6.0.0 7.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade600700.log
  302. php upgrade2.php 6.0.0 7.0.0 > $TRAVIS_BUILD_DIR/upgrade600700-2.log
  303. php step5.php 6.0.0 7.0.0 > $TRAVIS_BUILD_DIR/upgrade600700-3.log
  304. php upgrade.php 7.0.0 8.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade700800.log
  305. php upgrade2.php 7.0.0 8.0.0 > $TRAVIS_BUILD_DIR/upgrade700800-2.log
  306. php step5.php 7.0.0 8.0.0 > $TRAVIS_BUILD_DIR/upgrade700800-3.log
  307. php upgrade.php 8.0.0 9.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade800900.log
  308. php upgrade2.php 8.0.0 9.0.0 > $TRAVIS_BUILD_DIR/upgrade800900-2.log
  309. php step5.php 8.0.0 9.0.0 > $TRAVIS_BUILD_DIR/upgrade800900-3.log
  310. php upgrade.php 9.0.0 10.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade9001000.log
  311. php upgrade2.php 9.0.0 10.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-2.log
  312. php step5.php 9.0.0 10.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-3.log
  313. php upgrade.php 10.0.0 11.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade9001000.log
  314. php upgrade2.php 10.0.0 11.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-2.log
  315. php step5.php 10.0.0 11.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-3.log
  316. # Enable modules not enabled into original dump
  317. php upgrade2.php 0.0.0 0.0.0 MAIN_MODULE_API,MAIN_MODULE_SUPPLIERPROPOSAL,MAIN_MODULE_WEBSITE,MAIN_MODULE_TICKETSUP,MAIN_MODULE_ACCOUNTING > $TRAVIS_BUILD_DIR/enablemodule.log
  318. echo $?
  319. cd -
  320. set +e
  321. echo
  322. #cat /tmp/dolibarr_install.log
  323. cat $TRAVIS_BUILD_DIR/enablemodule.log
  324. - |
  325. echo "Unit testing"
  326. # Ensure we catch errors. Set this to +e if you want to go to the end to see dolibarr.log file.
  327. set -e
  328. phpunit -d memory_limit=-1 -c test/phpunit/phpunittest.xml test/phpunit/AllTests.php
  329. phpunitresult=$?
  330. echo "Phpunit return code = $phpunitresult"
  331. set +e
  332. after_script:
  333. - |
  334. echo "After script - Output lines of dolibarr.log"
  335. ls $TRAVIS_BUILD_DIR/documents
  336. #cat $TRAVIS_BUILD_DIR/documents/dolibarr.log
  337. sudo tail -n 50 $TRAVIS_BUILD_DIR/documents/dolibarr.log
  338. after_success:
  339. - |
  340. echo Success
  341. after_failure:
  342. - |
  343. echo Failure detected, so we show samples of log to help diagnose
  344. # This part of code is executed only if previous command that fails are enclosed with set +e
  345. # Upgrade log files
  346. for ficlog in `ls $TRAVIS_BUILD_DIR/*.log`
  347. do
  348. echo "Debugging informations for file $ficlog"
  349. #cat $ficlog
  350. done
  351. # Apache log file
  352. echo "Debugging informations for file apache error.log"
  353. sudo cat /var/log/apache2/travis_error_log
  354. if [ "$DEBUG" = true ]; then
  355. # Dolibarr log file
  356. echo "Debugging informations for file dolibarr.log (latest 50 lines)"
  357. tail -n 50 $TRAVIS_BUILD_DIR/documents/dolibarr.log
  358. # MariaDB log file
  359. echo "Debugging informations for file mysql error.log"
  360. sudo tail -n 50 /var/log/mysql/error.log
  361. # TODO: PostgreSQL log file
  362. echo
  363. fi