Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
D
dolibarr
Manage
Activity
Members
Code
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Deploy
Releases
Container Registry
Model registry
Analyze
Contributor analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Software_Artifact_Infrastructure_Repository
dolibarr
Commits
c1c0fa88
Commit
c1c0fa88
authored
9 years ago
by
Laurent Destailleur
Browse files
Options
Downloads
Patches
Plain Diff
Fix for new travis setup
parent
7af4d918
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
.travis.yml
+296
-95
296 additions, 95 deletions
.travis.yml
build/travis-ci/apache.conf
+18
-0
18 additions, 0 deletions
build/travis-ci/apache.conf
with
314 additions
and
95 deletions
.travis.yml
+
296
−
95
View file @
c1c0fa88
# This script is used by Travis CI to run automatically Continuous test integration
# from Dolibarr GitHub repository.
# Command run is phpunit
# For syntax, see http://about.travis-ci.org/docs/user/languages/php/
sudo
:
required
language
:
php
php
:
-
'
5.3'
-
'
5.4'
-
'
5.5'
-
'
5.6'
-
'
7.0'
-
nightly
addons
:
mariadb
:
'
10.0'
# FIXME: find a way to import a MySQL dump into PostgreSQL
#postgresql: '9.3'
apt
:
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
# Start on every boot
services
:
-
memcached
env
:
global
:
# Set to true for very verbose output
-
DEBUG=true
matrix
:
# MariaDB overrides MySQL installation so it's not possible to test both yet
#- DB=mysql
-
DB=mariadb
# FIXME: find a way to import a MySQL dump into PostgreSQL
#- DB=postgresql
# TODO
#- DB=sqlite
# 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
matrix
:
fast_finish
:
true
allow_failures
:
-
php
:
'
7.0'
-
php
:
nightly
# FIXME
#- env: DB=postgresql
# TODO
#- env: DB=sqlite
notifications
:
email
:
on_success
:
never
# [always|never|change] default: change
on_failure
:
change
# [always|never|change] default: always
services
:
-
memcached
# will start memcached
irc
:
channels
:
-
"
chat.freenode.net#dolibarr"
on_success
:
change
on_failure
:
always
use_notice
:
true
# This will tell travis to run phpunit
language
:
php
php
:
# - "5.2" is not supported because pyrus to install PHP_Codesniffer is not available
-
"
5.3"
-
"
5.4"
-
"
5.5"
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
env
:
-
DB=mysql
# - DB=postgres
before_script
:
-
echo Start travis
-
echo Current dir is `pwd`
-
echo Home dir is `echo ~`
-
export PHPV=`phpenv version-name`
-
echo PHP version $PHPV
# - echo Update composer
# - ~/.phpenv/versions/$(phpenv version-name)/bin/composer.phar self-update
-
echo PHPUnit version
-
phpunit --version
-
echo Install phpcs then show installed rules
-
pyrus install pear/PHP_CodeSniffer
-
phpenv rehash
-
phpcs -i
-
echo Create dir $(pwd)/htdocs/documents
-
sudo mkdir -p $(pwd)/htdocs/documents/admin/temp;
-
sudo touch $(pwd)/htdocs/documents/dolibarr.log;
-
sudo chmod a+rwx /home; sudo chmod a+rwx /home/travis; sudo chmod -R a+rwx /home/travis/build;
-
sudo chmod -R a+rwx $(pwd);
-
sudo chown -R www-data:travis $(pwd)/htdocs/documents;
-
find $(pwd)/htdocs/documents -type d -exec ls -alt {} \;
-
echo Edit php.ini file
-
echo 'date.timezone = "Europe/Paris"' >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
# - echo "extension = memcache.so" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
-
echo "extension = memcached.so" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
-
sh -c "if [ '$PHPV' = '5.3' ]; then echo 'extension = apc.so' >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini; fi"
-
sh -c "if [ '$PHPV' = '5.4' ]; then echo 'extension = apc.so' >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini; fi"
-
sh -c "if [ '$PHPV' = '5.3' ]; then echo 'zend_extension_ts = xdebug.so' >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini; fi"
-
sh -c "if [ '$PHPV' = '5.4' ]; then echo 'zend_extension_ts = xdebug.so' >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini; fi"
-
cat ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
-
echo Init database
-
sh -c "if [ '$DB' = 'pgsql' ]; then psql -c 'DROP DATABASE IF EXISTS myapp_test;' -U postgres; fi"
-
sh -c "if [ '$DB' = 'pgsql' ]; then psql -c 'CREATE DATABASE myapp_test;' -U postgres; fi"
-
sh -c "if [ '$DB' = 'mysql' ]; then mysql -e 'DROP DATABASE IF EXISTS myapp_test;'; fi"
-
sh -c "if [ '$DB' = 'mysql' ]; then mysql -e 'CREATE DATABASE IF NOT EXISTS myapp_test;'; fi"
-
sh -c "if [ '$DB' = 'mysql' ]; then mysql -D myapp_test < $(pwd)/dev/initdata/mysqldump_dolibarr_3.4.0.sql; fi"
-
echo Create config file htdocs/conf/conf.php
-
echo '<?php ' > htdocs/conf/conf.php
-
sh -c "if [ '$DB' = 'pgsql' ]; then echo '$'dolibarr_main_db_type=\'pgsql\'';' >> htdocs/conf/conf.php; fi"
-
sh -c "if [ '$DB' = 'mysql' ]; then echo '$'dolibarr_main_db_type=\'mysqli\'';' >> htdocs/conf/conf.php; fi"
-
echo '$'dolibarr_main_url_root=\'http://localhost/\'';' >> htdocs/conf/conf.php
-
echo '$'dolibarr_main_document_root=\'$(pwd)/htdocs\'';' >> htdocs/conf/conf.php
-
echo '$'dolibarr_main_data_root=\'$(pwd)/htdocs/documents\'';' >> htdocs/conf/conf.php
-
echo '$'dolibarr_main_db_host=\'localhost\'';' >> htdocs/conf/conf.php
-
echo '$'dolibarr_main_db_name=\'myapp_test\'';' >> htdocs/conf/conf.php
-
echo '$'dolibarr_main_db_user=\'travis\'';' >> htdocs/conf/conf.php
-
echo '$'dolibarr_main_authentication=\'dolibarr\'';' >> htdocs/conf/conf.php
-
echo '?>' >> htdocs/conf/conf.php
-
echo Show conf.php content
-
cat htdocs/conf/conf.php
-
echo Install apache server
-
sudo apt-get update
-
sudo apt-get install -y --force-yes apache2 libapache2-mod-php5 php5-curl php5-mysql php5-pgsql php5-intl
-
sudo sed -i -e "s,/var/www,$(pwd)/htdocs,g" /etc/apache2/sites-available/default
-
echo Show default virtual host
-
sudo cat /etc/apache2/sites-available/default
-
sudo /etc/init.d/apache2 restart
-
wget http://localhost/
-
cat index.html
script
:
-
cd htdocs/install
-
php upgrade.php 3.4.0 3.5.0 > upgrade.log
-
php upgrade2.php 3.4.0 3.5.0 > upgrade2.log
-
php upgrade.php 3.5.0 3.6.0 >> upgrade.log
-
php upgrade2.php 3.5.0 3.6.0 >> upgrade2.log
# - cat upgrade.log
# - cat upgrade2.log
-
cd ../..
-
date
# - phpcs -p --warning-severity=0 -s --report-summary --standard=dev/codesniffer/ruleset.xml --tab-width=4 --ignore=/build/html/,/dev/vagrant/,/documents/,/includes/,/test/report/ htdocs/core/class/dolgraph.class.php 2>&1
-
phpcs -p --warning-severity=0 -s --report-checkstyle --report-summary --standard=dev/codesniffer/ruleset.xml --tab-width=4 --ignore=/build/html/,/dev/vagrant/,/documents/,/includes/,/test/report/ . 2>&1
-
date
-
phpunit -d memory_limit=-1 --configuration test/phpunit/phpunittest.xml test/phpunit/AllTests.php
install
:
-
|
echo "Updating Composer"
composer self-update
echo
after_script
:
# - echo Output dolibarr log file; cat $(pwd)/htdocs/documents/dolibarr.log
-
echo Output apache log file; sudo cat /var/log/apache2/error.log
-
echo End travis
-
|
echo "Installing Parallel Lint"
composer -n require jakub-onderka/php-parallel-lint ^0
composer -n require jakub-onderka/php-console-highlighter ^0
echo
-
|
echo "Installing PHP Unit"
if [ "$TRAVIS_PHP_VERSION" = '5.3' ] || [ "$TRAVIS_PHP_VERSION" = '5.4' ] || [ "$TRAVIS_PHP_VERSION" = '5.5' ]; then
composer -n require phpunit/phpunit ^4
fi
if [ "$TRAVIS_PHP_VERSION" = '5.6' ] || [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
composer -n require phpunit/phpunit ^5
fi
echo
-
|
echo "Installing PHP CodeSniffer"
composer require squizlabs/php_codesniffer ^2
echo
-
|
echo "Adding Composer binaries to the path"
export PATH="$TRAVIS_BUILD_DIR/htdocs/includes/bin:$PATH"
echo
before_script
:
-
|
echo Start travis
echo Current dir is `pwd`
echo Home dir is `echo ~`
echo TRAVIS_BUILD_DIR is $TRAVIS_BUILD_DIR
-
|
echo "Re-enabling Xdebug for PHP CodeSniffer and PHP Unit"
phpenv config-add /tmp/xdebug.ini
echo
-
|
echo "Setting up PHP"
echo
echo "Set timezone"
echo 'date.timezone = "Europe/Paris"' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
if [ "$TRAVIS_PHP_VERSION" = '5.3' ] || [ "$TRAVIS_PHP_VERSION" = '5.4' ]; then
echo
echo "Enabling APC for PHP <= 5.4"
# Documentation says it should be available for PHP <= 5.6 but it's not for 5.5 and 5.6!
echo 'extension = apc.so' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
echo
echo "Enabling Memcached for PHP <= 5.4"
# Documentation says it should be available for all PHP versions but it's not for 5.5 and 5.6, 7.0 and nightly!
echo 'extension = memcached.so' >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
fi
phpenv rehash
echo
-
|
if [ "$DEBUG" = true ]; then
echo "Debugging informations"
# Check PHP
php -i
# Check PHP CodeSniffer installation
which phpcs
phpcs --version
phpcs -i
# Check PHPUnit installation
which phpunit
phpunit --version
# Check MySQL
mysql --version
mysql -e "SELECT VERSION();"
echo
fi
-
|
echo "Setting up database"
if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
echo "MySQL"
mysql -e 'DROP DATABASE IF EXISTS travis;'
mysql -e 'CREATE DATABASE IF NOT EXISTS travis;'
mysql -D travis < dev/initdata/mysqldump_dolibarr_3.5.0.sql
fi
# FIXME: find a way to import a MySQL dump into PostgreSQL
#if [ "$DB" = 'postgresql' ]; then
# pgsql travis < dev/initdata/mysqldump_dolibarr_3.5.0.sql
#fi
# TODO: SQLite
echo
-
|
echo "Setting up Dolibarr"
export CONF_FILE=htdocs/conf/conf.php
echo '<?php ' > $CONF_FILE
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
if [ "$DB" = 'mysql' ] || [ "$DB" = 'mariadb' ]; then
echo '$'dolibarr_main_db_type=\'mysqli\'';' >> $CONF_FILE
fi
# FIXME
#if [ "$DB" = 'postgresql' ]; then
# echo '$'dolibarr_main_db_type=\'pgsql\'';' >> $CONF_FILE
#fi
# TODO: SQLite
echo '$'dolibarr_main_authentication=\'dolibarr\'';' >> $CONF_FILE
echo
-
|
if [ "$DEBUG" = true ]; then
echo "Debugging informations"
cat $CONF_FILE
echo
fi
-
|
echo "Create documents directory and set permissions"
# and admin/temp subdirectory needed for unit tests
mkdir -p documents/admin/temp
echo
-
|
echo "Setting up Apache + FPM"
# enable php-fpm
cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.conf.default ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.conf
if [ "$TRAVIS_PHP_VERSION" = '7.0' ] || [ "$TRAVIS_PHP_VERSION" = 'nightly' ]; then
# Copy the included pool
cp ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.d/www.conf.default ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.d/www.conf
fi
if [ "$DEBUG" = true ]; then
cat ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php-fpm.conf
fi
sudo a2enmod rewrite actions fastcgi alias
echo "cgi.fix_pathinfo = 1" >> ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
if [ "$DEBUG" = true ]; then
cat ~/.phpenv/versions/$PHP_VERSION_NAME/etc/php.ini
fi
~/.phpenv/versions/$PHP_VERSION_NAME/sbin/php-fpm
# configure apache virtual hosts
sudo cp -f build/travis-ci/apache.conf /etc/apache2/sites-available/default
sudo sed -e "s?%TRAVIS_BUILD_DIR%?$TRAVIS_BUILD_DIR?g" --in-place /etc/apache2/sites-available/default
if [ "$DEBUG" = true ]; then
sudo cat /etc/apache2/sites-available/default
fi
sudo service apache2 restart
echo
script
:
-
|
echo "Checking webserver availability"
# Ensure we catch errors
set -e
wget http://127.0.0.1
if [ "$DEBUG" = true ]; then
cat index.html
fi
set +e
echo
-
|
echo "Checking PHP syntax errors"
# Ensure we catch errors
set -e
parallel-lint --exclude htdocs/includes --blame .
set +e
echo
# TODO: dev/* checks
-
|
echo "Checking coding style"
# Ensure we catch errors
set -e
# Exclusions are defined in the ruleset.xml file
phpcs -s -n -p -d memory_limit=-1 --colors --tab-width=4 --standard=dev/codesniffer/ruleset.xml --encoding=utf-8 .
set +e
echo
# TODO: Check Javascript (jshint?)
# TODO: Check CSS (csslint?)
# TODO: check SQL syntax (pgsanity?)
-
|
echo "Upgrading Dolibarr"
# Ensure we catch errors
set -e
cd htdocs/install
php upgrade.php 3.5.0 3.6.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade350360.log
php upgrade2.php 3.5.0 3.6.0 ignoredbversion > $TRAVIS_BUILD_DIR/upgrade350360-2.log
cd -
set +e
echo
-
|
echo "Unit testing"
# Ensure we catch errors
set -e
phpunit -d memory_limit=-1 -c test/phpunit/phpunittest.xml test/phpunit/AllTests.php
set +e
echo
after_success
:
after_failure
:
-
|
if [ "$DEBUG" = true ]; then
echo "Debugging informations"
# Upgrade log files
cat *.log
# Dolibarr log file
cat documents/dolibarr.log
# Apache log file
sudo cat /var/log/apache2/error.log
# MariaDB log file
sudo cat /var/log/mysql/error.log
# TODO: PostgreSQL log file
echo
fi
after_script
:
This diff is collapsed.
Click to expand it.
build/travis-ci/apache.conf
0 → 100644
+
18
−
0
View file @
c1c0fa88
<
VirtualHost
*:
80
>
DocumentRoot
%
TRAVIS_BUILD_DIR
%/
htdocs
<
Directory
"%TRAVIS_BUILD_DIR%/htdocs"
>
Options
FollowSymLinks
MultiViews
ExecCGI
AllowOverride
All
Order
deny
,
allow
Allow
from
all
</
Directory
>
# Wire up Apache to use Travis CI's php-fpm.
<
IfModule
mod_fastcgi
.
c
>
AddHandler
php5
-
fcgi
.
php
Action
php5
-
fcgi
/
php5
-
fcgi
Alias
/
php5
-
fcgi
/
usr
/
lib
/
cgi
-
bin
/
php5
-
fcgi
FastCgiExternalServer
/
usr
/
lib
/
cgi
-
bin
/
php5
-
fcgi
-
host
127
.
0
.
0
.
1
:
9000
-
pass
-
header
Authorization
</
IfModule
>
</
VirtualHost
>
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment