Skip to content
Extraits de code Groupes Projets
.travis.yml 6,86 ko
Newer Older
  • Learn to ignore specific revisions
  • # do not edit this file manually, instead run the generate:travis-yml console command
    
    # if you are a Piwik core developer, edit this template file to auto generate the .travis.yml: https://github.com/piwik/piwik/blob/master/plugins/TestRunner/templates/travis.yml.twig
    
    
    # when modifying this file, please consider whether your changes should apply to plugin .travis.yml files. if not, check whether the pluginName twig var is empty,
    # otherwise your changes will be synced with every plugin that uses an auto generated .travis.yml
    
    # also please test generation before committing by running ./console generate:travis-yml --core and ./console generate:travis-yml --plugin=CustomAlerts
    # and making sure the .travis.yml files are changed correctly
    
    Thomas Steur's avatar
    Thomas Steur a validé
    services:
      - redis-server
    
    
          - python2.6
          - python2.6-dev
          - nginx
          - realpath
          - lftp
    
    Fabian Becker's avatar
    Fabian Becker a validé
    # Separate different test suites
    
        - TEST_SUITE=IntegrationTests MYSQL_ADAPTER=PDO_MYSQL
        - TEST_SUITE=UnitTests MYSQL_ADAPTER=PDO_MYSQL
    
        - TEST_SUITE=JavascriptTests MYSQL_ADAPTER=PDO_MYSQL
    
        - TEST_SUITE=AngularJSTests MYSQL_ADAPTER=PDO_MYSQL SKIP_COMPOSER_INSTALL=1
    
        # All tests after another
        - TEST_SUITE=AllTests MYSQL_ADAPTER=PDO_MYSQL
        - TEST_SUITE=AllTests MYSQL_ADAPTER=MYSQLI
    
        - TEST_SUITE=UITests MYSQL_ADAPTER=PDO_MYSQL UITEST_EXTRA_OPTIONS="--run-first-half-only"
        - TEST_SUITE=UITests MYSQL_ADAPTER=PDO_MYSQL UITEST_EXTRA_OPTIONS="--run-second-half-only"
    
        - PIWIK_ROOT_DIR=$TRAVIS_BUILD_DIR
    
        - secure: "AMhZmPZx4SUcuZRBzGHlQPxzM4D8FvFB3UThDa52gbi9KIBrwcumzV2VGi6B\n5fgjwtB4XTE1In7qhY2HMikPWBmWYYOQ5QcMPJsqqHt4iMmahx8WKzne6NOk\nNpqAuje/fulNGeP2LJZi0nrub3Fh4VwXaOvpNloKNQN/2JuqPtM="
        - secure: "DySde80fX3dw0osGY5s5lGiGLjMleUkkONsuRDC4xjT1hAQP94FGHpPXVZV8\nAQY0s8MQmcK2eRLOQrmE9Bh1XXbGqh40s66XhSWq0hulFHxQH5OLaZXccFeu\n5WxGkHXnNDIc+CVhXW/IIbHZPO1K6hffS8fuvP1o6mYgxwFL6Xw="
    
        - secure: "CW73pDjcaabpSL7bWiWIQLydKmvLzA1gWNv/zK0VcAKezQtCAQbqpIY1+B56wOhkaCWa7P+xdd2gUWEtvvdRKEC0sZcgCdHD5pQx390e5PWCMQTFO+doAElI4w4DMATCbH890Wcw2rotiZcjlkPYY+urIpUlcRsl6mMtBVQuQ9c="
    
    matrix:
    
      fast_finish: true
    
      allow_failures:
        - php: hhvm
    
      exclude:
    
        # Run test suites separately only on PHP 5.6 with PDO
    
          env: TEST_SUITE=SystemTests MYSQL_ADAPTER=PDO_MYSQL
    
          env: TEST_SUITE=IntegrationTests MYSQL_ADAPTER=PDO_MYSQL
    
          env: TEST_SUITE=AllTests MYSQL_ADAPTER=PDO_MYSQL
    
        - php: 7
          env: TEST_SUITE=AllTests MYSQL_ADAPTER=PDO_MYSQL
    
          env: TEST_SUITE=UnitTests MYSQL_ADAPTER=PDO_MYSQL
        - php: hhvm
          env: TEST_SUITE=SystemTests MYSQL_ADAPTER=PDO_MYSQL
        - php: hhvm
          env: TEST_SUITE=IntegrationTests MYSQL_ADAPTER=PDO_MYSQL
        - php: hhvm
          env: TEST_SUITE=UnitTests MYSQL_ADAPTER=PDO_MYSQL
    
          env: TEST_SUITE=UITests MYSQL_ADAPTER=PDO_MYSQL UITEST_EXTRA_OPTIONS="--run-first-half-only"
        - php: 5.6
          env: TEST_SUITE=UITests MYSQL_ADAPTER=PDO_MYSQL UITEST_EXTRA_OPTIONS="--run-second-half-only"
    
        # run all tests not on PHP 5.6 and run MySQLI tests only on 5.6
        - php: 5.6
    
          env: TEST_SUITE=AllTests MYSQL_ADAPTER=PDO_MYSQL
    
          env: TEST_SUITE=AllTests MYSQL_ADAPTER=MYSQLI
    
        - php: 7
          env: TEST_SUITE=AllTests MYSQL_ADAPTER=MYSQLI
    
        - php: hhvm
          env: TEST_SUITE=AllTests MYSQL_ADAPTER=MYSQLI
    
        # Javascript tests need to run only on one PHP version
    
          env: TEST_SUITE=JavascriptTests MYSQL_ADAPTER=PDO_MYSQL
    
        - php: hhvm
    
          env: TEST_SUITE=JavascriptTests MYSQL_ADAPTER=PDO_MYSQL
    
          env: TEST_SUITE=JavascriptTests MYSQL_ADAPTER=PDO_MYSQL
    
        # AngularJS tests need to run only on one PHP version
    
    fabiocarneiro's avatar
    fabiocarneiro a validé
          env: TEST_SUITE=AngularJSTests MYSQL_ADAPTER=PDO_MYSQL SKIP_COMPOSER_INSTALL=1
    
    fabiocarneiro's avatar
    fabiocarneiro a validé
          env: TEST_SUITE=AngularJSTests MYSQL_ADAPTER=PDO_MYSQL SKIP_COMPOSER_INSTALL=1
    
        - php: 7
          env: TEST_SUITE=AngularJSTests MYSQL_ADAPTER=PDO_MYSQL SKIP_COMPOSER_INSTALL=1
    
    script: $PIWIK_ROOT_DIR/tests/travis/travis.sh
    
      # Disable it until this is in master, otherwise we have to create a branch for travis submodule
      #- export GENERATE_TRAVIS_YML_COMMAND="php ./tests/travis/generator/main.php generate:travis-yml --core --verbose"
      #- '[[ "$TRAVIS_JOB_NUMBER" != *.1 || "$TRAVIS_PULL_REQUEST" != "false" ]] || ./tests/travis/autoupdate_travis_yml.sh'
    
      # travis now complains about this failing 9 times out of 10, so removing it
      #- travis_retry composer self-update
    
      - '[ "$SKIP_COMPOSER_INSTALL" == "1" ] || travis_retry composer install'
    
      - if [[ "$TRAVIS_PHP_VERSION" != 7* ]]; then phpenv config-rm xdebug.ini; fi
    
      # add always_populate_raw_post_data=-1 to php.ini
      - echo "always_populate_raw_post_data=-1" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
    
    
      # disable opcache to avoid random failures on travis
      - echo "opcache.enable=0" >> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini
    
    
      - mysql --version
      - mysql -e "SELECT VERSION();"
    
      - mysql -e "SET GLOBAL sql_mode = 'NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES'" # Travis default
    
    mattab's avatar
    mattab a validé
      # try to avoid mysql has gone away errors
      - mysql -e "SET GLOBAL wait_timeout = 36000;"
    
      - mysql -e "SET GLOBAL max_allowed_packet = 134209536;"
      - mysql -e "SHOW VARIABLES LIKE 'max_allowed_packet';"
      - mysql -e "SHOW VARIABLES LIKE 'wait_timeout';"
    
    mattab's avatar
    mattab a validé
      - mysql -e "SELECT @@sql_mode;"
    
      # - mysql -e "SHOW GLOBAL VARIABLES;"
    
    
    Fabian Becker's avatar
    Fabian Becker a validé
      - uname -a
      - date
    
    mattab's avatar
    mattab a validé
      - php -r "var_dump(gd_info());"
    
    Benaka Moorthi's avatar
    Benaka Moorthi a validé
      - mysql -e 'create database piwik_tests;'
    
    Fabian Becker's avatar
    Fabian Becker a validé
      - ./tests/travis/prepare.sh
    
      - ./tests/travis/setup_webserver.sh
    
      # change directory back to root travis dir
    
      - cd $PIWIK_ROOT_DIR
    
    
      # output contents of files w/ debugging info to screen
    
      - cat $PIWIK_ROOT_DIR/tests/travis/error.log
    
      - cat $PIWIK_ROOT_DIR/tmp/php-fpm.log
      - cat $PIWIK_ROOT_DIR/tmp/logs/piwik.log
      - cat $PIWIK_ROOT_DIR/config/config.ini.php
    
      # upload test artifacts (for debugging travis failures)
    
    after_success:
      - cd $PIWIK_ROOT_DIR
      - ./tests/travis/generate_docs.sh
    
    
    mattab's avatar
    mattab a validé
      slack:
        rooms:
          - piwik:3HWhNh21qPfDACQXTrJOb0mW
          - piwikpro:7OABSbDrywSTo2nv9lD2svXG
    
        on_success: change
    
        on_failure: change
    
        template:
          - "%{repository} (%{commit}) : %{message} %{foo} "
    
          - "Build details: %{build_url}"