# Travis CI configuration file. # @link https://travis-ci.org/ # For use with the UnderStrap WordPress theme # @link https://github.com/understrap/understrap # Declare project language and PHP versions to test against. # @link https://docs.travis-ci.com/user/languages/php/ language: php # Declare versions of PHP to use. Use one decimal max. php: - "7.3" - "5.6" # Ditch sudo and use containers. # @link http://docs.travis-ci.com/user/migrating-from-legacy/#Why-migrate-to-container-based-infrastructure%3F # @link http://docs.travis-ci.com/user/workers/container-based-infrastructure/#Routing-your-build-to-container-based-infrastructure sudo: false # Declare which versions of WordPress to test against. # Also declare whether or not to test in Multisite. env: # Trunk (current version in development is 5.3) # @link https://github.com/WordPress/WordPress - WP_VERSION=master WP_MULTISITE=0 # Use this to prepare your build for testing. # e.g. copy database configurations, environment variables, etc. # Failures in this section will result in build status 'errored'. before_script: # Speed up build time by disabling Xdebug. - phpenv config-rm xdebug.ini || echo 'No xdebug config.' # Set up temporary paths. - export PHPCS_DIR=/tmp/phpcs - export WPCS_DIR=/tmp/wpcs - export PHPCOMPAT_DIR=/tmp/phpcompatibility # Set up WordPress installation. - export WP_DEVELOP_DIR=/tmp/wordpress/ - mkdir -p $WP_DEVELOP_DIR # Use the Git mirror of WordPress. - git clone --depth=1 --branch="$WP_VERSION" git://develop.git.wordpress.org/ $WP_DEVELOP_DIR # Set up UnderStrap theme information. - theme_slug=$(basename $(pwd)) - theme_dir=$WP_DEVELOP_DIR/src/wp-content/themes/$theme_slug - cd .. - mv $theme_slug $theme_dir # Set up WordPress configuration. - cd $WP_DEVELOP_DIR - echo $WP_DEVELOP_DIR - cp wp-tests-config-sample.php wp-tests-config.php - sed -i "s/youremptytestdbnamehere/wordpress_test/" wp-tests-config.php - sed -i "s/yourusernamehere/root/" wp-tests-config.php - sed -i "s/yourpasswordhere//" wp-tests-config.php # Create WordPress database. #- mysql -u root -e "CREATE DATABASE wordpress_test;" # Install CodeSniffer for WordPress Coding Standards checks. - git clone -b master --depth 1 https://github.com/squizlabs/PHP_CodeSniffer.git $PHPCS_DIR # Install WordPress Coding Standards. - git clone -b master --depth 1 https://github.com/WordPress-Coding-Standards/WordPress-Coding-Standards.git $WPCS_DIR # Install PHP Compatibility sniffs. - git clone -b master --depth 1 https://github.com/wimg/PHPCompatibility.git $PHPCOMPAT_DIR # Set install path for PHPCS sniffs. # @link https://github.com/squizlabs/PHP_CodeSniffer/blob/4237c2fc98cc838730b76ee9cee316f99286a2a7/CodeSniffer.php#L1941 - $PHPCS_DIR/bin/phpcs --config-set installed_paths $WPCS_DIR,$PHPCOMPAT_DIR # Hop into themes directory. - cd $theme_dir # After CodeSniffer install you should refresh your path. - phpenv rehash # Install JSCS: JavaScript Code Style checker # @link http://jscs.info/ - npm install -g jscs # Install JSHint, a JavaScript Code Quality Tool # @link https://jshint.com/docs/ - npm install -g jshint - wget https://develop.svn.wordpress.org/trunk/.jshintrc # Run test script commands. # Default is specific to project language. # All commands must exit with code 0 on success. Anything else is considered failure. script: # Search theme for PHP syntax errors. - find . \( -name '*.php' \) -exec php -lf {} \; # Run the theme through JSHint - jshint . # Run the theme through JavaScript Code Style checker - jscs . # WordPress Coding Standards # @link https://github.com/WordPress-Coding-Standards/WordPress-Coding-Standards # @link http://pear.php.net/package/PHP_CodeSniffer/ # -p flag: Show progress of the run. # -s flag: Show sniff codes in all reports. # -v flag: Print verbose output. # -n flag: Do not print warnings (shortcut for --warning-severity=0) # --standard: Use WordPress as the standard. # --extensions: Only sniff PHP files. - $PHPCS_DIR/bin/phpcs -p -s -v -n . --extensions=php --ignore=*/woocommerce/*,*/src/*