Update .travis.yml

* Removes WordPress install
* Adds linting of php files against parse errors
* Adds check for PHP compatibility
* Adds check for WPThemeReview rules
This commit is contained in:
IanDelMar 2020-05-03 22:55:19 +02:00
parent 9b43d3423e
commit ef1b57eb79
1 changed files with 39 additions and 71 deletions

View File

@ -4,94 +4,62 @@
# 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"
# Declare virtual environment and operating system.
# @link https://docs.travis-ci.com/user/reference/overview/#virtualization-environments
os: linux
dist: xenial
# 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
# Declare project language and PHP versions to test against.
# @link https://docs.travis-ci.com/user/languages/php/
language: php
php:
- '5.6'
- '7.0'
- '7.1'
- '7.2'
- '7.3'
- '7.4'
# 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'.
matrix:
fast_finish: true
include:
- php: 7.4
env: PHPCS=1
# Use this to prepare the build for testing.
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 composer dependencies
- composer install
# Install JSCS: JavaScript Code Style checker
# @link http://jscs.info/
- npm install -g jscs
- if [[ "$PHPCS" == 1 ]]; then npm install -g jscs; fi
# Install JSHint, a JavaScript Code Quality Tool
# @link https://jshint.com/docs/
- npm install -g jshint
- wget https://develop.svn.wordpress.org/trunk/.jshintrc
- if [[ "$PHPCS" == 1 ]]; then npm install -g jshint; fi
- if [[ "$PHPCS" == 1 ]]; then wget https://develop.svn.wordpress.org/trunk/.jshintrc; fi
# 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/*
# Validate the composer.json file.
# @link https://getcomposer.org/doc/03-cli.md#validate
- composer validate --no-check-all --strict
# Lint the PHP files against parse errors.
- composer lint:php
# Check the code against the standards as documented in the phpcs.xml file.
- if [[ "$PHPCS" == 1 ]]; then composer checks; fi
# Run the theme through JSHint
- if [[ "$PHPCS" == 1 ]]; then jshint .; fi
# Run the theme through JavaScript Code Style checker
- if [[ "$PHPCS" == 1 ]]; then jscs .; fi