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:
parent
9b43d3423e
commit
ef1b57eb79
110
.travis.yml
110
.travis.yml
|
|
@ -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
|
||||
Loading…
Reference in New Issue