language: php php: - 7.2 - 7.3 - 7.4 # none of our dependencies allow 8.0 # - master matrix: fast_finish: true # allow_failures: # - php: master services: - memcached - mysql # - postgres sudo: required before_script: - sudo apt-get update -qq - sudo apt-get install -y libpcre3-dev apache2 libapache2-mod-fastcgi - case $(phpenv version-name) in "7"|"7.0"|"7.1"|"7.2") yes "" | pecl install apcu; echo "extension=memcached.so" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini; phpenv config-rm xdebug.ini; ;; "7.3"|"7.4"|"master") echo "extension=memcached.so" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini; ;; esac # enable apache with php-fpm see https://docs.travis-ci.com/user/languages/php/#apache--php - sudo cp ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf.default ~/.phpenv/versions/$(phpenv version-name)/etc/php-fpm.conf - 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 # configure apache virtual hosts - sudo cp -f doc/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 service apache2 restart - curl -i http://localhost/egroupware/groupdav.php/ - php -m - php -i - php install-cli.php --ignore-platform-reqs # create data directory - sudo mkdir /var/lib/egroupware - sudo chown travis /var/lib/egroupware - ln -s /var/lib/egroupware/header.inc.php script: # install egroupware using MariaDB as domain "default" # and add an admin user "demo" with password "guest" - php doc/rpm-build/post_install.php --domain default --source_dir `pwd` --start_db '' --autostart_db '' --start_webserver '' --webserver_user '' --admin_user demo --admin_passwd guest --admin_email noreply@example.com # disable PostgreSQL install as it fails in Travis with Fatal error: Call to unimplemented native function pg_set_client_encoding # install egroupware using PostgreSQL as domain "pgsql", need some specific handling we can not create users via sql #- psql -U postgres -c 'create database egroupware'; # disable postgres install for hhvm, as there is no psql extension #- test $(phpenv version-name) = 'hhvm' || # php doc/rpm-build/post_install.php --domain pgsql --db_type pgsql --db_port 5432 --db_user postgres --db_pass '' # --source_dir `pwd` --start_db '' --autostart_db '' --start_webserver '' --webserver_user '' # install egroupware with LDAP for account and MySQL as domain "ldap" #- php doc/rpm-build/post_install.php --domain ldap --db_name ldap --db_user ldap # --account-auth ldap --ldap_suffix dc=local --ldap_admin 'cn=admin,$suffix' --ldap_admin_pw secret # --source_dir `pwd` --start_db '' --autostart_db '' --start_webserver '' --webserver_user '' # Ubuntu has problems with #!/usr/bin/env php -dapc.enable=1, it stalls forever - vendor/bin/phpunit -c doc -dapc.enable_cli=1 # do not run syntax check for hhvm, as it always fails / get terminated after 10m - test $(phpenv version-name) = 'hhvm' || ./doc/php_syntax_check.sh cache: directories: - $HOME/.composer/cache