Build/Test Tools: Remove the dependency on a globally installed Grunt.

The existing `"grunt": "grunt"` script in `package.json` allows for the use of `npm run grunt ...` which uses the local `grunt` binary in the project's `node_modules`.

Fixes #47380


git-svn-id: https://develop.svn.wordpress.org/trunk@45445 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
John Blackbourn 2019-05-26 19:34:24 +00:00
parent 68f7c2d7a5
commit 814aa7149f
8 changed files with 21 additions and 21 deletions

View File

@ -89,7 +89,6 @@ before_script:
- npm --version - npm --version
- node --version - node --version
- nvm install 10.13.0 - nvm install 10.13.0
- npm install -g grunt-cli
- npm install - npm install
- npm prune - npm prune
- mysql --version - mysql --version
@ -101,11 +100,10 @@ before_script:
- which phpunit - which phpunit
- phpunit --version - phpunit --version
- curl --version - curl --version
- grunt --version
- git --version - git --version
- svn --version - svn --version
- locale -a - locale -a
script: grunt $WP_TRAVISCI script: npm run grunt $WP_TRAVISCI
after_script: after_script:
- | - |
if [[ "$WP_TEST_REPORTER" == "true" ]]; then if [[ "$WP_TEST_REPORTER" == "true" ]]; then

View File

@ -11,7 +11,6 @@ branches:
install: install:
- ps: Install-Product node $env:nodejs_version - ps: Install-Product node $env:nodejs_version
- npm install npm -g - npm install npm -g
- npm install grunt-cli -g
- npm install - npm install
before_build: before_build:
@ -19,7 +18,7 @@ before_build:
- npm --version - npm --version
build_script: build_script:
- cmd: "grunt build" - cmd: "npm run build"
test: off test: off

View File

@ -19,7 +19,7 @@
"check-node-version": "3.2.0", "check-node-version": "3.2.0",
"copy-webpack-plugin": "^4.6.0", "copy-webpack-plugin": "^4.6.0",
"cssnano": "4.1.8", "cssnano": "4.1.8",
"grunt": "~1.0.3", "grunt": "1.0.4",
"grunt-banner": "^0.6.0", "grunt-banner": "^0.6.0",
"grunt-contrib-clean": "~2.0.0", "grunt-contrib-clean": "~2.0.0",
"grunt-contrib-concat": "~1.0.0", "grunt-contrib-concat": "~1.0.0",
@ -46,7 +46,7 @@
"matchdep": "~2.0.0", "matchdep": "~2.0.0",
"node-sass": "~4.12.0", "node-sass": "~4.12.0",
"source-map-loader": "^0.2.4", "source-map-loader": "^0.2.4",
"uglify-js": "^3.4.9", "uglify-js": "3.5.15",
"uglifyjs-webpack-plugin": "2.1.1", "uglifyjs-webpack-plugin": "2.1.1",
"webpack": "4.29.2", "webpack": "4.29.2",
"webpack-dev-server": "3.1.14", "webpack-dev-server": "3.1.14",
@ -113,6 +113,10 @@
"whatwg-fetch": "3.0.0" "whatwg-fetch": "3.0.0"
}, },
"scripts": { "scripts": {
"build": "grunt build",
"dev": "grunt build --dev",
"test": "grunt test",
"watch": "grunt watch",
"grunt": "grunt" "grunt": "grunt"
} }
} }

View File

