123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- # Travis CI configuration file.
- # @link https://travis-ci.org/
- # For use with the Twenty Sixteen WordPress theme
- # @link https://github.com/WordPress/twentysixteen/
- # Declare project language and PHP versions to test against.
- # @link http://about.travis-ci.org/docs/user/languages/php/
- language: php
- # Declare versions of PHP to use. Use one decimal max.
- php:
- - "7.0"
- - "5.6"
- - "5.5"
- - "5.4"
- - "5.3"
- # Current $required_php_version for WordPress: 5.2.4
- - "5.2"
- # 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 4.4)
- # @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:
- # 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 Twenty Sixteen 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 -e 'CREATE DATABASE wordpress_test;' -uroot
- # Install CodeSniffer for WordPress Coding Standards checks.
- - mkdir php-codesniffer && curl -L https://github.com/squizlabs/PHP_CodeSniffer/archive/master.tar.gz | tar xz --strip-components=1 -C php-codesniffer
- # Install WordPress Coding Standards.
- - mkdir wordpress-coding-standards && curl -L https://github.com/WordPress-Coding-Standards/WordPress-Coding-Standards/archive/master.tar.gz | tar xz --strip-components=1 -C wordpress-coding-standards
- # Hop into CodeSniffer directory.
- - cd php-codesniffer
- # Set install path for WordPress Coding Standards
- # @link https://github.com/squizlabs/PHP_CodeSniffer/blob/4237c2fc98cc838730b76ee9cee316f99286a2a7/CodeSniffer.php#L1941
- - scripts/phpcs --config-set installed_paths ../wordpress-coding-standards
- # 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 http://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.
- - $WP_DEVELOP_DIR/php-codesniffer/scripts/phpcs -p -s -v -n . --standard=./codesniffer.ruleset.xml --extensions=php
|