.travis.yml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  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. dist: precise
  5. sudo: required
  6. language: php
  7. php:
  8. - '5.3'
  9. - '5.4'
  10. - '5.5'
  11. - '5.6'
  12. - '7.0'
  13. - '7.1'
  14. - nightly
  15. addons:
  16. mariadb: '10.0'
  17. postgresql: '9.3'
  18. apt:
  19. sources:
  20. # To use the last version of pgloader, we add repo of postgresql
  21. - postgresql
  22. - sourceline: 'deb http://apt.postgresql.org/pub/repos/apt/ trusty-pgdg main'
  23. - key_url: 'https://www.postgresql.org/media/keys/ACCC4CF8.asc'
  24. packages:
  25. # We need a webserver to test the webservices
  26. # Let's install Apache with.
  27. - apache2
  28. # mod_php is not supported by Travis. Add fcgi. We install FPM later on.
  29. - libapache2-mod-fastcgi
  30. # We need pgloader for import mysql database into pgsql
  31. - pgloader
  32. # Start on every boot
  33. services:
  34. - memcached
  35. env:
  36. global:
  37. # Set to true for very verbose output
  38. - DEBUG=false
  39. matrix:
  40. # MariaDB overrides MySQL installation so it's not possible to test both yet
  41. #- DB=mysql
  42. - DB=mariadb
  43. - DB=postgresql
  44. # TODO
  45. #- DB=sqlite
  46. # See https://docs.travis-ci.com/user/languages/php/#Apache-%2B-PHP
  47. #- WS=apache
  48. # See https://github.com/DracoBlue/travis-ci-nginx-php-fpm-test
  49. #- WS=nginx
  50. matrix:
  51. fast_finish: true
  52. allow_failures:
  53. - php: 7.1
  54. - php: nightly
  55. #- env: DB=postgresql
  56. # TODO
  57. #- env: DB=sqlite
  58. notifications:
  59. email:
  60. on_success: never # [always|never|change] default: change
  61. on_failure: change # [always|never|change] default: always
  62. irc:
  63. channels:
  64. - "chat.freenode.net#dolibarr"
  65. on_success: change
  66. on_failure: always
  67. use_notice: true
  68. before_install:
  69. - |
  70. echo "Disabling Xdebug for composer"
  71. export PHP_VERSION_NAME=$(phpenv version-name)
  72. cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/conf.d/xdebug.ini /tmp/xdebug.ini
  73. phpenv config-rm xdebug.ini
  74. echo
  75. - |
  76. if [ "$DB" = 'postgresql' ]; then
  77. echo "Check pgloader version"
  78. pgloader --version
  79. echo
  80. fi
  81. install:
  82. - |
  83. echo "Updating Composer"
  84. rm $TRAVIS_BUILD_DIR/composer.json
  85. rm $TRAVIS_BUILD_DIR/composer.lock
  86. composer self-update
  87. composer -n init
  88. composer -n config vendor-dir htdocs/includes
  89. echo
  90. - |
  91. echo "Installing Parallel Lint"
  92. composer -n require jakub-onderka/php-parallel-lint ^0
  93. composer -n require jakub-onderka/php-console-highlighter ^0
  94. echo
  95. - |
  96. echo "Installing PHP Unit"
  97. if [ "$TRAVIS_PHP_VERSION" = '5.3' ] || [ "$TRAVIS_PHP_VERSION" = '5.4' ] || [ "$TRAVIS_PHP_VERSION" = '5.5' ]; then
  98. composer -n require phpunit/phpunit ^4
  99. fi
  100. if [ "$TRAVIS_PHP_VERSION" = '5.6' ] || [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = '7.1' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
  101. composer -n require phpunit/phpunit ^5
  102. fi
  103. echo
  104. - |
  105. echo "Installing PHP CodeSniffer"
  106. composer -n require squizlabs/php_codesniffer ^2
  107. echo
  108. - |
  109. echo "Adding path of binaries tools installed by composer to the PATH"
  110. export PATH="$TRAVIS_BUILD_DIR/htdocs/includes/bin:$PATH"
  111. echo
  112. before_script:
  113. - |
  114. echo Start travis
  115. echo Current dir is `pwd`
  116. echo Home dir is `echo ~`
  117. echo TRAVIS_BUILD_DIR is $TRAVIS_BUILD_DIR
  118. - |
  119. echo "Re-enabling Xdebug for PHP CodeSniffer and PHP Unit"
  120. phpenv config-add /tmp/xdebug.ini
  121. echo
  122. - |
  123. echo "Setting up PHP"
  124. echo
  125. echo "Set timezone"
  126. echo 'date.timezone = "Europe/Paris"' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
  127. if [ "$TRAVIS_PHP_VERSION" = '5.3' ] || [ "$TRAVIS_PHP_VERSION" = '5.4' ]; then
  128. #echo
  129. #echo "Enabling APC for PHP <= 5.4"
  130. # Documentation says it should be available for PHP <= 5.6 but it's not for 5.5 and 5.6!
  131. #echo 'extension = apc.so' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
  132. echo
  133. echo "Enabling Memcached for PHP <= 5.4"
  134. # Documentation says it should be available for all PHP versions but it's not for 5.5 and 5.6, 7.0, 7.1 and nightly!
  135. echo 'extension = memcached.so' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
  136. fi
  137. phpenv rehash
  138. echo
  139. - |
  140. if [ "$DEBUG" = true ]; then
  141. echo "Debugging informations"
  142. # Check PHP
  143. php -i
  144. # Check PHP CodeSniffer installation
  145. which phpcs
  146. phpcs --version
  147. phpcs -i
  148. # Check PHPUnit installation
  149. which phpunit
  150. phpunit --version
  151. # Check MySQL
  152. mysql --version
  153. mysql -e "SELECT VERSION();"
  154. echo
  155. fi
  156. - |
  157. echo "Setting up database"
  158. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ] || [ "$DB" = 'postgresql' ]; then
  159. echo "MySQL"
  160. mysql -e 'DROP DATABASE IF EXISTS travis;'
  161. mysql -e 'CREATE DATABASE IF NOT EXISTS travis;'
  162. mysql -e 'GRANT ALL PRIVILEGES ON travis.* TO travis@127.0.0.1;'
  163. mysql -e 'FLUSH PRIVILEGES;'
  164. mysql -D travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  165. fi
  166. if [ "$DB" = 'postgresql' ]; then
  167. #pgsql travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  168. #pgloader mysql://root:pass@127.0.0.1/base postgresql://dolibarrowner@127.0.0.1/dolibarr
  169. pgloader mysql://root@127.0.0.1/travis postgresql:///travis
  170. fi
  171. # TODO: SQLite
  172. echo
  173. - |
  174. export CONF_FILE=htdocs/conf/conf.php
  175. echo "Setting up Dolibarr $CONF_FILE"
  176. echo '<?php ' > $CONF_FILE
  177. echo '$'dolibarr_main_url_root=\'http://127.0.0.1\'';' >> $CONF_FILE
  178. echo '$'dolibarr_main_document_root=\'$TRAVIS_BUILD_DIR/htdocs\'';' >> $CONF_FILE
  179. echo '$'dolibarr_main_data_root=\'$TRAVIS_BUILD_DIR/documents\'';' >> $CONF_FILE
  180. echo '$'dolibarr_main_db_host=\'127.0.0.1\'';' >> $CONF_FILE
  181. echo '$'dolibarr_main_db_name=\'travis\'';' >> $CONF_FILE
  182. echo '$'dolibarr_main_db_user=\'travis\'';' >> $CONF_FILE
  183. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
  184. echo '$'dolibarr_main_db_type=\'mysqli\'';' >> $CONF_FILE
  185. fi
  186. if [ "$DB" = 'postgresql' ]; then
  187. echo '$'dolibarr_main_db_type=\'pgsql\'';' >> $CONF_FILE
  188. fi
  189. # TODO: SQLite
  190. echo '$'dolibarr_main_authentication=\'dolibarr\'';' >> $CONF_FILE
  191. cat $CONF_FILE
  192. echo
  193. - |
  194. echo "Create documents directory and set permissions"
  195. # and admin/temp subdirectory needed for unit tests
  196. mkdir -p documents/admin/temp
  197. echo "first line" > documents/dolibarr.log
  198. echo
  199. - |
  200. echo "Setting up Apache + FPM"
  201. # enable php-fpm
  202. cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.conf.default ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.conf
  203. if [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = '7.1' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
  204. # Copy the included pool
  205. cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.d/www.conf.default ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.d/www.conf
  206. fi
  207. if [ "$DEBUG" = true ]; then
  208. cat ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.conf
  209. fi
  210. sudo a2enmod rewrite actions fastcgi alias
  211. echo "cgi.fix_pathinfo = 1" >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
  212. if [ "$DEBUG" = true ]; then
  213. cat ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
  214. fi
  215. ~/.phpenv/versions/$PHP_VERSION_NAME/sbin/php-fpm
  216. # configure apache virtual hosts
  217. sudo cp -f build/travis-ci/apache.conf /etc/apache2/sites-available/default
  218. sudo sed -e "s?%TRAVIS_BUILD_DIR%?$TRAVIS_BUILD_DIR?g" --in-place /etc/apache2/sites-available/default
  219. if [ "$DEBUG" = true ]; then
  220. sudo cat /etc/apache2/sites-available/default
  221. fi
  222. sudo service apache2 restart
  223. echo
  224. script:
  225. - |
  226. echo "Checking webserver availability"
  227. # Ensure we catch errors
  228. set -e
  229. wget http://127.0.0.1
  230. if [ "$DEBUG" = true ]; then
  231. cat index.html
  232. fi
  233. set +e
  234. echo
  235. - |
  236. echo "Checking PHP syntax errors"
  237. # Ensure we catch errors
  238. set -e
  239. parallel-lint --exclude htdocs/includes --blame .
  240. set +e
  241. echo
  242. - |
  243. echo "Checking coding style"
  244. # Ensure we catch errors
  245. set -e
  246. # Exclusions are defined in the ruleset.xml file
  247. phpcs -s -n -p -d memory_limit=-1 --colors --tab-width=4 --standard=dev/setup/codesniffer/ruleset.xml --encoding=utf-8 .
  248. set +e
  249. echo
  250. # TODO: Check Javascript (jshint?)
  251. # TODO: Check CSS (csslint?)
  252. - |
  253. echo "Upgrading Dolibarr"
  254. # Ensure we catch errors
  255. set +e
  256. cd htdocs/install
  257. php upgrade.php 3.5.0 3.6.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade350360.log
  258. php upgrade2.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-2.log
  259. php step5.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-3.log
  260. php upgrade.php 3.6.0 3.7.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade360370.log
  261. php upgrade2.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-2.log
  262. php step5.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-3.log
  263. php upgrade.php 3.7.0 3.8.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade370380.log
  264. php upgrade2.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-2.log
  265. php step5.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-3.log
  266. php upgrade.php 3.8.0 3.9.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade380390.log
  267. php upgrade2.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-2.log
  268. php step5.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-3.log
  269. php upgrade.php 3.9.0 4.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade390400.log
  270. php upgrade2.php 3.9.0 4.0.0 MAIN_MODULE_API,MAIN_MODULE_SUPPLIERPROPOSAL > $TRAVIS_BUILD_DIR/upgrade390400-2.log
  271. php step5.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-3.log
  272. php upgrade.php 4.0.0 5.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade400500.log
  273. php upgrade2.php 4.0.0 5.0.0 MAIN_MODULE_API,MAIN_MODULE_SUPPLIERPROPOSAL > $TRAVIS_BUILD_DIR/upgrade400500-2.log
  274. php step5.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-3.log
  275. php upgrade.php 5.0.0 6.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade500600.log
  276. php upgrade2.php 5.0.0 6.0.0 MAIN_MODULE_API,MAIN_MODULE_SUPPLIERPROPOSAL > $TRAVIS_BUILD_DIR/upgrade500600-2.log
  277. php step5.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-3.log
  278. cd -
  279. set +e
  280. echo
  281. #cat $TRAVIS_BUILD_DIR/upgrade400500-2.log
  282. #cat /tmp/dolibarr_install.log
  283. - |
  284. echo "Unit testing"
  285. # Ensure we catch errors. Set this to +e if you want to go to the end to see log file.
  286. set -e
  287. phpunit -d memory_limit=-1 -c test/phpunit/phpunittest.xml test/phpunit/AllTests.php
  288. set +e
  289. - |
  290. #echo "Output dolibarr.log"
  291. #echo cat documents/dolibarr.log
  292. after_script:
  293. - |
  294. # Dolibarr log file
  295. #echo "After script"
  296. #cat documents/dolibarr.log
  297. after_success:
  298. - |
  299. echo Success
  300. after_failure:
  301. - |
  302. echo Failure
  303. # This part of code seems to be never executed, error or not ???
  304. echo "Debugging informations"
  305. # Upgrade log files
  306. cat *.log
  307. echo "Debugging informations"
  308. # Apache log file
  309. sudo cat /var/log/apache2/error.log
  310. # Dolibarr log file
  311. cat documents/dolibarr.log
  312. if [ "$DEBUG" = true ]; then
  313. # MariaDB log file
  314. sudo cat /var/log/mysql/error.log
  315. # TODO: PostgreSQL log file
  316. echo
  317. fi