@ -34,24 +34,23 @@ $die = __( 'You are running WordPress without JavaScript and CSS files. These ne
$die .= '<p>' . sprintf( $die .= '<p>' . sprintf(
/* translators: %s: npm install */ /* translators: %s: npm install */
__( 'Before running any grunt tasks you need to make sure the dependencies are installed. You can install these by running %s.' ), __( 'Before running any build tasks you need to make sure the dependencies are installed. You can install these by running %s.' ),
'<code style="color: green;">npm install</code>' '<code style="color: green;">npm install</code>'
) . '</p>'; ) . '</p>';
$die .= '<ul>'; $die .= '<ul>';
$die .= '<li>' . __( 'To build WordPress while developing, run:' ) . '<br /><br />'; $die .= '<li>' . __( 'To build WordPress while developing, run:' ) . '<br /><br />';
$die .= '<code style="color: green;">grunt build --dev</code></li>'; $die .= '<code style="color: green;">npm run dev</code></li>';
$die .= '<li>' . __( 'To build files automatically when changing the source files, run:' ) . '<br /><br />'; $die .= '<li>' . __( 'To build files automatically when changing the source files, run:' ) . '<br /><br />';
$die .= '<code style="color: green;">grunt watch</code></li>'; $die .= '<code style="color: green;">npm run watch</code></li>';
$die .= '<li>' . __( 'To create a production build of WordPress, run:' ) . '<br /><br />'; $die .= '<li>' . __( 'To create a production build of WordPress, run:' ) . '<br /><br />';
$die .= '<code style="color: green;">grunt build</code></li>'; $die .= '<code style="color: green;">npm run build</code></li>';
$die .= '</ul>'; $die .= '</ul>';
$die .= '<p>' . sprintf( $die .= '<p>' . sprintf(
/* translators: 1: NPM URL, 2: Grunt URL, 3: Handbook URL */ /* translators: 1: NPM URL, 2: Handbook URL */
__( 'This requires <a href="%1$s">NPM</a> and <a href="%2$s">Grunt</a>. <a href="%3$s">Read more about setting up your local development environment</a>.' ), __( 'This requires <a href="%1$s">NPM</a>. <a href="%2$s">Read more about setting up your local development environment</a>.' ),
'https://www.npmjs.com/get-npm', 'https://www.npmjs.com/get-npm',
'https://gruntjs.com/getting-started',
__( 'https://make.wordpress.org/core/handbook/tutorials/installing-wordpress-locally/' ) __( 'https://make.wordpress.org/core/handbook/tutorials/installing-wordpress-locally/' )
) . '</p>'; ) . '</p>';

View File

@ -446,7 +446,7 @@ function get_post_embed_html( $width, $height, $post = null ) {
} else { } else {
/* /*
* If you're looking at a src version of this file, you'll see an "include" * If you're looking at a src version of this file, you'll see an "include"
* statement below. This is used by the `grunt build` process to directly * statement below. This is used by the `npm run build` process to directly
* include a minified version of wp-embed.js, instead of using the * include a minified version of wp-embed.js, instead of using the
* file_get_contents() method from above. * file_get_contents() method from above.
* *
@ -1008,7 +1008,7 @@ function print_embed_styles() {
} else { } else {
/* /*
* If you're looking at a src version of this file, you'll see an "include" * If you're looking at a src version of this file, you'll see an "include"
* statement below. This is used by the `grunt build` process to directly * statement below. This is used by the `npm run build` process to directly
* include a minified version of wp-oembed-embed.css, instead of using the * include a minified version of wp-oembed-embed.css, instead of using the
* readfile() method from above. * readfile() method from above.
* *
@ -1039,7 +1039,7 @@ function print_embed_scripts() {
} else { } else {
/* /*
* If you're looking at a src version of this file, you'll see an "include" * If you're looking at a src version of this file, you'll see an "include"
* statement below. This is used by the `grunt build` process to directly * statement below. This is used by the `npm run build` process to directly
* include a minified version of wp-embed-template.js, instead of using the * include a minified version of wp-embed-template.js, instead of using the
* readfile() method from above. * readfile() method from above.
* *

View File

@ -5520,7 +5520,7 @@ function _print_emoji_detection_script() {
/* /*
* If you're looking at a src version of this file, you'll see an "include" * If you're looking at a src version of this file, you'll see an "include"
* statement below. This is used by the `grunt build` process to directly * statement below. This is used by the `npm run build` process to directly
* include a minified version of wp-emoji-loader.js, instead of using the * include a minified version of wp-emoji-loader.js, instead of using the
* readfile() method from above. * readfile() method from above.
* *
@ -5736,7 +5736,7 @@ function wp_staticize_emoji_for_email( $mail ) {
* Returns arrays of emoji data. * Returns arrays of emoji data.
* *
* These arrays are automatically built from the regex in twemoji.js - if they need to be updated, * These arrays are automatically built from the regex in twemoji.js - if they need to be updated,
* you should update the regex there, then run the `grunt precommit:emoji` job. * you should update the regex there, then run the `npm run grunt precommit:emoji` job.
* *
* @since 4.9.0 * @since 4.9.0
* @access private * @access private

View File

@ -47,7 +47,7 @@ if ( version_compare( tests_get_phpunit_version(), '8.0', '>=' ) ) {
} }
if ( defined( 'WP_RUN_CORE_TESTS' ) && WP_RUN_CORE_TESTS && ! is_dir( ABSPATH ) ) { if ( defined( 'WP_RUN_CORE_TESTS' ) && WP_RUN_CORE_TESTS && ! is_dir( ABSPATH ) ) {
echo "ERROR: The /build/ directory is missing! Please run `grunt build` prior to running PHPUnit.\n"; echo "ERROR: The /build/ directory is missing! Please run `npm run build` prior to running PHPUnit.\n";
exit( 1 ); exit( 1 );
} }

View File

@ -309,7 +309,7 @@ class Tests_Embed_Template extends WP_UnitTestCase {
* So this test checks for ampersands in build/wp-includes/js/wp-embed.min.js. * So this test checks for ampersands in build/wp-includes/js/wp-embed.min.js.
* In many cases, this file will not exist; in those cases, we simply skip the test. * In many cases, this file will not exist; in those cases, we simply skip the test.
* *
* So when would it be run? We have Travis CI run `grunt test` which then runs, in order, * So when would it be run? We have Travis CI run `npm run test` which then runs, in order,
* `qunit:compiled` (which runs the build) and then `phpunit`. Thus, this test will at least be * `qunit:compiled` (which runs the build) and then `phpunit`. Thus, this test will at least be
* run during continuous integration. * run during continuous integration.
* *