.travis.yml 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533
  1. # This script is used by Travis CI to run automatically Continuous test integration
  2. # from Dolibarr GitHub repository.
  3. # For syntax, see https://docs.travis-ci.com/user/languages/php/
  4. # We use dist: bionic = 18.04, focal = 20.04
  5. os: linux
  6. dist: focal
  7. language: php
  8. git:
  9. depth: 1
  10. # Start on every boot
  11. services:
  12. - memcached
  13. - mysql
  14. - postgresql
  15. before_install:
  16. - |
  17. echo "Add ondrej PPA"
  18. sudo add-apt-repository -y ppa:ondrej/php
  19. sudo apt-get update
  20. echo "Disabling Xdebug for composer"
  21. export PHP_VERSION_NAME=$(phpenv version-name)
  22. echo $PHP_VERSION_NAME
  23. ls ~/.phpenv/versions/$PHP_VERSION_NAME/etc/conf.d/
  24. cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/conf.d/xdebug.ini /tmp/xdebug.ini
  25. phpenv config-rm xdebug.ini || echo "xdebug not available"
  26. phpenv rehash
  27. echo
  28. addons:
  29. # Force postgresql version
  30. postgresql: '10'
  31. apt:
  32. sources:
  33. - sourceline: 'ppa:ondrej/php'
  34. update: true
  35. packages:
  36. # We need a webserver to test the webservices
  37. # Let's install Apache with.
  38. - apache2
  39. # We need pgloader for import mysql database into pgsql
  40. - pgloader
  41. - php
  42. - php7.1
  43. - php7.1-pgsql
  44. - php7.1-mysqli
  45. - php7.1-xml
  46. - php7.1-intl
  47. - php8.1
  48. - php8.1-pgsql
  49. - php8.1-mysqli
  50. - php8.1-xml
  51. - php8.1-intl
  52. - php8.2
  53. - php8.2-pgsql
  54. - php8.2-mysqli
  55. - php8.2-xml
  56. - php8.2-intl
  57. env:
  58. global:
  59. # Set to true for very verbose output
  60. - DEBUG=false
  61. jobs:
  62. fast_finish: true
  63. #allow_failures:
  64. #- php: nightly
  65. include:
  66. - stage: PHP 7.0-8.1
  67. if: type = push
  68. php: '7.1'
  69. env: DB=postgresql
  70. - stage: PHP 7.0-8.1
  71. if: type = pull_request OR type = push
  72. php: '8.1'
  73. env: DB=mysql
  74. - stage: PHP Dev
  75. if: type = push AND branch = developdisabled
  76. php: '8.2'
  77. env: DB=mysql
  78. notifications:
  79. email:
  80. on_success: never # [always|never|change] default: change
  81. on_failure: never # [always|never|change] default: always
  82. irc:
  83. channels:
  84. - "chat.freenode.net#dolibarr"
  85. on_success: change
  86. on_failure: always
  87. use_notice: true
  88. install:
  89. - |
  90. echo "Updating Composer config"
  91. composer -V
  92. #rm $TRAVIS_BUILD_DIR/composer.json
  93. #rm $TRAVIS_BUILD_DIR/composer.lock
  94. #composer -n init
  95. #composer -n config vendor-dir htdocs/includes
  96. composer -n config -g vendor-dir htdocs/includes
  97. echo
  98. - |
  99. echo "Update Composer version and Install tools - PHP Unit, Parallel Lint, PHP CodeSniffer, PHP Vardump check - for $TRAVIS_PHP_VERSION"
  100. echo "(version 2.5 is bugged and generate phpunit error Exception: Serialization of 'Closure' is not allowed)"
  101. if [ "$TRAVIS_PHP_VERSION" = '7.1' ] || [ "$TRAVIS_PHP_VERSION" = '7.2' ]; then
  102. composer self-update 2.2.18
  103. composer -n require phpunit/phpunit ^7.5 \
  104. php-parallel-lint/php-parallel-lint ^1 \
  105. php-parallel-lint/php-console-highlighter ^0 \
  106. php-parallel-lint/php-var-dump-check ~0.4 \
  107. squizlabs/php_codesniffer ^3
  108. fi
  109. if [ "$TRAVIS_PHP_VERSION" = '7.3' ] || [ "$TRAVIS_PHP_VERSION" = '7.4' ]; then
  110. composer self-update 2.2.18
  111. composer -n require phpunit/phpunit ^7.5 \
  112. php-parallel-lint/php-parallel-lint ^1.2 \
  113. php-parallel-lint/php-console-highlighter ^0 \
  114. php-parallel-lint/php-var-dump-check ~0.4 \
  115. squizlabs/php_codesniffer ^3
  116. fi
  117. # phpunit 9 is required for php 8
  118. if [ "$TRAVIS_PHP_VERSION" = '8.0' ] || [ "$TRAVIS_PHP_VERSION" = '8.1' ] || [ "$TRAVIS_PHP_VERSION" = '8.2' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
  119. composer self-update 2.4.4
  120. composer -n require --ignore-platform-reqs phpunit/phpunit ^8 \
  121. php-parallel-lint/php-parallel-lint ^1.2 \
  122. php-parallel-lint/php-console-highlighter ^0 \
  123. php-parallel-lint/php-var-dump-check ~0.4 \
  124. squizlabs/php_codesniffer ^3
  125. fi
  126. # Remove non expected files
  127. rm -fr /home/travis/build/Dolibarr/dolibarr/htdocs/includes/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/js
  128. echo
  129. - |
  130. echo "Adding path of binaries tools installed by composer to the PATH"
  131. export PATH="$TRAVIS_BUILD_DIR/htdocs/includes/bin:$PATH"
  132. echo $PATH
  133. ls $TRAVIS_BUILD_DIR/vendor
  134. ls $TRAVIS_BUILD_DIR/htdocs/includes/bin
  135. echo
  136. before_script:
  137. - |
  138. echo Start travis
  139. echo Current dir is `pwd`
  140. echo Home dir is `echo ~`
  141. echo TRAVIS_BUILD_DIR is $TRAVIS_BUILD_DIR
  142. - |
  143. echo "Re-enabling Xdebug for PHP CodeSniffer and PHP Unit"
  144. phpenv config-add /tmp/xdebug.ini
  145. echo
  146. - |
  147. echo "Setting up PHP"
  148. echo
  149. echo "Set timezone"
  150. echo 'date.timezone = "Europe/Paris"' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
  151. phpenv rehash
  152. echo
  153. - |
  154. echo "Versions information"
  155. echo
  156. # Check PHP
  157. echo "PHP version"
  158. php -i | head -
  159. # Check Parallel-lint version
  160. echo "Parallel-lint version"
  161. which parallel-lint
  162. parallel-lint -V
  163. # Check PHP CodeSniffer version
  164. echo "PHPCS version"
  165. which phpcs
  166. phpcs --version | head -
  167. phpcs -i | head -
  168. # Check PHP Vardump check version
  169. echo "PHP Vardump check version"
  170. which var_dump_check
  171. var_dump_check --version
  172. # Check PHPUnit version
  173. echo "PHPUnit version"
  174. which phpunit
  175. phpunit --version | head -
  176. # Check Apache version
  177. echo "Apache version"
  178. apache2 -v | head -
  179. # Check Database
  180. echo "Database version"
  181. mysql --version | head -
  182. mysql -e "SELECT VERSION();" | head -
  183. psql --version
  184. if [ "$DB" = 'postgresql' ]; then
  185. echo "Check pgloader version"
  186. pgloader --version
  187. fi
  188. echo
  189. - |
  190. echo "Setting up database"
  191. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ] || [ "$DB" = 'postgresql' ]; then
  192. echo "MySQL"
  193. mysql -u root -e 'DROP DATABASE IF EXISTS travis;'
  194. mysql -u root -e 'CREATE DATABASE IF NOT EXISTS travis;'
  195. mysql -u root -e 'GRANT ALL PRIVILEGES ON travis.* TO travis@127.0.0.1;'
  196. mysql -u root -e 'FLUSH PRIVILEGES;'
  197. mysql -u root -D travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  198. fi
  199. if [ "$DB" = 'postgresql' ]; then
  200. #psql -c 'create database travis;' -U postgres
  201. #psql travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  202. #pgloader mysql://root:pass@127.0.0.1/dolibarr_src postgresql://dolibarrowner:dolibarrownerpass@127.0.0.1/dolibarr_dest
  203. echo pgloader mysql://root@127.0.0.1/travis postgresql://postgres@/travis
  204. pgloader mysql://root@127.0.0.1/travis postgresql://postgres@/travis
  205. echo 'ALTER SEQUENCE llx_accountingaccount_rowid_seq RENAME TO llx_accounting_account_rowid_seq' | psql -U postgres travis
  206. echo 'ALTER SEQUENCE llx_accounting_account_rowid_seq RESTART WITH 1000001;' | psql -U postgres travis
  207. # Create pgsql compatibility functions
  208. psql -U postgres travis < htdocs/install/pgsql/functions/functions.sql
  209. fi
  210. echo
  211. - |
  212. export CONF_FILE=htdocs/conf/conf.php
  213. echo "Setting up Dolibarr $CONF_FILE"
  214. echo '<?php' > $CONF_FILE
  215. echo '$'dolibarr_main_url_root=\'http://127.0.0.1\'';' >> $CONF_FILE
  216. echo '$'dolibarr_main_document_root=\'$TRAVIS_BUILD_DIR/htdocs\'';' >> $CONF_FILE
  217. echo '$'dolibarr_main_data_root=\'$TRAVIS_BUILD_DIR/documents\'';' >> $CONF_FILE
  218. echo '$'dolibarr_main_db_host=\'127.0.0.1\'';' >> $CONF_FILE
  219. echo '$'dolibarr_main_db_name=\'travis\'';' >> $CONF_FILE
  220. echo '$'dolibarr_main_db_user=\'travis\'';' >> $CONF_FILE
  221. echo '$'dolibarr_main_instance_unique_id=\'travis1234567890\'';' >> $CONF_FILE
  222. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
  223. echo '$'dolibarr_main_db_type=\'mysqli\'';' >> $CONF_FILE
  224. echo '$'dolibarr_main_db_port=\'3306\'';' >> $CONF_FILE
  225. fi
  226. if [ "$DB" = 'postgresql' ]; then
  227. echo '$'dolibarr_main_db_type=\'pgsql\'';' >> $CONF_FILE
  228. echo '$'dolibarr_main_db_port=\'5432\'';' >> $CONF_FILE
  229. fi
  230. echo '$'dolibarr_main_authentication=\'dolibarr\'';' >> $CONF_FILE
  231. cat $CONF_FILE
  232. echo
  233. - |
  234. echo "Create documents directory and set permissions"
  235. # and admin/temp subdirectory needed for unit tests
  236. mkdir -p $TRAVIS_BUILD_DIR/documents/admin/temp
  237. sudo chmod -R a+rwx $TRAVIS_BUILD_DIR/documents
  238. echo "***** First line of dolibarr.log" > $TRAVIS_BUILD_DIR/documents/dolibarr.log
  239. echo
  240. - echo "Setting up Apache + FPM"
  241. # setup link for php legacy
  242. - sudo ln -s ~/.phpenv/versions/$(phpenv version-name)/bin/php /bin/php
  243. # install apache web server
  244. - sudo apt-get install apache2 php-fpm php-mysql php-pgsql php-gd php-ldap php-xml php-mbstring libapache2-mod-php
  245. # enable php-fpm
  246. - sudo cp ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf.default ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf
  247. - |
  248. 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" = '8.0' ] || [ "$TRAVIS_PHP_VERSION" = '8.1' ] || [ "$TRAVIS_PHP_VERSION" = '8.2' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
  249. # Copy the included pool
  250. 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
  251. fi
  252. - sudo a2enmod proxy_fcgi rewrite setenvif cgi alias
  253. - echo "cgi.fix_pathinfo = 1" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
  254. - sudo sed -i -e "s,www-data,travis,g" /etc/apache2/envvars
  255. #- sudo chown -R travis:travis /var/lib/apache2/fastcgi
  256. # start php-fpm
  257. - ~/.phpenv/versions/$(phpenv version-name)/sbin/php-fpm
  258. # configure apache virtual hosts
  259. - sudo cp -f build/travis-ci/apache.conf /etc/apache2/sites-available/000-default.conf
  260. - sudo sed -e "s?%TRAVIS_BUILD_DIR%?$(pwd)?g" --in-place /etc/apache2/sites-available/000-default.conf
  261. - sudo cat /etc/apache2/sites-available/000-default.conf
  262. - sudo service apache2 restart
  263. script:
  264. - |
  265. echo "Checking webserver availability by a wget -O - http://127.0.0.1"
  266. # Ensure we stop on error with set -e
  267. set +e
  268. # The wget should return a page with line '<meta name="generator" content="Dolibarr installer">
  269. wget -O - http://127.0.0.1 > test.html
  270. head test.html
  271. sudo cat /var/log/apache2/travis_error_log
  272. set +e
  273. echo
  274. - |
  275. echo "Checking PHP syntax errors (only 1 version to not overload travis and avoid duplicate tests)"
  276. # Ensure we catch errors
  277. set -e
  278. #parallel-lint --exclude htdocs/includes --blame .
  279. # Exclusions are defined in the ruleset.xml file
  280. if [ "$TRAVIS_PHP_VERSION" = "8.1" ]; then
  281. parallel-lint -e php --exclude dev/tools/test/namespacemig --exclude htdocs/includes/composer --exclude htdocs/includes/myclabs --exclude htdocs/includes/phpspec --exclude dev/initdata/dbf/includes \
  282. --exclude htdocs/includes/sabre --exclude htdocs/includes/phpoffice/PhpSpreadsheet --exclude htdocs/includes/sebastian \
  283. --exclude htdocs/includes/squizlabs/php_codesniffer --exclude htdocs/includes/jakub-onderka --exclude htdocs/includes/php-parallel-lint --exclude htdocs/includes/symfony \
  284. --exclude htdocs/includes/mike42/escpos-php/example --exclude htdocs/includes/maximebf \
  285. --exclude htdocs/includes/phpunit/ --exclude htdocs/includes/tecnickcom/tcpdf/include/barcodes --exclude htdocs/includes/webmozart --exclude htdocs/includes/webklex --blame .
  286. fi
  287. set +e
  288. echo
  289. - |
  290. echo "Checking coding style (only for Pull Requests builds and 1 version to not overload travis and avoid duplicate tests)"
  291. # Ensure we catch errors
  292. set -e
  293. # Exclusions are defined in the ruleset.xml file
  294. if [ "$TRAVIS_PULL_REQUEST" = "false" ] && [ "$TRAVIS_PHP_VERSION" = "8.1" ]; then
  295. 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 .;
  296. fi
  297. set +e
  298. echo
  299. - |
  300. echo "Checking missing debug"
  301. # Ensure we catch errors
  302. set -e
  303. # Exclusions are defined in the ruleset.xml file
  304. if [ "$TRAVIS_PULL_REQUEST" = "false" ] && [ "$TRAVIS_PHP_VERSION" = "8.1" ]; then
  305. var-dump-check --extensions php --tracy --exclude htdocs/includes --exclude test/ --exclude htdocs/public/test/ --exclude htdocs/core/lib/functions.lib.php .
  306. fi
  307. set +e
  308. echo
  309. - |
  310. export INSTALL_FORCED_FILE=htdocs/install/install.forced.php
  311. echo "Setting up Dolibarr $INSTALL_FORCED_FILE to test installation"
  312. # Ensure we catch errors
  313. set +e
  314. echo '<?php ' > $INSTALL_FORCED_FILE
  315. echo '$'force_install_noedit=2';' >> $INSTALL_FORCED_FILE
  316. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
  317. echo '$'force_install_type=\'mysqli\'';' >> $INSTALL_FORCED_FILE
  318. fi
  319. if [ "$DB" = 'postgresql' ]; then
  320. echo '$'force_install_type=\'pgsql\'';' >> $INSTALL_FORCED_FILE
  321. fi
  322. echo '$'force_install_dbserver=\'127.0.0.1\'';' >> $INSTALL_FORCED_FILE
  323. echo '$'force_install_database=\'travis\'';' >> $INSTALL_FORCED_FILE
  324. echo '$'force_install_databaselogin=\'travis\'';' >> $INSTALL_FORCED_FILE
  325. echo '$'force_install_databasepass=\'\'';' >> $INSTALL_FORCED_FILE
  326. echo '$'force_install_port=\'5432\'';' >> $INSTALL_FORCED_FILE
  327. echo '$'force_install_prefix=\'llx_\'';' >> $INSTALL_FORCED_FILE
  328. echo '$'force_install_createdatabase=false';' >> $INSTALL_FORCED_FILE
  329. echo '$'force_install_createuser=false';' >> $INSTALL_FORCED_FILE
  330. echo '$'force_install_mainforcehttps=false';' >> $INSTALL_FORCED_FILE
  331. echo '$'force_install_main_data_root=\'$TRAVIS_BUILD_DIR/htdocs\'';' >> $INSTALL_FORCED_FILE
  332. #cat $INSTALL_FORCED_FILE
  333. #- |
  334. # echo "Installing Dolibarr"
  335. # cd htdocs/install
  336. # php step1.php $TRAVIS_BUILD_DIR/htdocs > $TRAVIS_BUILD_DIR/install.log
  337. # php step2.php set >> $TRAVIS_BUILD_DIR/install.log
  338. # if [ "$?" -ne "0" ]; then
  339. # echo "SORRY, AN ERROR OCCURED DURING INSTALLATION PROCESS"
  340. # cat $TRAVIS_BUILD_DIR/install.log
  341. # exit 1
  342. # fi
  343. # cd ../..
  344. # rm $INSTALL_FORCED_FILE
  345. # #cat $TRAVIS_BUILD_DIR/install.log
  346. # set +e
  347. # echo
  348. - |
  349. echo "Setting up database to test migrations"
  350. if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ] || [ "$DB" = 'postgresql' ]; then
  351. echo "MySQL"
  352. mysql -e 'DROP DATABASE IF EXISTS travis;'
  353. mysql -e 'CREATE DATABASE IF NOT EXISTS travis;'
  354. mysql -e 'GRANT ALL PRIVILEGES ON travis.* TO travis@127.0.0.1;'
  355. mysql -e 'FLUSH PRIVILEGES;'
  356. mysql -D travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  357. fi
  358. if [ "$DB" = 'postgresql' ]; then
  359. #pgsql travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
  360. #pgloader mysql://root:pass@127.0.0.1/base postgresql://dolibarrowner@127.0.0.1/dolibarr
  361. echo pgloader mysql://root@127.0.0.1/travis postgresql:///travis
  362. pgloader mysql://root@127.0.0.1/travis postgresql:///travis
  363. echo 'ALTER SEQUENCE llx_accountingaccount_rowid_seq RENAME TO llx_accounting_account_rowid_seq' | psql travis
  364. echo 'ALTER SEQUENCE llx_accounting_account_rowid_seq RESTART WITH 1000001;' | psql travis
  365. #echo 'select * from INFORMATION_SCHEMA.COLUMNS where table_name = 'llx_accountingaccount' | psql travis
  366. #echo 'select * from information_schema.table_constraints;' | psql travis
  367. #echo 'ALTER TABLE "llx_accounting_account" DROP CONSTRAINT "idx_16390_primary"' | psql travis
  368. fi
  369. echo
  370. - |
  371. echo "Upgrading Dolibarr"
  372. # Ensure we catch errors. Set this to +e if you want to go to the end to see log files.
  373. set +e
  374. cd htdocs/install
  375. php upgrade.php 3.5.0 3.6.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade350360.log
  376. php upgrade2.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-2.log
  377. php step5.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-3.log
  378. php upgrade.php 3.6.0 3.7.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade360370.log
  379. php upgrade2.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-2.log
  380. php step5.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-3.log
  381. php upgrade.php 3.7.0 3.8.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade370380.log
  382. php upgrade2.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-2.log
  383. php step5.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-3.log
  384. php upgrade.php 3.8.0 3.9.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade380390.log
  385. php upgrade2.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-2.log
  386. php step5.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-3.log
  387. php upgrade.php 3.9.0 4.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade390400.log
  388. php upgrade2.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-2.log
  389. php step5.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-3.log
  390. php upgrade.php 4.0.0 5.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade400500.log
  391. php upgrade2.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-2.log
  392. php step5.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-3.log
  393. php upgrade.php 5.0.0 6.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade500600.log
  394. php upgrade2.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-2.log
  395. php step5.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-3.log
  396. php upgrade.php 6.0.0 7.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade600700.log
  397. php upgrade2.php 6.0.0 7.0.0 > $TRAVIS_BUILD_DIR/upgrade600700-2.log
  398. php step5.php 6.0.0 7.0.0 > $TRAVIS_BUILD_DIR/upgrade600700-3.log
  399. php upgrade.php 7.0.0 8.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade700800.log
  400. php upgrade2.php 7.0.0 8.0.0 > $TRAVIS_BUILD_DIR/upgrade700800-2.log
  401. php step5.php 7.0.0 8.0.0 > $TRAVIS_BUILD_DIR/upgrade700800-3.log
  402. php upgrade.php 8.0.0 9.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade800900.log
  403. php upgrade2.php 8.0.0 9.0.0 > $TRAVIS_BUILD_DIR/upgrade800900-2.log
  404. php step5.php 8.0.0 9.0.0 > $TRAVIS_BUILD_DIR/upgrade800900-3.log
  405. php upgrade.php 9.0.0 10.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade9001000.log
  406. php upgrade2.php 9.0.0 10.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-2.log
  407. php step5.php 9.0.0 10.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-3.log
  408. php upgrade.php 10.0.0 11.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade10001100.log
  409. php upgrade2.php 10.0.0 11.0.0 > $TRAVIS_BUILD_DIR/upgrade10001100-2.log
  410. php step5.php 10.0.0 11.0.0 > $TRAVIS_BUILD_DIR/upgrade10001100-3.log
  411. php upgrade.php 11.0.0 12.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade11001200.log
  412. php upgrade2.php 11.0.0 12.0.0 > $TRAVIS_BUILD_DIR/upgrade11001200-2.log
  413. php step5.php 11.0.0 12.0.0 > $TRAVIS_BUILD_DIR/upgrade11001200-3.log
  414. php upgrade.php 12.0.0 13.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade12001300.log
  415. php upgrade2.php 12.0.0 13.0.0 > $TRAVIS_BUILD_DIR/upgrade12001300-2.log
  416. php step5.php 12.0.0 13.0.0 > $TRAVIS_BUILD_DIR/upgrade12001300-3.log
  417. php upgrade.php 13.0.0 14.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade13001400.log
  418. php upgrade2.php 13.0.0 14.0.0 > $TRAVIS_BUILD_DIR/upgrade13001400-2.log
  419. php step5.php 13.0.0 14.0.0 > $TRAVIS_BUILD_DIR/upgrade13001400-3.log
  420. php upgrade.php 14.0.0 15.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade14001500.log
  421. php upgrade2.php 14.0.0 15.0.0 > $TRAVIS_BUILD_DIR/upgrade14001500-2.log
  422. php step5.php 14.0.0 15.0.0 > $TRAVIS_BUILD_DIR/upgrade14001500-3.log
  423. php upgrade.php 15.0.0 16.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade15001600.log
  424. php upgrade2.php 15.0.0 16.0.0 > $TRAVIS_BUILD_DIR/upgrade15001600-2.log
  425. php step5.php 15.0.0 16.0.0 > $TRAVIS_BUILD_DIR/upgrade15001600-3.log
  426. php upgrade.php 16.0.0 17.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade16001700.log
  427. php upgrade2.php 16.0.0 17.0.0 > $TRAVIS_BUILD_DIR/upgrade16001700-2.log
  428. php step5.php 16.0.0 17.0.0 > $TRAVIS_BUILD_DIR/upgrade16001700-3.log
  429. php upgrade.php 17.0.0 18.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade17001800.log
  430. php upgrade2.php 17.0.0 18.0.0 > $TRAVIS_BUILD_DIR/upgrade17001800-2.log
  431. php step5.php 17.0.0 18.0.0 > $TRAVIS_BUILD_DIR/upgrade17001800-3.log
  432. ls -alrt $TRAVIS_BUILD_DIR/
  433. echo
  434. #cat $TRAVIS_BUILD_DIR/upgrade17001800.log
  435. #cat $TRAVIS_BUILD_DIR/upgrade17001800-2.log
  436. - |
  437. echo "Enabling new modules"
  438. # Enable modules not enabled into original dump
  439. set -e
  440. php upgrade2.php 0.0.0 0.0.0 MAIN_MODULE_API,MAIN_MODULE_PRODUCTBATCH,MAIN_MODULE_SUPPLIERPROPOSAL,MAIN_MODULE_STRIPE,MAIN_MODULE_EXPENSEREPORT > $TRAVIS_BUILD_DIR/enablemodule.log
  441. php upgrade2.php 0.0.0 0.0.0 MAIN_MODULE_WEBSITE,MAIN_MODULE_TICKET,MAIN_MODULE_ACCOUNTING,MAIN_MODULE_MRP >> $TRAVIS_BUILD_DIR/enablemodule.log
  442. php upgrade2.php 0.0.0 0.0.0 MAIN_MODULE_RECEPTION,MAIN_MODULE_RECRUITMENT >> $TRAVIS_BUILD_DIR/enablemodule.log
  443. php upgrade2.php 0.0.0 0.0.0 MAIN_MODULE_KNOWLEDGEMANAGEMENT,MAIN_MODULE_EVENTORGANIZATION,MAIN_MODULE_PARTNERSHIP >> $TRAVIS_BUILD_DIR/enablemodule.log
  444. php upgrade2.php 0.0.0 0.0.0 MAIN_MODULE_EMAILCOLLECTOR >> $TRAVIS_BUILD_DIR/enablemodule.log
  445. echo $?
  446. cd -
  447. set +e
  448. echo
  449. #cat /tmp/dolibarr_install.log
  450. cat $TRAVIS_BUILD_DIR/enablemodule.log
  451. - |
  452. echo "Unit testing"
  453. # Ensure we catch errors. Set this to +e instead of -e if you want to go to the end to see dolibarr.log file.
  454. set -e
  455. phpunit -d memory_limit=-1 -c test/phpunit/phpunittest.xml test/phpunit/AllTests.php
  456. phpunitresult=$?
  457. echo "Phpunit return code = $phpunitresult"
  458. set +e
  459. after_script:
  460. - |
  461. echo "After script - Output last lines of dolibarr.log"
  462. ls $TRAVIS_BUILD_DIR/documents
  463. #cat $TRAVIS_BUILD_DIR/documents/dolibarr.log
  464. sudo tail -n 50 $TRAVIS_BUILD_DIR/documents/dolibarr.log
  465. echo "After script - Output last lines of apache error.log"
  466. sudo ls /var/log/apache2
  467. sudo tail -n 50 /var/log/apache2/travis_error_log
  468. after_success:
  469. - |
  470. echo Success
  471. after_failure:
  472. - |
  473. echo Failure detected, so we show samples of log to help diagnose
  474. # This part of code is executed only if the command that fails are enclosed with set +e
  475. # Show upgrade log files
  476. for ficlog in `ls $TRAVIS_BUILD_DIR/*.log`
  477. do
  478. #echo "Debugging informations for file $ficlog"
  479. #cat $ficlog
  480. done
  481. # Show Apache log file
  482. echo "Debugging informations for file apache error.log"
  483. sudo tail -n 50 /var/log/apache2/travis_error_log
  484. if [ "$DEBUG" = true ]; then
  485. # Dolibarr log file
  486. echo "Debugging informations for file dolibarr.log (latest 50 lines)"
  487. tail -n 50 $TRAVIS_BUILD_DIR/documents/dolibarr.log
  488. # Database log file
  489. echo "Debugging informations for file mysql error.log"
  490. sudo tail -n 50 /var/log/mysql/error.log
  491. # TODO: PostgreSQL log file
  492. echo
  493. fi