.travis.yml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440
  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: xenial to have php 5.6+ available
  5. os: linux
  6. dist: xenial
  7. #dist: bionic
  8. language: php
  9. # Start on every boot
  10. services:
  11. - memcached
  12. - mysql
  13. - postgresql
  14. addons:
  15. # Force postgresql to 9.4 (the oldest availablable on xenial)
  16. postgresql: '9.4'
  17. apt:
  18. sources:
  19. # To use the last version of pgloader, we add repo of postgresql with a name available in http://apt.postgresql.org/pub/repos/apt/
  20. - pgdg-xenial
  21. packages:
  22. # We need a webserver to test the webservices
  23. # Let's install Apache with.
  24. - apache2
  25. # mod_php is not supported by Travis. Add fcgi. We install FPM later on.
  26. - libapache2-mod-fastcgi
  27. # We need pgloader for import mysql database into pgsql
  28. - pgloader
  29. env:
  30. global:
  31. # Set to true for very verbose output
  32. - DEBUG=false
  33. jobs:
  34. fast_finish: true
  35. allow_failures:
  36. - php: nightly
  37. include:
  38. - if: type = push
  39. php: '5.6'
  40. env: DB=postgresql
  41. - if: type = pull_request OR type = push
  42. php: '7.4'
  43. env: DB=mysql
  44. - if: type = push AND branch = develop
  45. php: nightly
  46. env: DB=mysql
  47. notifications:
  48. email:
  49. on_success: never # [always|never|change] default: change
  50. on_failure: never # [always|never|change] default: always
  51. irc:
  52. channels:
  53. - "chat.freenode.net#dolibarr"
  54. on_success: change
  55. on_failure: always
  56. use_notice: true
  57. before_install:
  58. - |
  59. echo "Disabling Xdebug for composer"
  60. export PHP_VERSION_NAME=$(phpenv version-name)
  61. cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/conf.d/xdebug.ini /tmp/xdebug.ini
  62. phpenv config-rm xdebug.ini
  63. echo
  64. - |
  65. if [ "$DB" = 'postgresql' ]; then
  66. echo "Check pgloader version"
  67. pgloader --version
  68. echo
  69. fi
  70. install:
  71. - |
  72. echo "Updating Composer"
  73. rm $TRAVIS_BUILD_DIR/composer.json
  74. rm $TRAVIS_BUILD_DIR/composer.lock
  75. composer -V
  76. composer self-update
  77. composer -n init
  78. composer -n config vendor-dir htdocs/includes
  79. composer -n config -g vendor-dir htdocs/includes
  80. echo
  81. - |
  82. echo "Installing Composer dependencies (PHP Unit, Parallel Lint & PHP CodeSniffer"
  83. if [ "$TRAVIS_PHP_VERSION" = '5.4' ] || [ "$TRAVIS_PHP_VERSION" = '5.5' ]; then
  84. composer -n require phpunit/phpunit ^4 \
  85. jakub-onderka/php-parallel-lint ^0 \
  86. jakub-onderka/php-console-highlighter ^0 \
  87. squizlabs/php_codesniffer ^3
  88. fi
  89. if [ "$TRAVIS_PHP_VERSION" = '5.6' ] || [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = '7.1' ] \
  90. [ "$TRAVIS_PHP_VERSION" = '7.2' ] || [ "$TRAVIS_PHP_VERSION" = '7.3' ] || [ "$TRAVIS_PHP_VERSION" = '7.4' ]; then
  91. composer -n require phpunit/phpunit ^5 \
  92. jakub-onderka/php-parallel-lint ^0 \
  93. jakub-onderka/php-console-highlighter ^0 \
  94. squizlabs/php_codesniffer ^3
  95. fi
  96. if [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
  97. composer -n require --ignore-platform-reqs phpunit/phpunit ^5 \
  98. jakub-onderka/php-parallel-lint ^0 \
  99. jakub-onderka/php-console-highlighter ^0 \
  100. squizlabs/php_codesniffer ^3
  101. fi
  102. echo
  103. - |
  104. echo "Adding path of binaries tools installed by composer to the PATH"
  105. export PATH="$TRAVIS_BUILD_DIR/htdocs/includes/bin:$PATH"
  106. echo $PATH
  107. ls $TRAVIS_BUILD_DIR/vendor
  108. ls $TRAVIS_BUILD_DIR/htdocs/includes/bin
  109. echo
  110. before_script:
  111. - |
  112. echo Start travis
  113. echo Current dir is `pwd`
  114. echo Home dir is `echo ~`
  115. echo TRAVIS_BUILD_DIR is $TRAVIS_BUILD_DIR
  116. - |
  117. echo "Re-enabling Xdebug for PHP CodeSniffer and PHP Unit"
  118. phpenv config-add /tmp/xdebug.ini
  119. echo
  120. - |
  121. echo "Setting up PHP"
  122. echo
  123. echo "Set timezone"
  124. echo 'date.timezone = "Europe/Paris"' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
  125. phpenv rehash
  126. echo
  127. - |
  128. echo "Versions information"
  129. echo
  130. # Check PHP
  131. echo "PHP version"
  132. php -i | head -
  133. # Check Parallel-lint version
  134. echo "Parallel-lint version"
  135. which parallel-lint
  136. parallel-lint -V
  137. # Check PHP CodeSniffer version
  138. echo "PHPCS version"
  139. which phpcs
  140. phpcs --version | head -
  141. phpcs -i | head -
  142. # Check PHPUnit version
  143. echo "PHPUnit version"
  144. which phpunit
  145. phpunit --version | head -
  146. # Check Apache version
  147. echo "Apache version"
  148. apache2 -v | head -
  149. # Check Database
  150. echo "Database version"
  151. mysql --version | head -
  152. mysql -e "SELECT VERSION();" | head -
  153. psql --version
  154. echo
  155. - |
  156. echo "Setting up database"
  157. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ] || [ "$DB" = 'postgresql' ]; then
  158. echo "MySQL"
  159. mysql -u root -e 'DROP DATABASE IF EXISTS travis;'
  160. mysql -u root -e 'CREATE DATABASE IF NOT EXISTS travis;'
  161. mysql -u root -e 'GRANT ALL PRIVILEGES ON travis.* TO travis@127.0.0.1;'
  162. mysql -u root -e 'FLUSH PRIVILEGES;'
  163. mysql -u root -D travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  164. fi
  165. if [ "$DB" = 'postgresql' ]; then
  166. #psql -c 'create database travis;' -U postgres
  167. #psql travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  168. #pgloader mysql://root:pass@127.0.0.1/dolibarr_src postgresql://dolibarrowner:dolibarrownerpass@127.0.0.1/dolibarr_dest
  169. echo pgloader mysql://root@127.0.0.1/travis postgresql://postgres@/travis
  170. pgloader mysql://root@127.0.0.1/travis postgresql://postgres@/travis
  171. echo 'ALTER SEQUENCE llx_accountingaccount_rowid_seq RENAME TO llx_accounting_account_rowid_seq' | psql -U postgres travis
  172. echo 'ALTER SEQUENCE llx_accounting_account_rowid_seq RESTART WITH 1000001;' | psql -U postgres travis
  173. fi
  174. echo
  175. - |
  176. export CONF_FILE=htdocs/conf/conf.php
  177. echo "Setting up Dolibarr $CONF_FILE"
  178. echo '<?php' > $CONF_FILE
  179. echo '$'dolibarr_main_url_root=\'http://127.0.0.1\'';' >> $CONF_FILE
  180. echo '$'dolibarr_main_document_root=\'$TRAVIS_BUILD_DIR/htdocs\'';' >> $CONF_FILE
  181. echo '$'dolibarr_main_data_root=\'$TRAVIS_BUILD_DIR/documents\'';' >> $CONF_FILE
  182. echo '$'dolibarr_main_db_host=\'127.0.0.1\'';' >> $CONF_FILE
  183. echo '$'dolibarr_main_db_name=\'travis\'';' >> $CONF_FILE
  184. echo '$'dolibarr_main_db_user=\'travis\'';' >> $CONF_FILE
  185. echo '$'dolibarr_main_instance_unique_id=\'travis1234567890\'';' >> $CONF_FILE
  186. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
  187. echo '$'dolibarr_main_db_type=\'mysqli\'';' >> $CONF_FILE
  188. echo '$'dolibarr_main_db_port=\'3306\'';' >> $CONF_FILE
  189. fi
  190. if [ "$DB" = 'postgresql' ]; then
  191. echo '$'dolibarr_main_db_type=\'pgsql\'';' >> $CONF_FILE
  192. echo '$'dolibarr_main_db_port=\'5432\'';' >> $CONF_FILE
  193. fi
  194. echo '$'dolibarr_main_authentication=\'dolibarr\'';' >> $CONF_FILE
  195. cat $CONF_FILE
  196. echo
  197. - |
  198. echo "Create documents directory and set permissions"
  199. # and admin/temp subdirectory needed for unit tests
  200. mkdir -p $TRAVIS_BUILD_DIR/documents/admin/temp
  201. sudo chmod -R a+rwx $TRAVIS_BUILD_DIR/documents
  202. echo "***** First line of dolibarr.log" > $TRAVIS_BUILD_DIR/documents/dolibarr.log
  203. echo
  204. - echo "Setting up Apache + FPM"
  205. # enable php-fpm
  206. - sudo cp ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf.default ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf
  207. - |
  208. if [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = '7.1' ] || [ "$TRAVIS_PHP_VERSION" = '7.2' ] || [ "$TRAVIS_PHP_VERSION" = '7.3' ] || [ "$TRAVIS_PHP_VERSION" = '7.4' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
  209. # Copy the included pool
  210. 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
  211. fi
  212. - sudo a2enmod rewrite actions fastcgi alias
  213. - echo "cgi.fix_pathinfo = 1" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
  214. - sudo sed -i -e "s,www-data,travis,g" /etc/apache2/envvars
  215. - sudo chown -R travis:travis /var/lib/apache2/fastcgi
  216. - ~/.phpenv/versions/$(phpenv version-name)/sbin/php-fpm
  217. # configure apache virtual hosts
  218. - sudo cp -f build/travis-ci/apache.conf /etc/apache2/sites-available/000-default.conf
  219. - sudo sed -e "s?%TRAVIS_BUILD_DIR%?$(pwd)?g" --in-place /etc/apache2/sites-available/000-default.conf
  220. - sudo cat /etc/apache2/sites-available/000-default.conf
  221. - sudo service apache2 restart
  222. script:
  223. - |
  224. echo "Checking webserver availability by a wget -O - http://127.0.0.1"
  225. # Ensure we stop on error with set -e
  226. set +e
  227. # The wget should return a page with line '<meta name="generator" content="Dolibarr installer">
  228. wget -O - http://127.0.0.1 > test.html
  229. head test.html
  230. sudo cat /var/log/apache2/travis_error_log
  231. set +e
  232. echo
  233. - |
  234. echo "Checking PHP syntax errors"
  235. # Ensure we catch errors
  236. set -e
  237. #parallel-lint --exclude htdocs/includes --blame .
  238. parallel-lint --exclude dev/namespacemig --exclude htdocs/includes/composer --exclude htdocs/includes/myclabs --exclude htdocs/includes/webmozart --exclude htdocs/includes/phpspec --exclude dev/initdata/dbf/includes --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 --exclude htdocs/includes/jakub-onderka --exclude htdocs/includes/mike42/escpos-php/example --exclude htdocs/includes/phpunit/ --exclude htdocs/includes/composer/autoload_static.php --blame .
  239. set +e
  240. echo
  241. - |
  242. echo "Checking coding style (excluding Pull Requests builds to not overload travis, excluding also some jobs to avoid duplicate tests)"
  243. # Ensure we catch errors
  244. set -e
  245. # Exclusions are defined in the ruleset.xml file
  246. if [ "$TRAVIS_PULL_REQUEST" = "false" ] && [ "$TRAVIS_PHP_VERSION" = "7.4" ] && [ "$DB" = "mysql" ]; then
  247. 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 .;
  248. fi
  249. set +e
  250. echo
  251. - |
  252. export INSTALL_FORCED_FILE=htdocs/install/install.forced.php
  253. echo "Setting up Dolibarr $INSTALL_FORCED_FILE to test installation"
  254. # Ensure we catch errors
  255. set +e
  256. echo '<?php ' > $INSTALL_FORCED_FILE
  257. echo '$'force_install_noedit=2';' >> $INSTALL_FORCED_FILE
  258. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
  259. echo '$'force_install_type=\'mysqli\'';' >> $INSTALL_FORCED_FILE
  260. fi
  261. if [ "$DB" = 'postgresql' ]; then
  262. echo '$'force_install_type=\'pgsql\'';' >> $INSTALL_FORCED_FILE
  263. fi
  264. echo '$'force_install_dbserver=\'127.0.0.1\'';' >> $INSTALL_FORCED_FILE
  265. echo '$'force_install_database=\'travis\'';' >> $INSTALL_FORCED_FILE
  266. echo '$'force_install_databaselogin=\'travis\'';' >> $INSTALL_FORCED_FILE
  267. echo '$'force_install_databasepass=\'\'';' >> $INSTALL_FORCED_FILE
  268. echo '$'force_install_port=\'5432\'';' >> $INSTALL_FORCED_FILE
  269. echo '$'force_install_prefix=\'llx_\'';' >> $INSTALL_FORCED_FILE
  270. echo '$'force_install_createdatabase=false';' >> $INSTALL_FORCED_FILE
  271. echo '$'force_install_createuser=false';' >> $INSTALL_FORCED_FILE
  272. echo '$'force_install_mainforcehttps=false';' >> $INSTALL_FORCED_FILE
  273. echo '$'force_install_main_data_root=\'$TRAVIS_BUILD_DIR/htdocs\'';' >> $INSTALL_FORCED_FILE
  274. #cat $INSTALL_FORCED_FILE
  275. #- |
  276. # echo "Installing Dolibarr"
  277. # cd htdocs/install
  278. # php step1.php $TRAVIS_BUILD_DIR/htdocs > $TRAVIS_BUILD_DIR/install.log
  279. # php step2.php set >> $TRAVIS_BUILD_DIR/install.log
  280. # if [ "$?" -ne "0" ]; then
  281. # echo "SORRY, AN ERROR OCCURED DURING INSTALLATION PROCESS"
  282. # cat $TRAVIS_BUILD_DIR/install.log
  283. # exit 1
  284. # fi
  285. # cd ../..
  286. # rm $INSTALL_FORCED_FILE
  287. # #cat $TRAVIS_BUILD_DIR/install.log
  288. # set +e
  289. # echo
  290. - |
  291. echo "Setting up database to test migrations"
  292. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ] || [ "$DB" = 'postgresql' ]; then
  293. echo "MySQL"
  294. mysql -e 'DROP DATABASE IF EXISTS travis;'
  295. mysql -e 'CREATE DATABASE IF NOT EXISTS travis;'
  296. mysql -e 'GRANT ALL PRIVILEGES ON travis.* TO travis@127.0.0.1;'
  297. mysql -e 'FLUSH PRIVILEGES;'
  298. mysql -D travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  299. fi
  300. if [ "$DB" = 'postgresql' ]; then
  301. #pgsql travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  302. #pgloader mysql://root:pass@127.0.0.1/base postgresql://dolibarrowner@127.0.0.1/dolibarr
  303. echo pgloader mysql://root@127.0.0.1/travis postgresql:///travis
  304. pgloader mysql://root@127.0.0.1/travis postgresql:///travis
  305. echo 'ALTER SEQUENCE llx_accountingaccount_rowid_seq RENAME TO llx_accounting_account_rowid_seq' | psql travis
  306. echo 'ALTER SEQUENCE llx_accounting_account_rowid_seq RESTART WITH 1000001;' | psql travis
  307. #echo 'select * from INFORMATION_SCHEMA.COLUMNS where table_name = 'llx_accountingaccount' | psql travis
  308. #echo 'select * from information_schema.table_constraints;' | psql travis
  309. #echo 'ALTER TABLE "llx_accounting_account" DROP CONSTRAINT "idx_16390_primary"' | psql travis
  310. fi
  311. echo
  312. - |
  313. echo "Upgrading Dolibarr"
  314. # Ensure we catch errors. Set this to +e if you want to go to the end to see log files.
  315. set +e
  316. cd htdocs/install
  317. php upgrade.php 3.5.0 3.6.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade350360.log
  318. php upgrade2.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-2.log
  319. php step5.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-3.log
  320. php upgrade.php 3.6.0 3.7.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade360370.log
  321. php upgrade2.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-2.log
  322. php step5.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-3.log
  323. php upgrade.php 3.7.0 3.8.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade370380.log
  324. php upgrade2.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-2.log
  325. php step5.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-3.log
  326. php upgrade.php 3.8.0 3.9.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade380390.log
  327. php upgrade2.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-2.log
  328. php step5.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-3.log
  329. php upgrade.php 3.9.0 4.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade390400.log
  330. php upgrade2.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-2.log
  331. php step5.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-3.log
  332. php upgrade.php 4.0.0 5.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade400500.log
  333. php upgrade2.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-2.log
  334. php step5.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-3.log
  335. php upgrade.php 5.0.0 6.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade500600.log
  336. php upgrade2.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-2.log
  337. php step5.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-3.log
  338. php upgrade.php 6.0.0 7.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade600700.log
  339. php upgrade2.php 6.0.0 7.0.0 > $TRAVIS_BUILD_DIR/upgrade600700-2.log
  340. php step5.php 6.0.0 7.0.0 > $TRAVIS_BUILD_DIR/upgrade600700-3.log
  341. php upgrade.php 7.0.0 8.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade700800.log
  342. php upgrade2.php 7.0.0 8.0.0 > $TRAVIS_BUILD_DIR/upgrade700800-2.log
  343. php step5.php 7.0.0 8.0.0 > $TRAVIS_BUILD_DIR/upgrade700800-3.log
  344. php upgrade.php 8.0.0 9.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade800900.log
  345. php upgrade2.php 8.0.0 9.0.0 > $TRAVIS_BUILD_DIR/upgrade800900-2.log
  346. php step5.php 8.0.0 9.0.0 > $TRAVIS_BUILD_DIR/upgrade800900-3.log
  347. php upgrade.php 9.0.0 10.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade9001000.log
  348. php upgrade2.php 9.0.0 10.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-2.log
  349. php step5.php 9.0.0 10.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-3.log
  350. php upgrade.php 10.0.0 11.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade10001100.log
  351. php upgrade2.php 10.0.0 11.0.0 > $TRAVIS_BUILD_DIR/upgrade10001100-2.log
  352. php step5.php 10.0.0 11.0.0 > $TRAVIS_BUILD_DIR/upgrade10001100-3.log
  353. php upgrade.php 11.0.0 12.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade11001200.log
  354. php upgrade2.php 11.0.0 12.0.0 > $TRAVIS_BUILD_DIR/upgrade11001200-2.log
  355. php step5.php 11.0.0 12.0.0 > $TRAVIS_BUILD_DIR/upgrade11001200-3.log
  356. # Enable modules not enabled into original dump
  357. 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
  358. echo $?
  359. cd -
  360. set +e
  361. echo
  362. #cat /tmp/dolibarr_install.log
  363. cat $TRAVIS_BUILD_DIR/enablemodule.log
  364. - |
  365. echo "Unit testing"
  366. # Ensure we catch errors. Set this to +e if you want to go to the end to see dolibarr.log file.
  367. set -e
  368. phpunit -d memory_limit=-1 -c test/phpunit/phpunittest.xml test/phpunit/AllTests.php
  369. phpunitresult=$?
  370. echo "Phpunit return code = $phpunitresult"
  371. set +e
  372. after_script:
  373. - |
  374. echo "After script - Output last lines of dolibarr.log"
  375. ls $TRAVIS_BUILD_DIR/documents
  376. #cat $TRAVIS_BUILD_DIR/documents/dolibarr.log
  377. sudo tail -n 50 $TRAVIS_BUILD_DIR/documents/dolibarr.log
  378. after_success:
  379. - |
  380. echo Success
  381. after_failure:
  382. - |
  383. echo Failure detected, so we show samples of log to help diagnose
  384. # This part of code is executed only if previous command that fails are enclosed with set +e
  385. # Upgrade log files
  386. for ficlog in `ls $TRAVIS_BUILD_DIR/*.log`
  387. do
  388. echo "Debugging informations for file $ficlog"
  389. #cat $ficlog
  390. done
  391. # Apache log file
  392. echo "Debugging informations for file apache error.log"
  393. sudo cat /var/log/apache2/travis_error_log
  394. if [ "$DEBUG" = true ]; then
  395. # Dolibarr log file
  396. echo "Debugging informations for file dolibarr.log (latest 50 lines)"
  397. tail -n 50 $TRAVIS_BUILD_DIR/documents/dolibarr.log
  398. # Database log file
  399. echo "Debugging informations for file mysql error.log"
  400. sudo tail -n 50 /var/log/mysql/error.log
  401. # TODO: PostgreSQL log file
  402. echo
  403. fi