.travis.yml 24 KB

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