2013-09-09 00:25:06 +02:00
|
|
|
# This script is used by Travis CI to run automatically Continuous test integration
|
|
|
|
|
# from Dolibarr GitHub repository.
|
|
|
|
|
# For syntax, see http://about.travis-ci.org/docs/user/languages/php/
|
2013-09-08 23:38:55 +02:00
|
|
|
|
2020-01-30 12:24:04 +01:00
|
|
|
# We use dist: xenial to have php 5.6+ available
|
2020-02-27 18:07:32 +01:00
|
|
|
os: linux
|
2020-01-30 02:09:01 +01:00
|
|
|
dist: xenial
|
2020-08-04 15:18:24 +02:00
|
|
|
#dist: bionic
|
2020-10-07 20:16:16 +02:00
|
|
|
# Deprecated: The key sudo has no effect anymore.
|
|
|
|
|
#sudo: required
|
2015-12-11 05:08:32 +01:00
|
|
|
|
|
|
|
|
language: php
|
|
|
|
|
|
2017-09-14 09:33:10 +02:00
|
|
|
# Start on every boot
|
|
|
|
|
services:
|
|
|
|
|
- memcached
|
2020-01-30 02:23:13 +01:00
|
|
|
- mysql
|
|
|
|
|
- postgresql
|
2015-12-11 05:08:32 +01:00
|
|
|
|
2015-01-25 11:39:48 +01:00
|
|
|
addons:
|
2020-01-30 04:33:10 +01:00
|
|
|
# Force postgresql to 9.4 (the oldest availablable on xenial)
|
|
|
|
|
postgresql: '9.4'
|
2015-12-11 05:08:32 +01:00
|
|
|
apt:
|
2017-06-19 15:30:55 +02:00
|
|
|
sources:
|
2020-01-30 03:10:10 +01:00
|
|
|
# To use the last version of pgloader, we add repo of postgresql with a name available in http://apt.postgresql.org/pub/repos/apt/
|
|
|
|
|
- pgdg-xenial
|
2015-12-11 05:08:32 +01:00
|
|
|
packages:
|
|
|
|
|
# We need a webserver to test the webservices
|
|
|
|
|
# Let's install Apache with.
|
|
|
|
|
- apache2
|
|
|
|
|
# mod_php is not supported by Travis. Add fcgi. We install FPM later on.
|
|
|
|
|
- libapache2-mod-fastcgi
|
2017-06-19 15:30:55 +02:00
|
|
|
# We need pgloader for import mysql database into pgsql
|
|
|
|
|
- pgloader
|
2017-09-14 09:33:10 +02:00
|
|
|
|
|
|
|
|
php:
|
|
|
|
|
- '5.6'
|
|
|
|
|
- '7.0'
|
|
|
|
|
- '7.1'
|
2017-11-17 17:13:30 +01:00
|
|
|
- '7.2'
|
2019-01-19 15:33:10 +01:00
|
|
|
- '7.3'
|
2019-12-23 16:03:20 +01:00
|
|
|
- '7.4'
|
2017-09-14 09:33:10 +02:00
|
|
|
- nightly
|
2013-09-08 23:38:55 +02:00
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
env:
|
|
|
|
|
global:
|
|
|
|
|
# Set to true for very verbose output
|
|
|
|
|
- DEBUG=false
|
2020-02-27 18:07:32 +01:00
|
|
|
jobs:
|
2015-12-11 05:08:32 +01:00
|
|
|
# MariaDB overrides MySQL installation so it's not possible to test both yet
|
2020-01-30 03:53:05 +01:00
|
|
|
#- DB=mariadb
|
|
|
|
|
- DB=mysql
|
2017-06-19 15:30:55 +02:00
|
|
|
- DB=postgresql
|
2015-12-11 05:08:32 +01:00
|
|
|
# See https://docs.travis-ci.com/user/languages/php/#Apache-%2B-PHP
|
|
|
|
|
#- WS=apache
|
|
|
|
|
# See https://github.com/DracoBlue/travis-ci-nginx-php-fpm-test
|
|
|
|
|
#- WS=nginx
|
2015-09-07 14:01:05 +02:00
|
|
|
|
2020-02-27 18:07:32 +01:00
|
|
|
jobs:
|
2015-12-11 05:08:32 +01:00
|
|
|
fast_finish: true
|
2015-03-10 09:57:40 +01:00
|
|
|
allow_failures:
|
2015-12-11 05:08:32 +01:00
|
|
|
- php: nightly
|
2017-09-14 09:24:17 +02:00
|
|
|
# We exclude some combinations not usefull to save Travis CPU
|
|
|
|
|
exclude:
|
2018-09-01 15:34:25 +02:00
|
|
|
- php: '7.0'
|
2020-01-30 03:54:02 +01:00
|
|
|
env: DB=mysql
|
2018-09-01 15:34:25 +02:00
|
|
|
- php: '7.1'
|
2020-01-30 03:54:02 +01:00
|
|
|
env: DB=mysql
|
2019-02-13 22:46:24 +01:00
|
|
|
- php: '7.2'
|
2020-01-30 03:54:02 +01:00
|
|
|
env: DB=mysql
|
2019-12-23 16:41:22 +01:00
|
|
|
- php: '7.3'
|
2020-01-30 03:54:02 +01:00
|
|
|
env: DB=mysql
|
2017-09-14 09:37:57 +02:00
|
|
|
- php: '7.0'
|
|
|
|
|
env: DB=postgresql
|
2017-11-17 18:32:37 +01:00
|
|
|
- php: '7.1'
|
2017-11-17 17:13:30 +01:00
|
|
|
env: DB=postgresql
|
2019-02-13 22:46:24 +01:00
|
|
|
- php: '7.2'
|
2019-01-19 15:33:10 +01:00
|
|
|
env: DB=postgresql
|
2019-12-23 16:41:22 +01:00
|
|
|
- php: '7.3'
|
|
|
|
|
env: DB=postgresql
|
2017-09-14 09:33:10 +02:00
|
|
|
- php: nightly
|
|
|
|
|
env: DB=postgresql
|
2013-09-08 23:38:55 +02:00
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
notifications:
|
|
|
|
|
email:
|
|
|
|
|
on_success: never # [always|never|change] default: change
|
2017-10-26 18:50:27 +02:00
|
|
|
on_failure: never # [always|never|change] default: always
|
2015-12-11 05:08:32 +01:00
|
|
|
irc:
|
|
|
|
|
channels:
|
|
|
|
|
- "chat.freenode.net#dolibarr"
|
|
|
|
|
on_success: change
|
|
|
|
|
on_failure: always
|
|
|
|
|
use_notice: true
|
2013-09-08 23:38:55 +02:00
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
before_install:
|
|
|
|
|
- |
|
|
|
|
|
echo "Disabling Xdebug for composer"
|
|
|
|
|
export PHP_VERSION_NAME=$(phpenv version-name)
|
|
|
|
|
cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/conf.d/xdebug.ini /tmp/xdebug.ini
|
|
|
|
|
phpenv config-rm xdebug.ini
|
|
|
|
|
echo
|
|
|
|
|
|
2017-06-19 15:30:55 +02:00
|
|
|
- |
|
|
|
|
|
if [ "$DB" = 'postgresql' ]; then
|
|
|
|
|
echo "Check pgloader version"
|
|
|
|
|
pgloader --version
|
|
|
|
|
echo
|
|
|
|
|
fi
|
2018-11-14 22:08:07 +01:00
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
install:
|
|
|
|
|
- |
|
|
|
|
|
echo "Updating Composer"
|
2016-05-18 18:03:55 +02:00
|
|
|
rm $TRAVIS_BUILD_DIR/composer.json
|
|
|
|
|
rm $TRAVIS_BUILD_DIR/composer.lock
|
2016-05-18 17:16:44 +02:00
|
|
|
composer self-update
|
2019-09-03 15:35:06 +02:00
|
|
|
# To have composer making parallel downloads
|
2019-08-30 20:36:04 +02:00
|
|
|
composer global require hirak/prestissimo
|
2016-05-18 18:08:15 +02:00
|
|
|
composer -n init
|
2016-05-18 18:03:55 +02:00
|
|
|
composer -n config vendor-dir htdocs/includes
|
2015-12-11 05:08:32 +01:00
|
|
|
echo
|
|
|
|
|
|
|
|
|
|
- |
|
2020-09-07 16:11:57 +02:00
|
|
|
echo "Installing Composer dependencies - PHP Unit, Parallel Lint, PHP CodeSniffer - for $TRAVIS_PHP_VERSION"
|
2020-11-01 19:09:12 +01:00
|
|
|
if [ "$TRAVIS_PHP_VERSION" = '5.6' ] || [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = '7.1' ] || [ "$TRAVIS_PHP_VERSION" = '7.2' ]; then
|
2019-08-30 20:36:04 +02:00
|
|
|
composer -n require phpunit/phpunit ^5 \
|
2020-10-23 04:18:30 +02:00
|
|
|
php-parallel-lint/php-parallel-lint ^1 \
|
2020-09-07 16:11:57 +02:00
|
|
|
php-parallel-lint/php-console-highlighter ^0 \
|
2019-08-30 20:36:04 +02:00
|
|
|
squizlabs/php_codesniffer ^3
|
2015-12-11 05:08:32 +01:00
|
|
|
fi
|
2020-11-01 19:09:12 +01:00
|
|
|
if [ "$TRAVIS_PHP_VERSION" = '7.3' ] || [ "$TRAVIS_PHP_VERSION" = '7.4' ]; then
|
2020-11-01 19:29:22 +01:00
|
|
|
composer -n require phpunit/phpunit ^7 \
|
2020-11-01 19:09:12 +01:00
|
|
|
php-parallel-lint/php-parallel-lint ^1.2 \
|
|
|
|
|
php-parallel-lint/php-console-highlighter ^0 \
|
|
|
|
|
squizlabs/php_codesniffer ^3
|
|
|
|
|
fi
|
2019-08-30 21:17:56 +02:00
|
|
|
if [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
|
2020-11-01 19:29:22 +01:00
|
|
|
composer -n require --ignore-platform-reqs phpunit/phpunit ^7 \
|
2020-10-23 04:18:30 +02:00
|
|
|
php-parallel-lint/php-parallel-lint ^1.2 \
|
2020-09-07 16:11:57 +02:00
|
|
|
php-parallel-lint/php-console-highlighter ^0 \
|
2019-08-30 21:17:56 +02:00
|
|
|
squizlabs/php_codesniffer ^3
|
2020-11-01 19:09:12 +01:00
|
|
|
fi
|
2015-12-11 05:08:32 +01:00
|
|
|
echo
|
|
|
|
|
|
2016-05-18 12:26:46 +02:00
|
|
|
- |
|
|
|
|
|
echo "Adding path of binaries tools installed by composer to the PATH"
|
|
|
|
|
export PATH="$TRAVIS_BUILD_DIR/htdocs/includes/bin:$PATH"
|
|
|
|
|
echo
|
2018-04-22 18:34:33 +02:00
|
|
|
|
|
|
|
|
|
2016-05-18 12:26:46 +02:00
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
before_script:
|
2018-04-22 18:43:28 +02:00
|
|
|
- |
|
|
|
|
|
echo Start travis
|
|
|
|
|
echo Current dir is `pwd`
|
|
|
|
|
echo Home dir is `echo ~`
|
|
|
|
|
echo TRAVIS_BUILD_DIR is $TRAVIS_BUILD_DIR
|
2015-12-18 20:02:28 +01:00
|
|
|
|
2018-04-22 18:43:28 +02:00
|
|
|
- |
|
|
|
|
|
echo "Re-enabling Xdebug for PHP CodeSniffer and PHP Unit"
|
|
|
|
|
phpenv config-add /tmp/xdebug.ini
|
|
|
|
|
echo
|
2015-12-11 05:08:32 +01:00
|
|
|
|
2018-04-22 18:43:28 +02:00
|
|
|
- |
|
|
|
|
|
echo "Setting up PHP"
|
|
|
|
|
echo
|
|
|
|
|
echo "Set timezone"
|
|
|
|
|
echo 'date.timezone = "Europe/Paris"' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
|
|
|
|
|
phpenv rehash
|
2015-12-11 05:08:32 +01:00
|
|
|
echo
|
|
|
|
|
|
2018-04-22 18:43:28 +02:00
|
|
|
- |
|
|
|
|
|
echo "Versions information"
|
|
|
|
|
# Check PHP
|
|
|
|
|
echo "PHP version"
|
|
|
|
|
php -i | head -
|
|
|
|
|
# Check PHP CodeSniffer installation
|
|
|
|
|
echo "PHPCS version"
|
|
|
|
|
which phpcs
|
|
|
|
|
phpcs --version | head -
|
|
|
|
|
phpcs -i | head -
|
|
|
|
|
# Check PHPUnit installation
|
|
|
|
|
echo "PHPUnit version"
|
|
|
|
|
which phpunit
|
|
|
|
|
phpunit --version | head -
|
|
|
|
|
# Check Apache version
|
|
|
|
|
echo "Apache version"
|
|
|
|
|
apache2 -v | head -
|
2020-01-30 03:41:31 +01:00
|
|
|
# Check Database
|
|
|
|
|
echo "Database version"
|
2018-04-22 18:43:28 +02:00
|
|
|
mysql --version | head -
|
|
|
|
|
mysql -e "SELECT VERSION();" | head -
|
2020-01-30 04:15:37 +01:00
|
|
|
psql --version
|
2018-04-22 18:43:28 +02:00
|
|
|
echo
|
2018-11-14 22:08:07 +01:00
|
|
|
|
2018-04-22 18:43:28 +02:00
|
|
|
- |
|
|
|
|
|
echo "Setting up database"
|
|
|
|
|
if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ] || [ "$DB" = 'postgresql' ]; then
|
|
|
|
|
echo "MySQL"
|
2020-01-30 03:13:21 +01:00
|
|
|
mysql -u root -e 'DROP DATABASE IF EXISTS travis;'
|
2020-01-30 02:52:20 +01:00
|
|
|
mysql -u root -e 'CREATE DATABASE IF NOT EXISTS travis;'
|
2020-01-30 03:13:21 +01:00
|
|
|
mysql -u root -e 'GRANT ALL PRIVILEGES ON travis.* TO travis@127.0.0.1;'
|
|
|
|
|
mysql -u root -e 'FLUSH PRIVILEGES;'
|
|
|
|
|
mysql -u root -D travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
|
2018-04-22 18:43:28 +02:00
|
|
|
fi
|
|
|
|
|
if [ "$DB" = 'postgresql' ]; then
|
2020-01-30 04:40:24 +01:00
|
|
|
#psql -c 'create database travis;' -U postgres
|
2020-01-30 03:41:31 +01:00
|
|
|
#psql travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
|
2020-01-30 03:46:25 +01:00
|
|
|
#pgloader mysql://root:pass@127.0.0.1/dolibarr_src postgresql://dolibarrowner:dolibarrownerpass@127.0.0.1/dolibarr_dest
|
2020-01-30 04:11:07 +01:00
|
|
|
echo pgloader mysql://root@127.0.0.1/travis postgresql://postgres@/travis
|
|
|
|
|
pgloader mysql://root@127.0.0.1/travis postgresql://postgres@/travis
|
|
|
|
|
echo 'ALTER SEQUENCE llx_accountingaccount_rowid_seq RENAME TO llx_accounting_account_rowid_seq' | psql -U postgres travis
|
|
|
|
|
echo 'ALTER SEQUENCE llx_accounting_account_rowid_seq RESTART WITH 1000001;' | psql -U postgres travis
|
2018-04-22 18:43:28 +02:00
|
|
|
fi
|
|
|
|
|
echo
|
2015-12-11 05:08:32 +01:00
|
|
|
|
2018-04-22 18:43:28 +02:00
|
|
|
- |
|
|
|
|
|
export CONF_FILE=htdocs/conf/conf.php
|
|
|
|
|
echo "Setting up Dolibarr $CONF_FILE"
|
2018-07-26 18:33:00 +02:00
|
|
|
echo '<?php' > $CONF_FILE
|
2018-04-22 18:43:28 +02:00
|
|
|
echo '$'dolibarr_main_url_root=\'http://127.0.0.1\'';' >> $CONF_FILE
|
|
|
|
|
echo '$'dolibarr_main_document_root=\'$TRAVIS_BUILD_DIR/htdocs\'';' >> $CONF_FILE
|
|
|
|
|
echo '$'dolibarr_main_data_root=\'$TRAVIS_BUILD_DIR/documents\'';' >> $CONF_FILE
|
|
|
|
|
echo '$'dolibarr_main_db_host=\'127.0.0.1\'';' >> $CONF_FILE
|
|
|
|
|
echo '$'dolibarr_main_db_name=\'travis\'';' >> $CONF_FILE
|
|
|
|
|
echo '$'dolibarr_main_db_user=\'travis\'';' >> $CONF_FILE
|
2019-09-30 21:59:42 +02:00
|
|
|
echo '$'dolibarr_main_instance_unique_id=\'travis1234567890\'';' >> $CONF_FILE
|
2018-04-22 18:43:28 +02:00
|
|
|
if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
|
|
|
|
|
echo '$'dolibarr_main_db_type=\'mysqli\'';' >> $CONF_FILE
|
2019-01-19 18:00:20 +01:00
|
|
|
echo '$'dolibarr_main_db_port=\'3306\'';' >> $CONF_FILE
|
2018-04-22 18:43:28 +02:00
|
|
|
fi
|
|
|
|
|
if [ "$DB" = 'postgresql' ]; then
|
|
|
|
|
echo '$'dolibarr_main_db_type=\'pgsql\'';' >> $CONF_FILE
|
2019-01-19 18:00:20 +01:00
|
|
|
echo '$'dolibarr_main_db_port=\'5432\'';' >> $CONF_FILE
|
2018-04-22 18:43:28 +02:00
|
|
|
fi
|
|
|
|
|
echo '$'dolibarr_main_authentication=\'dolibarr\'';' >> $CONF_FILE
|
|
|
|
|
cat $CONF_FILE
|
|
|
|
|
echo
|
2015-12-11 05:08:32 +01:00
|
|
|
|
2018-04-22 18:43:28 +02:00
|
|
|
- |
|
|
|
|
|
echo "Create documents directory and set permissions"
|
|
|
|
|
# and admin/temp subdirectory needed for unit tests
|
2018-07-01 23:00:10 +02:00
|
|
|
mkdir -p $TRAVIS_BUILD_DIR/documents/admin/temp
|
|
|
|
|
sudo chmod -R a+rwx $TRAVIS_BUILD_DIR/documents
|
|
|
|
|
echo "***** First line of dolibarr.log" > $TRAVIS_BUILD_DIR/documents/dolibarr.log
|
2018-04-22 18:43:28 +02:00
|
|
|
echo
|
2015-12-11 05:08:32 +01:00
|
|
|
|
2018-04-22 19:00:18 +02:00
|
|
|
|
|
|
|
|
- echo "Setting up Apache + FPM"
|
|
|
|
|
# enable php-fpm
|
|
|
|
|
- sudo cp ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf.default ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf
|
2018-04-22 19:38:24 +02:00
|
|
|
- |
|
2019-12-23 16:04:35 +01:00
|
|
|
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
|
2018-04-22 19:27:37 +02:00
|
|
|
# Copy the included pool
|
|
|
|
|
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
|
|
|
|
|
fi
|
2018-04-22 19:00:18 +02:00
|
|
|
- sudo a2enmod rewrite actions fastcgi alias
|
|
|
|
|
- echo "cgi.fix_pathinfo = 1" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
|
|
|
|
|
- sudo sed -i -e "s,www-data,travis,g" /etc/apache2/envvars
|
|
|
|
|
- sudo chown -R travis:travis /var/lib/apache2/fastcgi
|
|
|
|
|
- ~/.phpenv/versions/$(phpenv version-name)/sbin/php-fpm
|
2020-01-30 12:24:35 +01:00
|
|
|
# configure apache virtual hosts
|
2018-04-22 19:00:18 +02:00
|
|
|
- sudo cp -f build/travis-ci/apache.conf /etc/apache2/sites-available/000-default.conf
|
|
|
|
|
- sudo sed -e "s?%TRAVIS_BUILD_DIR%?$(pwd)?g" --in-place /etc/apache2/sites-available/000-default.conf
|
|
|
|
|
- sudo cat /etc/apache2/sites-available/000-default.conf
|
|
|
|
|
- sudo service apache2 restart
|
|
|
|
|
|
2018-04-22 18:34:33 +02:00
|
|
|
|
|
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
script:
|
|
|
|
|
- |
|
2018-04-22 11:47:15 +02:00
|
|
|
echo "Checking webserver availability by a wget -O - http://127.0.0.1"
|
2019-01-19 16:54:04 +01:00
|
|
|
# Ensure we stop on error with set -e
|
|
|
|
|
set +e
|
2018-04-22 12:37:01 +02:00
|
|
|
# The wget should return a page with line '<meta name="generator" content="Dolibarr installer">
|
2018-04-22 11:47:15 +02:00
|
|
|
wget -O - http://127.0.0.1 > test.html
|
|
|
|
|
head test.html
|
2019-01-19 17:38:05 +01:00
|
|
|
sudo cat /var/log/apache2/travis_error_log
|
2018-04-22 12:10:53 +02:00
|
|
|
set +e
|
|
|
|
|
echo
|
|
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
- |
|
|
|
|
|
echo "Checking PHP syntax errors"
|
|
|
|
|
# Ensure we catch errors
|
|
|
|
|
set -e
|
2018-11-14 22:08:07 +01:00
|
|
|
#parallel-lint --exclude htdocs/includes --blame .
|
2020-09-08 04:24:20 +02:00
|
|
|
parallel-lint --exclude dev/namespacemig --exclude htdocs/includes/composer --exclude htdocs/includes/myclabs --exclude htdocs/includes/phpspec --exclude dev/initdata/dbf/includes \
|
2020-09-08 05:07:35 +02:00
|
|
|
--exclude htdocs/includes/sabre --exclude htdocs/includes/phpoffice/phpexcel --exclude htdocs/includes/phpoffice/PhpSpreadsheet --exclude htdocs/includes/sebastian \
|
2020-09-08 04:24:20 +02:00
|
|
|
--exclude htdocs/includes/squizlabs/php_codesniffer --exclude htdocs/includes/jakub-onderka --exclude htdocs/includes/php-parallel-lint --exclude htdocs/includes/symfony \
|
|
|
|
|
--exclude htdocs/includes/mike42/escpos-php/example --exclude htdocs/includes/maximebf \
|
2020-09-08 05:10:48 +02:00
|
|
|
--exclude htdocs/includes/phpunit/ --exclude htdocs/includes/tecnickcom/tcpdf/include/barcodes --exclude htdocs/includes/webmozart --blame .
|
2015-12-11 05:08:32 +01:00
|
|
|
set +e
|
|
|
|
|
echo
|
|
|
|
|
|
|
|
|
|
- |
|
2019-08-27 09:30:42 +02:00
|
|
|
echo "Checking coding style (excluding Pull Requests builds)"
|
2015-12-11 05:08:32 +01:00
|
|
|
# Ensure we catch errors
|
|
|
|
|
set -e
|
|
|
|
|
# Exclusions are defined in the ruleset.xml file
|
2020-05-21 09:21:30 +02:00
|
|
|
#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 .
|
|
|
|
|
if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then 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 .; fi
|
2015-12-11 05:08:32 +01:00
|
|
|
set +e
|
|
|
|
|
echo
|
|
|
|
|
|
2018-07-26 13:49:12 +02:00
|
|
|
- |
|
|
|
|
|
export INSTALL_FORCED_FILE=htdocs/install/install.forced.php
|
2019-09-30 22:13:21 +02:00
|
|
|
echo "Setting up Dolibarr $INSTALL_FORCED_FILE to test installation"
|
2018-07-26 13:49:12 +02:00
|
|
|
# Ensure we catch errors
|
|
|
|
|
set +e
|
|
|
|
|
echo '<?php ' > $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_noedit=2';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
|
|
|
|
|
echo '$'force_install_type=\'mysqli\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
fi
|
|
|
|
|
if [ "$DB" = 'postgresql' ]; then
|
|
|
|
|
echo '$'force_install_type=\'pgsql\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
fi
|
|
|
|
|
echo '$'force_install_dbserver=\'127.0.0.1\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_database=\'travis\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_databaselogin=\'travis\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_databasepass=\'\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_port=\'5432\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_prefix=\'llx_\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_createdatabase=false';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_createuser=false';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_mainforcehttps=false';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
echo '$'force_install_main_data_root=\'$TRAVIS_BUILD_DIR/htdocs\'';' >> $INSTALL_FORCED_FILE
|
|
|
|
|
#cat $INSTALL_FORCED_FILE
|
2019-09-30 22:13:21 +02:00
|
|
|
|
2019-09-30 22:50:48 +02:00
|
|
|
#- |
|
|
|
|
|
# echo "Installing Dolibarr"
|
|
|
|
|
# cd htdocs/install
|
|
|
|
|
# php step1.php $TRAVIS_BUILD_DIR/htdocs > $TRAVIS_BUILD_DIR/install.log
|
|
|
|
|
# php step2.php set >> $TRAVIS_BUILD_DIR/install.log
|
|
|
|
|
# if [ "$?" -ne "0" ]; then
|
|
|
|
|
# echo "SORRY, AN ERROR OCCURED DURING INSTALLATION PROCESS"
|
|
|
|
|
# cat $TRAVIS_BUILD_DIR/install.log
|
|
|
|
|
# exit 1
|
|
|
|
|
# fi
|
|
|
|
|
# cd ../..
|
|
|
|
|
# rm $INSTALL_FORCED_FILE
|
|
|
|
|
# #cat $TRAVIS_BUILD_DIR/install.log
|
|
|
|
|
# set +e
|
|
|
|
|
# echo
|
|
|
|
|
|
2019-09-30 22:13:21 +02:00
|
|
|
- |
|
2018-07-26 13:49:12 +02:00
|
|
|
echo "Setting up database to test migrations"
|
|
|
|
|
if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ] || [ "$DB" = 'postgresql' ]; then
|
|
|
|
|
echo "MySQL"
|
|
|
|
|
mysql -e 'DROP DATABASE IF EXISTS travis;'
|
|
|
|
|
mysql -e 'CREATE DATABASE IF NOT EXISTS travis;'
|
|
|
|
|
mysql -e 'GRANT ALL PRIVILEGES ON travis.* TO travis@127.0.0.1;'
|
2019-10-20 09:58:31 +02:00
|
|
|
mysql -e 'FLUSH PRIVILEGES;'
|
2018-07-26 13:49:12 +02:00
|
|
|
mysql -D travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
|
|
|
|
|
fi
|
|
|
|
|
if [ "$DB" = 'postgresql' ]; then
|
|
|
|
|
#pgsql travis < dev/initdemo/mysqldump_dolibarr_3.5.0.sql
|
|
|
|
|
#pgloader mysql://root:pass@127.0.0.1/base postgresql://dolibarrowner@127.0.0.1/dolibarr
|
2019-10-01 01:42:08 +02:00
|
|
|
echo pgloader mysql://root@127.0.0.1/travis postgresql:///travis
|
2018-07-26 13:49:12 +02:00
|
|
|
pgloader mysql://root@127.0.0.1/travis postgresql:///travis
|
2019-10-01 01:42:08 +02:00
|
|
|
echo 'ALTER SEQUENCE llx_accountingaccount_rowid_seq RENAME TO llx_accounting_account_rowid_seq' | psql travis
|
|
|
|
|
echo 'ALTER SEQUENCE llx_accounting_account_rowid_seq RESTART WITH 1000001;' | psql travis
|
|
|
|
|
#echo 'select * from INFORMATION_SCHEMA.COLUMNS where table_name = 'llx_accountingaccount' | psql travis
|
|
|
|
|
#echo 'select * from information_schema.table_constraints;' | psql travis
|
|
|
|
|
#echo 'ALTER TABLE "llx_accounting_account" DROP CONSTRAINT "idx_16390_primary"' | psql travis
|
2018-07-26 13:49:12 +02:00
|
|
|
fi
|
|
|
|
|
echo
|
2019-10-20 09:58:31 +02:00
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
- |
|
|
|
|
|
echo "Upgrading Dolibarr"
|
2019-01-20 17:06:24 +01:00
|
|
|
# Ensure we catch errors. Set this to +e if you want to go to the end to see log files.
|
2019-01-21 11:56:54 +01:00
|
|
|
set +e
|
2015-12-11 05:08:32 +01:00
|
|
|
cd htdocs/install
|
|
|
|
|
php upgrade.php 3.5.0 3.6.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade350360.log
|
2017-06-09 14:30:02 +02:00
|
|
|
php upgrade2.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-2.log
|
|
|
|
|
php step5.php 3.5.0 3.6.0 > $TRAVIS_BUILD_DIR/upgrade350360-3.log
|
2015-12-11 05:08:32 +01:00
|
|
|
php upgrade.php 3.6.0 3.7.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade360370.log
|
2017-06-09 14:30:02 +02:00
|
|
|
php upgrade2.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-2.log
|
|
|
|
|
php step5.php 3.6.0 3.7.0 > $TRAVIS_BUILD_DIR/upgrade360370-3.log
|
2015-12-11 05:08:32 +01:00
|
|
|
php upgrade.php 3.7.0 3.8.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade370380.log
|
2017-06-09 14:30:02 +02:00
|
|
|
php upgrade2.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-2.log
|
|
|
|
|
php step5.php 3.7.0 3.8.0 > $TRAVIS_BUILD_DIR/upgrade370380-3.log
|
2015-12-11 05:08:32 +01:00
|
|
|
php upgrade.php 3.8.0 3.9.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade380390.log
|
2017-06-09 14:30:02 +02:00
|
|
|
php upgrade2.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-2.log
|
|
|
|
|
php step5.php 3.8.0 3.9.0 > $TRAVIS_BUILD_DIR/upgrade380390-3.log
|
2016-01-12 22:54:20 +01:00
|
|
|
php upgrade.php 3.9.0 4.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade390400.log
|
2019-01-20 15:37:03 +01:00
|
|
|
php upgrade2.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-2.log
|
2017-06-09 14:30:02 +02:00
|
|
|
php step5.php 3.9.0 4.0.0 > $TRAVIS_BUILD_DIR/upgrade390400-3.log
|
2016-07-14 15:56:35 +02:00
|
|
|
php upgrade.php 4.0.0 5.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade400500.log
|
2017-10-22 16:08:52 +02:00
|
|
|
php upgrade2.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-2.log
|
2017-06-09 14:30:02 +02:00
|
|
|
php step5.php 4.0.0 5.0.0 > $TRAVIS_BUILD_DIR/upgrade400500-3.log
|
2017-01-27 13:56:16 +01:00
|
|
|
php upgrade.php 5.0.0 6.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade500600.log
|
2017-10-22 16:08:52 +02:00
|
|
|
php upgrade2.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-2.log
|
2017-06-09 14:30:02 +02:00
|
|
|
php step5.php 5.0.0 6.0.0 > $TRAVIS_BUILD_DIR/upgrade500600-3.log
|
2017-07-18 14:20:37 +02:00
|
|
|
php upgrade.php 6.0.0 7.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade600700.log
|
2019-01-20 15:37:03 +01:00
|
|
|
php upgrade2.php 6.0.0 7.0.0 > $TRAVIS_BUILD_DIR/upgrade600700-2.log
|
2017-07-18 14:20:37 +02:00
|
|
|
php step5.php 6.0.0 7.0.0 > $TRAVIS_BUILD_DIR/upgrade600700-3.log
|
2018-02-08 15:58:00 +01:00
|
|
|
php upgrade.php 7.0.0 8.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade700800.log
|
2019-01-20 15:37:03 +01:00
|
|
|
php upgrade2.php 7.0.0 8.0.0 > $TRAVIS_BUILD_DIR/upgrade700800-2.log
|
2018-02-08 15:58:00 +01:00
|
|
|
php step5.php 7.0.0 8.0.0 > $TRAVIS_BUILD_DIR/upgrade700800-3.log
|
2018-07-01 00:00:07 +02:00
|
|
|
php upgrade.php 8.0.0 9.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade800900.log
|
|
|
|
|
php upgrade2.php 8.0.0 9.0.0 > $TRAVIS_BUILD_DIR/upgrade800900-2.log
|
|
|
|
|
php step5.php 8.0.0 9.0.0 > $TRAVIS_BUILD_DIR/upgrade800900-3.log
|
2018-12-05 20:53:39 +01:00
|
|
|
php upgrade.php 9.0.0 10.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade9001000.log
|
|
|
|
|
php upgrade2.php 9.0.0 10.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-2.log
|
|
|
|
|
php step5.php 9.0.0 10.0.0 > $TRAVIS_BUILD_DIR/upgrade9001000-3.log
|
2019-12-23 13:51:12 +01:00
|
|
|
php upgrade.php 10.0.0 11.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade10001100.log
|
|
|
|
|
php upgrade2.php 10.0.0 11.0.0 > $TRAVIS_BUILD_DIR/upgrade10001100-2.log
|
|
|
|
|
php step5.php 10.0.0 11.0.0 > $TRAVIS_BUILD_DIR/upgrade10001100-3.log
|
|
|
|
|
php upgrade.php 11.0.0 12.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade11001200.log
|
|
|
|
|
php upgrade2.php 11.0.0 12.0.0 > $TRAVIS_BUILD_DIR/upgrade11001200-2.log
|
|
|
|
|
php step5.php 11.0.0 12.0.0 > $TRAVIS_BUILD_DIR/upgrade11001200-3.log
|
2020-05-18 15:47:21 +02:00
|
|
|
php upgrade.php 12.0.0 13.0.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade12001300.log
|
|
|
|
|
php upgrade2.php 12.0.0 13.0.0 > $TRAVIS_BUILD_DIR/upgrade12001300-2.log
|
|
|
|
|
php step5.php 12.0.0 13.0.0 > $TRAVIS_BUILD_DIR/upgrade12001300-3.log
|
|
|
|
|
|
2019-01-20 15:37:03 +01:00
|
|
|
# Enable modules not enabled into original dump
|
2020-11-01 19:29:22 +01:00
|
|
|
php upgrade2.php 0.0.0 0.0.0 MAIN_MODULE_API,MAIN_MODULE_SUPPLIERPROPOSAL,MAIN_MODULE_WEBSITE,MAIN_MODULE_TICKET,MAIN_MODULE_ACCOUNTING,MAIN_MODULE_MRP > $TRAVIS_BUILD_DIR/enablemodule.log
|
2019-01-20 19:45:10 +01:00
|
|
|
echo $?
|
2015-12-11 05:08:32 +01:00
|
|
|
cd -
|
|
|
|
|
set +e
|
|
|
|
|
echo
|
2018-07-03 20:44:39 +02:00
|
|
|
#cat /tmp/dolibarr_install.log
|
2019-01-20 15:37:03 +01:00
|
|
|
cat $TRAVIS_BUILD_DIR/enablemodule.log
|
2018-11-14 22:08:07 +01:00
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
- |
|
|
|
|
|
echo "Unit testing"
|
2017-10-04 02:56:45 +02:00
|
|
|
# Ensure we catch errors. Set this to +e if you want to go to the end to see dolibarr.log file.
|
2020-01-16 01:44:01 +01:00
|
|
|
set -e
|
2016-05-17 19:40:58 +02:00
|
|
|
phpunit -d memory_limit=-1 -c test/phpunit/phpunittest.xml test/phpunit/AllTests.php
|
2018-07-01 11:59:06 +02:00
|
|
|
phpunitresult=$?
|
2018-07-01 23:14:03 +02:00
|
|
|
echo "Phpunit return code = $phpunitresult"
|
2015-12-11 05:08:32 +01:00
|
|
|
set +e
|
2016-02-02 13:05:26 +01:00
|
|
|
|
2016-02-02 16:24:12 +01:00
|
|
|
after_script:
|
|
|
|
|
- |
|
2020-10-22 22:15:08 +02:00
|
|
|
echo "After script - Output last lines of dolibarr.log"
|
2018-07-01 23:57:54 +02:00
|
|
|
ls $TRAVIS_BUILD_DIR/documents
|
2019-01-21 05:50:14 +01:00
|
|
|
#cat $TRAVIS_BUILD_DIR/documents/dolibarr.log
|
|
|
|
|
sudo tail -n 50 $TRAVIS_BUILD_DIR/documents/dolibarr.log
|
2016-02-02 16:24:12 +01:00
|
|
|
|
2015-12-11 05:08:32 +01:00
|
|
|
after_success:
|
2016-02-02 12:53:45 +01:00
|
|
|
- |
|
|
|
|
|
echo Success
|
2015-12-11 05:08:32 +01:00
|
|
|
|
|
|
|
|
after_failure:
|
|
|
|
|
- |
|
2018-07-01 22:46:54 +02:00
|
|
|
echo Failure detected, so we show samples of log to help diagnose
|
2019-01-19 18:00:20 +01:00
|
|
|
# This part of code is executed only if previous command that fails are enclosed with set +e
|
2016-02-01 03:53:21 +01:00
|
|
|
# Upgrade log files
|
2018-07-01 22:46:54 +02:00
|
|
|
for ficlog in `ls $TRAVIS_BUILD_DIR/*.log`
|
|
|
|
|
do
|
|
|
|
|
echo "Debugging informations for file $ficlog"
|
2018-07-01 22:56:23 +02:00
|
|
|
#cat $ficlog
|
2018-07-01 22:46:54 +02:00
|
|
|
done
|
2016-02-01 03:53:21 +01:00
|
|
|
# Apache log file
|
2018-07-01 23:14:03 +02:00
|
|
|
echo "Debugging informations for file apache error.log"
|
2019-01-19 17:38:05 +01:00
|
|
|
sudo cat /var/log/apache2/travis_error_log
|
2015-12-11 05:08:32 +01:00
|
|
|
if [ "$DEBUG" = true ]; then
|
2018-07-01 23:14:03 +02:00
|
|
|
# Dolibarr log file
|
2018-07-01 22:46:54 +02:00
|
|
|
echo "Debugging informations for file dolibarr.log (latest 50 lines)"
|
2018-07-01 22:41:09 +02:00
|
|
|
tail -n 50 $TRAVIS_BUILD_DIR/documents/dolibarr.log
|
2020-01-30 03:54:02 +01:00
|
|
|
# Database log file
|
2018-07-01 22:46:54 +02:00
|
|
|
echo "Debugging informations for file mysql error.log"
|
2018-07-01 21:13:29 +02:00
|
|
|
sudo tail -n 50 /var/log/mysql/error.log
|
2015-12-11 05:08:32 +01:00
|
|
|
# TODO: PostgreSQL log file
|
|
|
|
|
echo
|
|
|
|
|
fi
|