.travis.yml 10 KB

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