diff --git a/CHANGELOG.md b/CHANGELOG.md index 1ebe74cdf..4197c82f7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,23 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. +### [4.0.3](https://github.com/webpack/webpack-dev-middleware/compare/v4.0.1...v4.0.3) (2021-01-12) + + +### Bug Fixes + +* output `stats` to `stdout` instead `stderr`, how does `webpack-cli`, if you need hide `stats` from output please use `{ stats: false }` or `{ stats: 'none' }` ([4de0f97](https://github.com/webpack/webpack-dev-middleware/commit/4de0f97596d52a7182ac108a9b9865462fca54fe)) +* colors are working for `stats` ([4de0f97](https://github.com/webpack/webpack-dev-middleware/commit/4de0f97596d52a7182ac108a9b9865462fca54fe)) +* schema description ([#783](https://github.com/webpack/webpack-dev-middleware/issues/783)) ([f9ce2b2](https://github.com/webpack/webpack-dev-middleware/commit/f9ce2b2537c331901e230c5a8452f4b91d45c713)) +* skip `Content-type header` on unknown types ([#809](https://github.com/webpack/webpack-dev-middleware/issues/809)) ([5c9eee5](https://github.com/webpack/webpack-dev-middleware/commit/5c9eee549be264f6df202d960b7cd10bfff7f97d)) + +### [4.0.2](https://github.com/webpack/webpack-dev-middleware/compare/v4.0.1...v4.0.2) (2020-11-10) + + +### Bug Fixes + +* compatibility with the `headers` option ([#763](https://github.com/webpack/webpack-dev-middleware/issues/763)) ([7c4cac5](https://github.com/webpack/webpack-dev-middleware/commit/7c4cac538dc7facf3c3334863ec3a49b14e16630)) + ### [4.0.1](https://github.com/webpack/webpack-dev-middleware/compare/v4.0.0...v4.0.1) (2020-11-09) diff --git a/README.md b/README.md index 7f856a8f9..89451a21e 100644 --- a/README.md +++ b/README.md @@ -66,7 +66,7 @@ The middleware accepts an `options` Object. The following is a property referenc Type: `Array` Default: `[ 'GET', 'HEAD' ]` -This property allows a user to pass the list of HTTP request methods accepted by the server. +This property allows a user to pass the list of HTTP request methods accepted by the middleware\*\*. ### headers @@ -107,26 +107,20 @@ For more information about `publicPath`, please see [the webpack documentation]( Type: `Boolean` Default: `undefined` -Instructs the module to enable or disable the server-side rendering mode. Please -see [Server-Side Rendering](#server-side-rendering) for more information. +Instructs the module to enable or disable the server-side rendering mode. +Please see [Server-Side Rendering](#server-side-rendering) for more information. ### writeToDisk Type: `Boolean|Function` Default: `false` -If `true`, the option will instruct the module to write files to the configured -location on disk as specified in your `webpack` config file. _Setting -`writeToDisk: true` won't change the behavior of the `webpack-dev-middleware`, -and bundle files accessed through the browser will still be served from memory._ -This option provides the same capabilities as the -[`WriteFilePlugin`](https://github.com/gajus/write-file-webpack-plugin/pulls). +If `true`, the option will instruct the module to write files to the configured location on disk as specified in your `webpack` config file. +_Setting `writeToDisk: true` won't change the behavior of the `webpack-dev-middleware`, and bundle files accessed through the browser will still be served from memory._ +This option provides the same capabilities as the [`WriteFilePlugin`](https://github.com/gajus/write-file-webpack-plugin/pulls). -This option also accepts a `Function` value, which can be used to filter which -files are written to disk. The function follows the same premise as -[`Array#filter`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter) -in which a return value of `false` _will not_ write the file, and a return value -of `true` _will_ write the file to disk. eg. +This option also accepts a `Function` value, which can be used to filter which files are written to disk. +The function follows the same premise as [`Array#filter`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter) in which a return value of `false` _will not_ write the file, and a return value of `true` _will_ write the file to disk. eg. ```js const webpack = require('webpack'); @@ -203,7 +197,7 @@ app.use(instance); setTimeout(() => { // After a short delay the configuration is changed and a banner plugin is added // to the config - compiler.apply(new webpack.BannerPlugin('A new banner')); + new webpack.BannerPlugin('A new banner').apply(compiler); // Recompile the bundle with the banner plugin: instance.invalidate(); diff --git a/jest.config.js b/jest.config.js index a891025a3..4619a0cd3 100644 --- a/jest.config.js +++ b/jest.config.js @@ -1,9 +1,8 @@ -'use strict'; - module.exports = { collectCoverage: false, coveragePathIgnorePatterns: ['test', '/node_modules'], moduleFileExtensions: ['js', 'json'], testMatch: ['**/test/**/*.test.js'], setupFilesAfterEnv: ['/setupTest.js'], + snapshotResolver: './test/helpers/snapshotResolver.js', }; diff --git a/package-lock.json b/package-lock.json index 5be1350f2..018b35fc2 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,16 +1,16 @@ { "name": "webpack-dev-middleware", - "version": "4.0.1", + "version": "4.0.3", "lockfileVersion": 1, "requires": true, "dependencies": { "@babel/cli": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.12.1.tgz", - "integrity": "sha512-eRJREyrfAJ2r42Iaxe8h3v6yyj1wu9OyosaUHW6UImjGf9ahGL9nsFNh7OCopvtcPL8WnEo7tp78wrZaZ6vG9g==", + "version": "7.12.10", + "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.12.10.tgz", + "integrity": "sha512-+y4ZnePpvWs1fc/LhZRTHkTesbXkyBYuOB+5CyodZqrEuETXi3zOVfpAQIdgC3lXbHLTDG9dQosxR9BhvLKDLQ==", "dev": true, "requires": { - "@nicolo-ribaudo/chokidar-2": "^2.1.8", + "@nicolo-ribaudo/chokidar-2": "2.1.8-no-fsevents", "chokidar": "^3.4.0", "commander": "^4.0.1", "convert-source-map": "^1.1.0", @@ -23,48 +23,47 @@ } }, "@babel/code-frame": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", - "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", + "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", "dev": true, "requires": { "@babel/highlight": "^7.10.4" } }, "@babel/compat-data": { - "version": "7.12.5", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.12.5.tgz", - "integrity": "sha512-DTsS7cxrsH3by8nqQSpFSyjSfSYl57D6Cf4q8dW3LK83tBKBDCkfcay1nYkXq1nIHXnpX8WMMb/O25HOy3h1zg==", + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.12.7.tgz", + "integrity": "sha512-YaxPMGs/XIWtYqrdEOZOCPsVWfEoriXopnsz3/i7apYPXQ3698UFhS6dVT1KN5qOsWmVgw/FOrmQgpRaZayGsw==", "dev": true }, "@babel/core": { - "version": "7.12.3", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.12.3.tgz", - "integrity": "sha512-0qXcZYKZp3/6N2jKYVxZv0aNCsxTSVCiK72DTiTYZAu7sjg73W0/aynWjMbiGd87EQL4WyA8reiJVh92AVla9g==", + "version": "7.12.10", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.12.10.tgz", + "integrity": "sha512-eTAlQKq65zHfkHZV0sIVODCPGVgoo1HdBlbSLi9CqOzuZanMv2ihzY+4paiKr1mH+XmYESMAmJ/dpZ68eN6d8w==", "dev": true, "requires": { "@babel/code-frame": "^7.10.4", - "@babel/generator": "^7.12.1", + "@babel/generator": "^7.12.10", "@babel/helper-module-transforms": "^7.12.1", - "@babel/helpers": "^7.12.1", - "@babel/parser": "^7.12.3", - "@babel/template": "^7.10.4", - "@babel/traverse": "^7.12.1", - "@babel/types": "^7.12.1", + "@babel/helpers": "^7.12.5", + "@babel/parser": "^7.12.10", + "@babel/template": "^7.12.7", + "@babel/traverse": "^7.12.10", + "@babel/types": "^7.12.10", "convert-source-map": "^1.7.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.1", "json5": "^2.1.2", "lodash": "^4.17.19", - "resolve": "^1.3.2", "semver": "^5.4.1", "source-map": "^0.5.0" }, "dependencies": { "debug": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", - "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", "dev": true, "requires": { "ms": "2.1.2" @@ -79,23 +78,23 @@ } }, "@babel/generator": { - "version": "7.12.5", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.12.5.tgz", - "integrity": "sha512-m16TQQJ8hPt7E+OS/XVQg/7U184MLXtvuGbCdA7na61vha+ImkyyNM/9DDA0unYCVZn3ZOhng+qz48/KBOT96A==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.12.11.tgz", + "integrity": "sha512-Ggg6WPOJtSi8yYQvLVjG8F/TlpWDlKx0OpS4Kt+xMQPs5OaGYWy+v1A+1TvxI6sAMGZpKWWoAQ1DaeQbImlItA==", "dev": true, "requires": { - "@babel/types": "^7.12.5", + "@babel/types": "^7.12.11", "jsesc": "^2.5.1", "source-map": "^0.5.0" } }, "@babel/helper-annotate-as-pure": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.10.4.tgz", - "integrity": "sha512-XQlqKQP4vXFB7BN8fEEerrmYvHp3fK/rBkRFz9jaJbzK0B1DSfej9Kc7ZzE8Z/OnId1jpJdNAZ3BFQjWG68rcA==", + "version": "7.12.10", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.12.10.tgz", + "integrity": "sha512-XplmVbC1n+KY6jL8/fgLVXXUauDIB+lD5+GsQEh6F6GBF1dq1qy4DP4yXWzDKcoqXB3X58t61e85Fitoww4JVQ==", "dev": true, "requires": { - "@babel/types": "^7.10.4" + "@babel/types": "^7.12.10" } }, "@babel/helper-builder-binary-assignment-operator-visitor": { @@ -134,13 +133,12 @@ } }, "@babel/helper-create-regexp-features-plugin": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.12.1.tgz", - "integrity": "sha512-rsZ4LGvFTZnzdNZR5HZdmJVuXK8834R5QkF3WvcnBhrlVtF0HSIUC6zbreL9MgjTywhKokn8RIYRiq99+DLAxA==", + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.12.7.tgz", + "integrity": "sha512-idnutvQPdpbduutvi3JVfEgcVIHooQnhvhx0Nk9isOINOIGYkZea1Pk2JlJRiUnMefrlvr0vkByATBY/mB4vjQ==", "dev": true, "requires": { "@babel/helper-annotate-as-pure": "^7.10.4", - "@babel/helper-regex": "^7.10.4", "regexpu-core": "^4.7.1" } }, @@ -165,23 +163,23 @@ } }, "@babel/helper-function-name": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz", - "integrity": "sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.12.11.tgz", + "integrity": "sha512-AtQKjtYNolKNi6nNNVLQ27CP6D9oFR6bq/HPYSizlzbp7uC1M59XJe8L+0uXjbIaZaUJF99ruHqVGiKXU/7ybA==", "dev": true, "requires": { - "@babel/helper-get-function-arity": "^7.10.4", - "@babel/template": "^7.10.4", - "@babel/types": "^7.10.4" + "@babel/helper-get-function-arity": "^7.12.10", + "@babel/template": "^7.12.7", + "@babel/types": "^7.12.11" } }, "@babel/helper-get-function-arity": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz", - "integrity": "sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==", + "version": "7.12.10", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.12.10.tgz", + "integrity": "sha512-mm0n5BPjR06wh9mPQaDdXWDoll/j5UpCAPl1x8fS71GHm7HA6Ua2V4ylG1Ju8lvcTOietbPNNPaSilKj+pj+Ag==", "dev": true, "requires": { - "@babel/types": "^7.10.4" + "@babel/types": "^7.12.10" } }, "@babel/helper-hoist-variables": { @@ -194,12 +192,12 @@ } }, "@babel/helper-member-expression-to-functions": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.12.1.tgz", - "integrity": "sha512-k0CIe3tXUKTRSoEx1LQEPFU9vRQfqHtl+kf8eNnDqb4AUJEy5pz6aIiog+YWtVm2jpggjS1laH68bPsR+KWWPQ==", + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.12.7.tgz", + "integrity": "sha512-DCsuPyeWxeHgh1Dus7APn7iza42i/qXqiFPWyBDdOFtvS581JQePsc1F/nD+fHrcswhLlRc2UpYS1NwERxZhHw==", "dev": true, "requires": { - "@babel/types": "^7.12.1" + "@babel/types": "^7.12.7" } }, "@babel/helper-module-imports": { @@ -229,12 +227,12 @@ } }, "@babel/helper-optimise-call-expression": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.10.4.tgz", - "integrity": "sha512-n3UGKY4VXwXThEiKrgRAoVPBMqeoPgHVqiHZOanAJCG9nQUL2pLRQirUzl0ioKclHGpGqRgIOkgcIJaIWLpygg==", + "version": "7.12.10", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.12.10.tgz", + "integrity": "sha512-4tpbU0SrSTjjt65UMWSrUOPZTsgvPgGG4S8QSTNHacKzpS51IVWGDj0yCwyeZND/i+LSN2g/O63jEXEWm49sYQ==", "dev": true, "requires": { - "@babel/types": "^7.10.4" + "@babel/types": "^7.12.10" } }, "@babel/helper-plugin-utils": { @@ -243,15 +241,6 @@ "integrity": "sha512-O4KCvQA6lLiMU9l2eawBPMf1xPP8xPfB3iEQw150hOVTqj/rfXz0ThTb4HEzqQfs2Bmo5Ay8BzxfzVtBrr9dVg==", "dev": true }, - "@babel/helper-regex": { - "version": "7.10.5", - "resolved": "https://registry.npmjs.org/@babel/helper-regex/-/helper-regex-7.10.5.tgz", - "integrity": "sha512-68kdUAzDrljqBrio7DYAEgCoJHxppJOERHOgOrDN7WjOzP0ZQ1LsSDRXcemzVZaLvjaJsJEESb6qt+znNuENDg==", - "dev": true, - "requires": { - "lodash": "^4.17.19" - } - }, "@babel/helper-remap-async-to-generator": { "version": "7.12.1", "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.12.1.tgz", @@ -264,15 +253,15 @@ } }, "@babel/helper-replace-supers": { - "version": "7.12.5", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.12.5.tgz", - "integrity": "sha512-5YILoed0ZyIpF4gKcpZitEnXEJ9UoDRki1Ey6xz46rxOzfNMAhVIJMoune1hmPVxh40LRv1+oafz7UsWX+vyWA==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.12.11.tgz", + "integrity": "sha512-q+w1cqmhL7R0FNzth/PLLp2N+scXEK/L2AHbXUyydxp828F4FEa5WcVoqui9vFRiHDQErj9Zof8azP32uGVTRA==", "dev": true, "requires": { - "@babel/helper-member-expression-to-functions": "^7.12.1", - "@babel/helper-optimise-call-expression": "^7.10.4", - "@babel/traverse": "^7.12.5", - "@babel/types": "^7.12.5" + "@babel/helper-member-expression-to-functions": "^7.12.7", + "@babel/helper-optimise-call-expression": "^7.12.10", + "@babel/traverse": "^7.12.10", + "@babel/types": "^7.12.11" } }, "@babel/helper-simple-access": { @@ -294,24 +283,24 @@ } }, "@babel/helper-split-export-declaration": { - "version": "7.11.0", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.11.0.tgz", - "integrity": "sha512-74Vejvp6mHkGE+m+k5vHY93FX2cAtrw1zXrZXRlG4l410Nm9PxfEiVTn1PjDPV5SnmieiueY4AFg2xqhNFuuZg==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.12.11.tgz", + "integrity": "sha512-LsIVN8j48gHgwzfocYUSkO/hjYAOJqlpJEc7tGXcIm4cubjVUf8LGW6eWRyxEu7gA25q02p0rQUWoCI33HNS5g==", "dev": true, "requires": { - "@babel/types": "^7.11.0" + "@babel/types": "^7.12.11" } }, "@babel/helper-validator-identifier": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", - "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", + "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", "dev": true }, "@babel/helper-validator-option": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.12.1.tgz", - "integrity": "sha512-YpJabsXlJVWP0USHjnC/AQDTLlZERbON577YUVO/wLpqyj6HAtVYnWaQaN0iUN+1/tWn3c+uKKXjRut5115Y2A==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.12.11.tgz", + "integrity": "sha512-TBFCyj939mFSdeX7U7DDj32WtzYY7fDcalgq8v3fBZMNOJQNn7nOYzMaUCiPxPYfCup69mtIpqlKgMZLvQ8Xhw==", "dev": true }, "@babel/helper-wrap-function": { @@ -349,15 +338,15 @@ } }, "@babel/parser": { - "version": "7.12.5", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.12.5.tgz", - "integrity": "sha512-FVM6RZQ0mn2KCf1VUED7KepYeUWoVShczewOCfm3nzoBybaih51h+sYVVGthW9M6lPByEPTQf+xm27PBdlpwmQ==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.12.11.tgz", + "integrity": "sha512-N3UxG+uuF4CMYoNj8AhnbAcJF0PiuJ9KHuy1lQmkYsxTer/MAH9UBNHsBoAX/4s6NvlDD047No8mYVGGzLL4hg==", "dev": true }, "@babel/plugin-proposal-async-generator-functions": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.12.1.tgz", - "integrity": "sha512-d+/o30tJxFxrA1lhzJqiUcEJdI6jKlNregCv5bASeGf2Q4MXmnwH7viDo7nhx1/ohf09oaH8j1GVYG/e3Yqk6A==", + "version": "7.12.12", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.12.12.tgz", + "integrity": "sha512-nrz9y0a4xmUrRq51bYkWJIO5SBZyG2ys2qinHsN0zHDHVsUaModrkpyWWWXfGqYQmOL3x9sQIcTNN/pBGpo09A==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.10.4", @@ -426,9 +415,9 @@ } }, "@babel/plugin-proposal-numeric-separator": { - "version": "7.12.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.12.5.tgz", - "integrity": "sha512-UiAnkKuOrCyjZ3sYNHlRlfuZJbBHknMQ9VMwVeX97Ofwx7RpD6gS2HfqTCh8KNUQgcOm8IKt103oR4KIjh7Q8g==", + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.12.7.tgz", + "integrity": "sha512-8c+uy0qmnRTeukiGsjLGy6uVs/TFjJchGXUeBqlG4VWYOdJWkhhVPdQ3uHwbmalfJwv2JsV0qffXP4asRfL2SQ==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.10.4", @@ -457,9 +446,9 @@ } }, "@babel/plugin-proposal-optional-chaining": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.12.1.tgz", - "integrity": "sha512-c2uRpY6WzaVDzynVY9liyykS+kVU+WRZPMPYpkelXH8KBt1oXoI89kPbZKKG/jDT5UK92FTW2fZkZaJhdiBabw==", + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.12.7.tgz", + "integrity": "sha512-4ovylXZ0PWmwoOvhU2vhnzVNnm88/Sm9nx7V8BPgMvAzn5zDou3/Awy0EjglyubVHasJj+XCEkr/r1X3P5elCA==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.10.4", @@ -643,9 +632,9 @@ } }, "@babel/plugin-transform-block-scoping": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.12.1.tgz", - "integrity": "sha512-zJyAC9sZdE60r1nVQHblcfCj29Dh2Y0DOvlMkcqSo0ckqjiCwNiUezUKw+RjOCwGfpLRwnAeQ2XlLpsnGkvv9w==", + "version": "7.12.12", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.12.12.tgz", + "integrity": "sha512-VOEPQ/ExOVqbukuP7BYJtI5ZxxsmegTwzZ04j1aF0dkSypGo9XpDHuOrABsJu+ie+penpSJheDJ11x1BEZNiyQ==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.10.4" @@ -881,13 +870,12 @@ } }, "@babel/plugin-transform-sticky-regex": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.12.1.tgz", - "integrity": "sha512-CiUgKQ3AGVk7kveIaPEET1jNDhZZEl1RPMWdTBE1799bdz++SwqDHStmxfCtDfBhQgCl38YRiSnrMuUMZIWSUQ==", + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.12.7.tgz", + "integrity": "sha512-VEiqZL5N/QvDbdjfYQBhruN0HYjSPjC4XkeqW4ny/jNtH9gcbgaqBIXYEZCNnESMAGs0/K/R7oFGMhOyu/eIxg==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.10.4", - "@babel/helper-regex": "^7.10.4" + "@babel/helper-plugin-utils": "^7.10.4" } }, "@babel/plugin-transform-template-literals": { @@ -900,9 +888,9 @@ } }, "@babel/plugin-transform-typeof-symbol": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.12.1.tgz", - "integrity": "sha512-EPGgpGy+O5Kg5pJFNDKuxt9RdmTgj5sgrus2XVeMp/ZIbOESadgILUbm50SNpghOh3/6yrbsH+NB5+WJTmsA7Q==", + "version": "7.12.10", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.12.10.tgz", + "integrity": "sha512-JQ6H8Rnsogh//ijxspCjc21YPd3VLVoYtAwv3zQmqAt8YGYUtdo5usNhdl4b9/Vir2kPFZl6n1h0PfUz4hJhaA==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.10.4" @@ -928,16 +916,16 @@ } }, "@babel/preset-env": { - "version": "7.12.1", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.12.1.tgz", - "integrity": "sha512-H8kxXmtPaAGT7TyBvSSkoSTUK6RHh61So05SyEbpmr0MCZrsNYn7mGMzzeYoOUCdHzww61k8XBft2TaES+xPLg==", + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.12.11.tgz", + "integrity": "sha512-j8Tb+KKIXKYlDBQyIOy4BLxzv1NUOwlHfZ74rvW+Z0Gp4/cI2IMDPBWAgWceGcE7aep9oL/0K9mlzlMGxA8yNw==", "dev": true, "requires": { - "@babel/compat-data": "^7.12.1", - "@babel/helper-compilation-targets": "^7.12.1", - "@babel/helper-module-imports": "^7.12.1", + "@babel/compat-data": "^7.12.7", + "@babel/helper-compilation-targets": "^7.12.5", + "@babel/helper-module-imports": "^7.12.5", "@babel/helper-plugin-utils": "^7.10.4", - "@babel/helper-validator-option": "^7.12.1", + "@babel/helper-validator-option": "^7.12.11", "@babel/plugin-proposal-async-generator-functions": "^7.12.1", "@babel/plugin-proposal-class-properties": "^7.12.1", "@babel/plugin-proposal-dynamic-import": "^7.12.1", @@ -945,10 +933,10 @@ "@babel/plugin-proposal-json-strings": "^7.12.1", "@babel/plugin-proposal-logical-assignment-operators": "^7.12.1", "@babel/plugin-proposal-nullish-coalescing-operator": "^7.12.1", - "@babel/plugin-proposal-numeric-separator": "^7.12.1", + "@babel/plugin-proposal-numeric-separator": "^7.12.7", "@babel/plugin-proposal-object-rest-spread": "^7.12.1", "@babel/plugin-proposal-optional-catch-binding": "^7.12.1", - "@babel/plugin-proposal-optional-chaining": "^7.12.1", + "@babel/plugin-proposal-optional-chaining": "^7.12.7", "@babel/plugin-proposal-private-methods": "^7.12.1", "@babel/plugin-proposal-unicode-property-regex": "^7.12.1", "@babel/plugin-syntax-async-generators": "^7.8.0", @@ -966,7 +954,7 @@ "@babel/plugin-transform-arrow-functions": "^7.12.1", "@babel/plugin-transform-async-to-generator": "^7.12.1", "@babel/plugin-transform-block-scoped-functions": "^7.12.1", - "@babel/plugin-transform-block-scoping": "^7.12.1", + "@babel/plugin-transform-block-scoping": "^7.12.11", "@babel/plugin-transform-classes": "^7.12.1", "@babel/plugin-transform-computed-properties": "^7.12.1", "@babel/plugin-transform-destructuring": "^7.12.1", @@ -990,14 +978,14 @@ "@babel/plugin-transform-reserved-words": "^7.12.1", "@babel/plugin-transform-shorthand-properties": "^7.12.1", "@babel/plugin-transform-spread": "^7.12.1", - "@babel/plugin-transform-sticky-regex": "^7.12.1", + "@babel/plugin-transform-sticky-regex": "^7.12.7", "@babel/plugin-transform-template-literals": "^7.12.1", - "@babel/plugin-transform-typeof-symbol": "^7.12.1", + "@babel/plugin-transform-typeof-symbol": "^7.12.10", "@babel/plugin-transform-unicode-escapes": "^7.12.1", "@babel/plugin-transform-unicode-regex": "^7.12.1", "@babel/preset-modules": "^0.1.3", - "@babel/types": "^7.12.1", - "core-js-compat": "^3.6.2", + "@babel/types": "^7.12.11", + "core-js-compat": "^3.8.0", "semver": "^5.5.0" } }, @@ -1024,37 +1012,37 @@ } }, "@babel/template": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.10.4.tgz", - "integrity": "sha512-ZCjD27cGJFUB6nmCB1Enki3r+L5kJveX9pq1SvAUKoICy6CZ9yD8xO086YXdYhvNjBdnekm4ZnaP5yC8Cs/1tA==", + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.12.7.tgz", + "integrity": "sha512-GkDzmHS6GV7ZeXfJZ0tLRBhZcMcY0/Lnb+eEbXDBfCAcZCjrZKe6p3J4we/D24O9Y8enxWAg1cWwof59yLh2ow==", "dev": true, "requires": { "@babel/code-frame": "^7.10.4", - "@babel/parser": "^7.10.4", - "@babel/types": "^7.10.4" + "@babel/parser": "^7.12.7", + "@babel/types": "^7.12.7" } }, "@babel/traverse": { - "version": "7.12.5", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.12.5.tgz", - "integrity": "sha512-xa15FbQnias7z9a62LwYAA5SZZPkHIXpd42C6uW68o8uTuua96FHZy1y61Va5P/i83FAAcMpW8+A/QayntzuqA==", + "version": "7.12.12", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.12.12.tgz", + "integrity": "sha512-s88i0X0lPy45RrLM8b9mz8RPH5FqO9G9p7ti59cToE44xFm1Q+Pjh5Gq4SXBbtb88X7Uy7pexeqRIQDDMNkL0w==", "dev": true, "requires": { - "@babel/code-frame": "^7.10.4", - "@babel/generator": "^7.12.5", - "@babel/helper-function-name": "^7.10.4", - "@babel/helper-split-export-declaration": "^7.11.0", - "@babel/parser": "^7.12.5", - "@babel/types": "^7.12.5", + "@babel/code-frame": "^7.12.11", + "@babel/generator": "^7.12.11", + "@babel/helper-function-name": "^7.12.11", + "@babel/helper-split-export-declaration": "^7.12.11", + "@babel/parser": "^7.12.11", + "@babel/types": "^7.12.12", "debug": "^4.1.0", "globals": "^11.1.0", "lodash": "^4.17.19" }, "dependencies": { "debug": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", - "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", "dev": true, "requires": { "ms": "2.1.2" @@ -1069,12 +1057,12 @@ } }, "@babel/types": { - "version": "7.12.6", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.12.6.tgz", - "integrity": "sha512-hwyjw6GvjBLiyy3W0YQf0Z5Zf4NpYejUnKFcfcUhZCSffoBBp30w6wP2Wn6pk31jMYZvcOrB/1b7cGXvEoKogA==", + "version": "7.12.12", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.12.12.tgz", + "integrity": "sha512-lnIX7piTxOH22xE7fDXDbSHg9MM1/6ORnafpJmov5rs0kX5g4BZxeXNJLXsMRiO0U5Rb8/FvMS6xlTnTHvxonQ==", "dev": true, "requires": { - "@babel/helper-validator-identifier": "^7.10.4", + "@babel/helper-validator-identifier": "^7.12.11", "lodash": "^4.17.19", "to-fast-properties": "^2.0.0" } @@ -1434,12 +1422,12 @@ } }, "p-limit": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.0.2.tgz", - "integrity": "sha512-iwqZSOoWIW+Ew4kAGUlN16J4M7OB3ysMLSZtnhmqx7njIHFPlxWBX8xo3lVTyFVq6mI/lL9qt2IsN1sHwaxJkg==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", "dev": true, "requires": { - "p-try": "^2.0.0" + "yocto-queue": "^0.1.0" } }, "p-locate": { @@ -1460,9 +1448,9 @@ "dev": true }, "@eslint/eslintrc": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.2.1.tgz", - "integrity": "sha512-XRUeBZ5zBWLYgSANMpThFddrZZkEbGHgUdt5UJjZfnlN9BGCiUBrf+nvbRupSjMvqzwnQN0qwCmOxITt1cfywA==", + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.2.2.tgz", + "integrity": "sha512-EfB5OHNYp1F4px/LI/FEnGylop7nOqkQ1LRzCM0KccA2U8tvV8w01KBv37LbO7nW4H+YhKyo2LcJhRwjjV17QQ==", "dev": true, "requires": { "ajv": "^6.12.4", @@ -1478,9 +1466,9 @@ }, "dependencies": { "debug": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", - "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", "dev": true, "requires": { "ms": "2.1.2" @@ -2118,61 +2106,48 @@ } }, "@nicolo-ribaudo/chokidar-2": { - "version": "2.1.8", - "resolved": "https://registry.npmjs.org/@nicolo-ribaudo/chokidar-2/-/chokidar-2-2.1.8.tgz", - "integrity": "sha512-FohwULwAebCUKi/akMFyGi7jfc7JXTeMHzKxuP3umRd9mK/2Y7/SMBSI2jX+YLopPXi+PF9l307NmpfxTdCegA==", + "version": "2.1.8-no-fsevents", + "resolved": "https://registry.npmjs.org/@nicolo-ribaudo/chokidar-2/-/chokidar-2-2.1.8-no-fsevents.tgz", + "integrity": "sha512-+nb9vWloHNNMFHjGofEam3wopE3m1yuambrrd/fnPc+lFOMB9ROTqQlche9ByFWNkdNqfSgR/kkQtQ8DzEWt2w==", "dev": true, "optional": true, "requires": { - "chokidar": "2.1.8" - }, - "dependencies": { - "chokidar": { - "version": "2.1.8", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz", - "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==", - "dev": true, - "optional": true, - "requires": { - "anymatch": "^2.0.0", - "async-each": "^1.0.1", - "braces": "^2.3.2", - "fsevents": "^1.2.7", - "glob-parent": "^3.1.0", - "inherits": "^2.0.3", - "is-binary-path": "^1.0.0", - "is-glob": "^4.0.0", - "normalize-path": "^3.0.0", - "path-is-absolute": "^1.0.0", - "readdirp": "^2.2.1", - "upath": "^1.1.1" - } - } + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" } }, "@nodelib/fs.scandir": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.3.tgz", - "integrity": "sha512-eGmwYQn3gxo4r7jdQnkrrN6bY478C3P+a/y72IJukF8LjB6ZHeB3c+Ehacj3sYeSmUXGlnA67/PmbM9CVwL7Dw==", + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.4.tgz", + "integrity": "sha512-33g3pMJk3bg5nXbL/+CY6I2eJDzZAni49PfJnL5fghPTggPvBd/pFNSgJsdAgWptuFu7qq/ERvOYFlhvsLTCKA==", "dev": true, "requires": { - "@nodelib/fs.stat": "2.0.3", + "@nodelib/fs.stat": "2.0.4", "run-parallel": "^1.1.9" } }, "@nodelib/fs.stat": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.3.tgz", - "integrity": "sha512-bQBFruR2TAwoevBEd/NWMoAAtNGzTRgdrqnYCc7dhzfoNvqPzLyqlEQnzZ3kVnNrSp25iyxE00/3h2fqGAGArA==", + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.4.tgz", + "integrity": "sha512-IYlHJA0clt2+Vg7bccq+TzRdJvv19c2INqBSsoOLp1je7xjtr7J26+WXR72MCdvU9q1qTzIWDfhMf+DRvQJK4Q==", "dev": true }, "@nodelib/fs.walk": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.4.tgz", - "integrity": "sha512-1V9XOY4rDW0rehzbrcqAmHnz8e7SKvX27gh8Gt2WgB0+pdzdiLV83p72kZPU+jvMbS1qU5mauP2iOvO8rhmurQ==", + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.6.tgz", + "integrity": "sha512-8Broas6vTtW4GIXTAHDoE32hnN2M5ykgCpWGbuXHQ15vEMqr23pB76e/GZcYsZCHALv50ktd24qhEyKr6wBtow==", "dev": true, "requires": { - "@nodelib/fs.scandir": "2.1.3", + "@nodelib/fs.scandir": "2.1.4", "fastq": "^1.6.0" } }, @@ -2217,9 +2192,9 @@ } }, "@types/babel__template": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.0.3.tgz", - "integrity": "sha512-uCoznIPDmnickEi6D0v11SBpW0OuVqHJCa7syXqQHy5uktSCreIlt0iglsCnmvz8yCb38hGcWeseA8cWJSwv5Q==", + "version": "7.4.0", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.0.tgz", + "integrity": "sha512-NTPErx4/FiPCGScH7foPyr+/1Dkzkni+rHiYHHoTjvwou7AQzJkNeD60A9CXRy+ZEN2B1bggmkTMCDb+Mv5k+A==", "dev": true, "requires": { "@babel/parser": "^7.1.0", @@ -2227,18 +2202,18 @@ } }, "@types/babel__traverse": { - "version": "7.0.15", - "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.0.15.tgz", - "integrity": "sha512-Pzh9O3sTK8V6I1olsXpCfj2k/ygO2q1X0vhhnDrEQyYLHZesWz+zMZMVcwXLCYf0U36EtmyYaFGPfXlTtDHe3A==", + "version": "7.11.0", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.11.0.tgz", + "integrity": "sha512-kSjgDMZONiIfSH1Nxcr5JIRMwUetDki63FSQfpTCz8ogF3Ulqm8+mr5f78dUYs6vMiB6gBusQqfQmBvHZj/lwg==", "dev": true, "requires": { "@babel/types": "^7.3.0" } }, "@types/eslint": { - "version": "7.2.4", - "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-7.2.4.tgz", - "integrity": "sha512-YCY4kzHMsHoyKspQH+nwSe+70Kep7Vjt2X+dZe5Vs2vkRudqtoFoUIv1RlJmZB8Hbp7McneupoZij4PadxsK5Q==", + "version": "7.2.6", + "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-7.2.6.tgz", + "integrity": "sha512-I+1sYH+NPQ3/tVqCeUSBwTE/0heyvtXqpIopUUArlBm0Kpocb8FbMa3AZ/ASKIFpN3rnEx932TTXDbt9OXsNDw==", "dev": true, "requires": { "@types/estree": "*", @@ -2328,9 +2303,9 @@ "dev": true }, "@types/node": { - "version": "14.14.6", - "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.6.tgz", - "integrity": "sha512-6QlRuqsQ/Ox/aJEQWBEJG7A9+u7oSYl3mem/K8IzxXG/kAGbV1YPD9Bg9Zw3vyxC/YP+zONKwy8hGkSt1jxFMw==", + "version": "14.14.20", + "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.20.tgz", + "integrity": "sha512-Y93R97Ouif9JEOWPIUyU+eyIdyRqQR0I8Ez1dzku4hDx34NWh4HbtIc3WNzwB1Y9ULvNGeu5B8h8bVL5cAk4/A==", "dev": true }, "@types/normalize-package-data": { @@ -2346,9 +2321,9 @@ "dev": true }, "@types/prettier": { - "version": "2.1.5", - "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.1.5.tgz", - "integrity": "sha512-UEyp8LwZ4Dg30kVU2Q3amHHyTn1jEdhCIE59ANed76GaT1Vp76DD3ZWSAxgCrw6wJ0TqeoBpqmfUHiUDPs//HQ==", + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.1.6.tgz", + "integrity": "sha512-6gOkRe7OIioWAXfnO/2lFiv+SJichKVSys1mSsgyrYHSEjk8Ctv4tSR/Odvnu+HWlH2C8j53dahU03XmQdd5fA==", "dev": true }, "@types/stack-utils": { @@ -2358,192 +2333,163 @@ "dev": true }, "@types/yargs": { - "version": "15.0.9", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.9.tgz", - "integrity": "sha512-HmU8SeIRhZCWcnRskCs36Q1Q00KBV6Cqh/ora8WN1+22dY07AZdn6Gel8QZ3t26XYPImtcL8WV/eqjhVmMEw4g==", + "version": "15.0.12", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.12.tgz", + "integrity": "sha512-f+fD/fQAo3BCbCDlrUpznF1A5Zp9rB0noS5vnoormHSIPFKL0Z2DcUJ3Gxp5ytH4uLRNxy7AwYUC9exZzqGMAw==", "dev": true, "requires": { "@types/yargs-parser": "*" } }, "@types/yargs-parser": { - "version": "15.0.0", - "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-15.0.0.tgz", - "integrity": "sha512-FA/BWv8t8ZWJ+gEOnLLd8ygxH/2UFbAvgEonyfN6yWGLKc7zVjbpl2Y4CTjid9h2RfgPP6SEt6uHwEOply00yw==", + "version": "20.2.0", + "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-20.2.0.tgz", + "integrity": "sha512-37RSHht+gzzgYeobbG+KWryeAW8J33Nhr69cjTqSYymXVZEN9NbRYWoYlRtDhHKPVT1FyNKwaTPC1NynKZpzRA==", "dev": true }, "@webassemblyjs/ast": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.9.0.tgz", - "integrity": "sha512-C6wW5L+b7ogSDVqymbkkvuW9kruN//YisMED04xzeBBqjHa2FYnmvOlS6Xj68xWQRgWvI9cIglsjFowH/RJyEA==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.0.tgz", + "integrity": "sha512-kX2W49LWsbthrmIRMbQZuQDhGtjyqXfEmmHyEi4XWnSZtPmxY0+3anPIzsnRb45VH/J55zlOfWvZuY47aJZTJg==", "dev": true, "requires": { - "@webassemblyjs/helper-module-context": "1.9.0", - "@webassemblyjs/helper-wasm-bytecode": "1.9.0", - "@webassemblyjs/wast-parser": "1.9.0" + "@webassemblyjs/helper-numbers": "1.11.0", + "@webassemblyjs/helper-wasm-bytecode": "1.11.0" } }, "@webassemblyjs/floating-point-hex-parser": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.9.0.tgz", - "integrity": "sha512-TG5qcFsS8QB4g4MhrxK5TqfdNe7Ey/7YL/xN+36rRjl/BlGE/NcBvJcqsRgCP6Z92mRE+7N50pRIi8SmKUbcQA==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.0.tgz", + "integrity": "sha512-Q/aVYs/VnPDVYvsCBL/gSgwmfjeCb4LW8+TMrO3cSzJImgv8lxxEPM2JA5jMrivE7LSz3V+PFqtMbls3m1exDA==", "dev": true }, "@webassemblyjs/helper-api-error": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.9.0.tgz", - "integrity": "sha512-NcMLjoFMXpsASZFxJ5h2HZRcEhDkvnNFOAKneP5RbKRzaWJN36NC4jqQHKwStIhGXu5mUWlUUk7ygdtrO8lbmw==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.0.tgz", + "integrity": "sha512-baT/va95eXiXb2QflSx95QGT5ClzWpGaa8L7JnJbgzoYeaA27FCvuBXU758l+KXWRndEmUXjP0Q5fibhavIn8w==", "dev": true }, "@webassemblyjs/helper-buffer": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.9.0.tgz", - "integrity": "sha512-qZol43oqhq6yBPx7YM3m9Bv7WMV9Eevj6kMi6InKOuZxhw+q9hOkvq5e/PpKSiLfyetpaBnogSbNCfBwyB00CA==", - "dev": true - }, - "@webassemblyjs/helper-code-frame": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.9.0.tgz", - "integrity": "sha512-ERCYdJBkD9Vu4vtjUYe8LZruWuNIToYq/ME22igL+2vj2dQ2OOujIZr3MEFvfEaqKoVqpsFKAGsRdBSBjrIvZA==", - "dev": true, - "requires": { - "@webassemblyjs/wast-printer": "1.9.0" - } - }, - "@webassemblyjs/helper-fsm": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-fsm/-/helper-fsm-1.9.0.tgz", - "integrity": "sha512-OPRowhGbshCb5PxJ8LocpdX9Kl0uB4XsAjl6jH/dWKlk/mzsANvhwbiULsaiqT5GZGT9qinTICdj6PLuM5gslw==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.0.tgz", + "integrity": "sha512-u9HPBEl4DS+vA8qLQdEQ6N/eJQ7gT7aNvMIo8AAWvAl/xMrcOSiI2M0MAnMCy3jIFke7bEee/JwdX1nUpCtdyA==", "dev": true }, - "@webassemblyjs/helper-module-context": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-module-context/-/helper-module-context-1.9.0.tgz", - "integrity": "sha512-MJCW8iGC08tMk2enck1aPW+BE5Cw8/7ph/VGZxwyvGbJwjktKkDK7vy7gAmMDx88D7mhDTCNKAW5tED+gZ0W8g==", + "@webassemblyjs/helper-numbers": { + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.0.tgz", + "integrity": "sha512-DhRQKelIj01s5IgdsOJMKLppI+4zpmcMQ3XboFPLwCpSNH6Hqo1ritgHgD0nqHeSYqofA6aBN/NmXuGjM1jEfQ==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.9.0" + "@webassemblyjs/floating-point-hex-parser": "1.11.0", + "@webassemblyjs/helper-api-error": "1.11.0", + "@xtuc/long": "4.2.2" } }, "@webassemblyjs/helper-wasm-bytecode": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.9.0.tgz", - "integrity": "sha512-R7FStIzyNcd7xKxCZH5lE0Bqy+hGTwS3LJjuv1ZVxd9O7eHCedSdrId/hMOd20I+v8wDXEn+bjfKDLzTepoaUw==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.0.tgz", + "integrity": "sha512-MbmhvxXExm542tWREgSFnOVo07fDpsBJg3sIl6fSp9xuu75eGz5lz31q7wTLffwL3Za7XNRCMZy210+tnsUSEA==", "dev": true }, "@webassemblyjs/helper-wasm-section": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.9.0.tgz", - "integrity": "sha512-XnMB8l3ek4tvrKUUku+IVaXNHz2YsJyOOmz+MMkZvh8h1uSJpSen6vYnw3IoQ7WwEuAhL8Efjms1ZWjqh2agvw==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.0.tgz", + "integrity": "sha512-3Eb88hcbfY/FCukrg6i3EH8H2UsD7x8Vy47iVJrP967A9JGqgBVL9aH71SETPx1JrGsOUVLo0c7vMCN22ytJew==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.9.0", - "@webassemblyjs/helper-buffer": "1.9.0", - "@webassemblyjs/helper-wasm-bytecode": "1.9.0", - "@webassemblyjs/wasm-gen": "1.9.0" + "@webassemblyjs/ast": "1.11.0", + "@webassemblyjs/helper-buffer": "1.11.0", + "@webassemblyjs/helper-wasm-bytecode": "1.11.0", + "@webassemblyjs/wasm-gen": "1.11.0" } }, "@webassemblyjs/ieee754": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.9.0.tgz", - "integrity": "sha512-dcX8JuYU/gvymzIHc9DgxTzUUTLexWwt8uCTWP3otys596io0L5aW02Gb1RjYpx2+0Jus1h4ZFqjla7umFniTg==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.0.tgz", + "integrity": "sha512-KXzOqpcYQwAfeQ6WbF6HXo+0udBNmw0iXDmEK5sFlmQdmND+tr773Ti8/5T/M6Tl/413ArSJErATd8In3B+WBA==", "dev": true, "requires": { "@xtuc/ieee754": "^1.2.0" } }, "@webassemblyjs/leb128": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.9.0.tgz", - "integrity": "sha512-ENVzM5VwV1ojs9jam6vPys97B/S65YQtv/aanqnU7D8aSoHFX8GyhGg0CMfyKNIHBuAVjy3tlzd5QMMINa7wpw==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.0.tgz", + "integrity": "sha512-aqbsHa1mSQAbeeNcl38un6qVY++hh8OpCOzxhixSYgbRfNWcxJNJQwe2rezK9XEcssJbbWIkblaJRwGMS9zp+g==", "dev": true, "requires": { "@xtuc/long": "4.2.2" } }, "@webassemblyjs/utf8": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.9.0.tgz", - "integrity": "sha512-GZbQlWtopBTP0u7cHrEx+73yZKrQoBMpwkGEIqlacljhXCkVM1kMQge/Mf+csMJAjEdSwhOyLAS0AoR3AG5P8w==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.0.tgz", + "integrity": "sha512-A/lclGxH6SpSLSyFowMzO/+aDEPU4hvEiooCMXQPcQFPPJaYcPQNKGOCLUySJsYJ4trbpr+Fs08n4jelkVTGVw==", "dev": true }, "@webassemblyjs/wasm-edit": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.9.0.tgz", - "integrity": "sha512-FgHzBm80uwz5M8WKnMTn6j/sVbqilPdQXTWraSjBwFXSYGirpkSWE2R9Qvz9tNiTKQvoKILpCuTjBKzOIm0nxw==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.0.tgz", + "integrity": "sha512-JHQ0damXy0G6J9ucyKVXO2j08JVJ2ntkdJlq1UTiUrIgfGMmA7Ik5VdC/L8hBK46kVJgujkBIoMtT8yVr+yVOQ==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.9.0", - "@webassemblyjs/helper-buffer": "1.9.0", - "@webassemblyjs/helper-wasm-bytecode": "1.9.0", - "@webassemblyjs/helper-wasm-section": "1.9.0", - "@webassemblyjs/wasm-gen": "1.9.0", - "@webassemblyjs/wasm-opt": "1.9.0", - "@webassemblyjs/wasm-parser": "1.9.0", - "@webassemblyjs/wast-printer": "1.9.0" + "@webassemblyjs/ast": "1.11.0", + "@webassemblyjs/helper-buffer": "1.11.0", + "@webassemblyjs/helper-wasm-bytecode": "1.11.0", + "@webassemblyjs/helper-wasm-section": "1.11.0", + "@webassemblyjs/wasm-gen": "1.11.0", + "@webassemblyjs/wasm-opt": "1.11.0", + "@webassemblyjs/wasm-parser": "1.11.0", + "@webassemblyjs/wast-printer": "1.11.0" } }, "@webassemblyjs/wasm-gen": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.9.0.tgz", - "integrity": "sha512-cPE3o44YzOOHvlsb4+E9qSqjc9Qf9Na1OO/BHFy4OI91XDE14MjFN4lTMezzaIWdPqHnsTodGGNP+iRSYfGkjA==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.0.tgz", + "integrity": "sha512-BEUv1aj0WptCZ9kIS30th5ILASUnAPEvE3tVMTrItnZRT9tXCLW2LEXT8ezLw59rqPP9klh9LPmpU+WmRQmCPQ==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.9.0", - "@webassemblyjs/helper-wasm-bytecode": "1.9.0", - "@webassemblyjs/ieee754": "1.9.0", - "@webassemblyjs/leb128": "1.9.0", - "@webassemblyjs/utf8": "1.9.0" + "@webassemblyjs/ast": "1.11.0", + "@webassemblyjs/helper-wasm-bytecode": "1.11.0", + "@webassemblyjs/ieee754": "1.11.0", + "@webassemblyjs/leb128": "1.11.0", + "@webassemblyjs/utf8": "1.11.0" } }, "@webassemblyjs/wasm-opt": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.9.0.tgz", - "integrity": "sha512-Qkjgm6Anhm+OMbIL0iokO7meajkzQD71ioelnfPEj6r4eOFuqm4YC3VBPqXjFyyNwowzbMD+hizmprP/Fwkl2A==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.0.tgz", + "integrity": "sha512-tHUSP5F4ywyh3hZ0+fDQuWxKx3mJiPeFufg+9gwTpYp324mPCQgnuVKwzLTZVqj0duRDovnPaZqDwoyhIO8kYg==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.9.0", - "@webassemblyjs/helper-buffer": "1.9.0", - "@webassemblyjs/wasm-gen": "1.9.0", - "@webassemblyjs/wasm-parser": "1.9.0" + "@webassemblyjs/ast": "1.11.0", + "@webassemblyjs/helper-buffer": "1.11.0", + "@webassemblyjs/wasm-gen": "1.11.0", + "@webassemblyjs/wasm-parser": "1.11.0" } }, "@webassemblyjs/wasm-parser": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.9.0.tgz", - "integrity": "sha512-9+wkMowR2AmdSWQzsPEjFU7njh8HTO5MqO8vjwEHuM+AMHioNqSBONRdr0NQQ3dVQrzp0s8lTcYqzUdb7YgELA==", - "dev": true, - "requires": { - "@webassemblyjs/ast": "1.9.0", - "@webassemblyjs/helper-api-error": "1.9.0", - "@webassemblyjs/helper-wasm-bytecode": "1.9.0", - "@webassemblyjs/ieee754": "1.9.0", - "@webassemblyjs/leb128": "1.9.0", - "@webassemblyjs/utf8": "1.9.0" - } - }, - "@webassemblyjs/wast-parser": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-parser/-/wast-parser-1.9.0.tgz", - "integrity": "sha512-qsqSAP3QQ3LyZjNC/0jBJ/ToSxfYJ8kYyuiGvtn/8MK89VrNEfwj7BPQzJVHi0jGTRK2dGdJ5PRqhtjzoww+bw==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.0.tgz", + "integrity": "sha512-6L285Sgu9gphrcpDXINvm0M9BskznnzJTE7gYkjDbxET28shDqp27wpruyx3C2S/dvEwiigBwLA1cz7lNUi0kw==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.9.0", - "@webassemblyjs/floating-point-hex-parser": "1.9.0", - "@webassemblyjs/helper-api-error": "1.9.0", - "@webassemblyjs/helper-code-frame": "1.9.0", - "@webassemblyjs/helper-fsm": "1.9.0", - "@xtuc/long": "4.2.2" + "@webassemblyjs/ast": "1.11.0", + "@webassemblyjs/helper-api-error": "1.11.0", + "@webassemblyjs/helper-wasm-bytecode": "1.11.0", + "@webassemblyjs/ieee754": "1.11.0", + "@webassemblyjs/leb128": "1.11.0", + "@webassemblyjs/utf8": "1.11.0" } }, "@webassemblyjs/wast-printer": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.9.0.tgz", - "integrity": "sha512-2J0nE95rHXHyQ24cWjMKJ1tqB/ds8z/cyeOZxJhcb+rW+SQASVjuznUSmdz5GpVJTzU8JkhYut0D3siFDD6wsA==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.0.tgz", + "integrity": "sha512-Fg5OX46pRdTgB7rKIUojkh9vXaVN6sGYCnEiJN1GYkb0RPwShZXp6KTDqmoMdQPKhcroOXh3fEzmkWmCYaKYhQ==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.9.0", - "@webassemblyjs/wast-parser": "1.9.0", + "@webassemblyjs/ast": "1.11.0", "@xtuc/long": "4.2.2" } }, @@ -2790,13 +2736,15 @@ "dev": true }, "array-includes": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.1.tgz", - "integrity": "sha512-c2VXaCHl7zPsvpkFsw4nxvFie4fh1ur9bpcgsVkIjqn0H/Xwdg+7fv3n2r/isyS8EBj5b06M9kHyZuIr4El6WQ==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.2.tgz", + "integrity": "sha512-w2GspexNQpx+PutG3QpT437/BenZBj0M/MZGn5mzv/MofYqo0xmRHzn4lFsoDlWJ+THYsGJmFlW68WlDFx7VRw==", "dev": true, "requires": { + "call-bind": "^1.0.0", "define-properties": "^1.1.3", - "es-abstract": "^1.17.0", + "es-abstract": "^1.18.0-next.1", + "get-intrinsic": "^1.0.1", "is-string": "^1.0.5" } }, @@ -2813,13 +2761,14 @@ "dev": true }, "array.prototype.flat": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.3.tgz", - "integrity": "sha512-gBlRZV0VSmfPIeWfuuy56XZMvbVfbEUnOXUvt3F/eUUUSyzlgLxhEX4YAEpxNAogRGehPSnfXyPtYyKAhkzQhQ==", + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.4.tgz", + "integrity": "sha512-4470Xi3GAPAjZqFcljX2xzckv1qeKPizoNkiS0+O4IoPR2ZNpcjE0pkhdihlDouK+x6QOast26B4Q/O9DJnwSg==", "dev": true, "requires": { + "call-bind": "^1.0.0", "define-properties": "^1.1.3", - "es-abstract": "^1.17.0-next.1" + "es-abstract": "^1.18.0-next.1" } }, "arrify": { @@ -2850,9 +2799,9 @@ "dev": true }, "astral-regex": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", - "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", + "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", "dev": true }, "async-each": { @@ -3059,9 +3008,9 @@ } }, "babel-preset-current-node-syntax": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.0.tgz", - "integrity": "sha512-mGkvkpocWJes1CmMKtgGUwCeeq0pOhALyymozzDWYomHTbDLwueDYG6p4TK1YOeYHCzBzYPsWkgTto10JubI1Q==", + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", + "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", "dev": true, "requires": { "@babel/plugin-syntax-async-generators": "^7.8.4", @@ -3171,16 +3120,6 @@ "dev": true, "optional": true }, - "bindings": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", - "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", - "dev": true, - "optional": true, - "requires": { - "file-uri-to-path": "1.0.0" - } - }, "body-parser": { "version": "1.19.0", "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", @@ -3245,16 +3184,16 @@ "dev": true }, "browserslist": { - "version": "4.14.7", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.14.7.tgz", - "integrity": "sha512-BSVRLCeG3Xt/j/1cCGj1019Wbty0H+Yvu2AOuZSuoaUWn3RatbL33Cxk+Q4jRMRAbOm0p7SLravLjpnT6s0vzQ==", + "version": "4.16.1", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.16.1.tgz", + "integrity": "sha512-UXhDrwqsNcpTYJBTZsbGATDxZbiVDsx6UjpmRUmtnP10pr8wAYr5LgFoEFw9ixriQH2mv/NX2SfGzE/o8GndLA==", "dev": true, "requires": { - "caniuse-lite": "^1.0.30001157", + "caniuse-lite": "^1.0.30001173", "colorette": "^1.2.1", - "electron-to-chromium": "^1.3.591", + "electron-to-chromium": "^1.3.634", "escalade": "^3.1.1", - "node-releases": "^1.1.66" + "node-releases": "^1.1.69" } }, "bser": { @@ -3329,9 +3268,9 @@ } }, "caniuse-lite": { - "version": "1.0.30001157", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001157.tgz", - "integrity": "sha512-gOerH9Wz2IRZ2ZPdMfBvyOi3cjaz4O4dgNwPGzx8EhqAs4+2IL/O+fJsbt+znSigujoZG8bVcIAUM/I/E5K3MA==", + "version": "1.0.30001173", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001173.tgz", + "integrity": "sha512-R3aqmjrICdGCTAnSXtNyvWYMK3YtV5jwudbq0T7nN9k4kmE4CBuwPqyJ+KBzepSTh0huivV2gLbSMEzTTmfeYw==", "dev": true }, "capture-exit": { @@ -3367,14 +3306,14 @@ "dev": true }, "chokidar": { - "version": "3.4.3", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.4.3.tgz", - "integrity": "sha512-DtM3g7juCXQxFVSNPNByEC2+NImtBuxQQvWlHunpJIS5Ocr0lG306cC7FCi7cEA0fzmybPUIl4txBIobk1gGOQ==", + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.0.tgz", + "integrity": "sha512-JgQM9JS92ZbFR4P90EvmzNpSGhpPBGBSj10PILeDyYFwp4h2/D9OM03wsJ4zW1fEp4ka2DGrnUeD7FuvQ2aZ2Q==", "dev": true, "requires": { "anymatch": "~3.1.1", "braces": "~3.0.2", - "fsevents": "~2.1.2", + "fsevents": "~2.3.1", "glob-parent": "~5.1.0", "is-binary-path": "~2.1.0", "is-glob": "~4.0.1", @@ -3416,13 +3355,6 @@ "to-regex-range": "^5.0.1" } }, - "fsevents": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", - "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", - "dev": true, - "optional": true - }, "glob-parent": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", @@ -3545,12 +3477,6 @@ "color-convert": "^2.0.1" } }, - "astral-regex": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", - "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", - "dev": true - }, "color-convert": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", @@ -3630,8 +3556,7 @@ "colorette": { "version": "1.2.1", "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.2.1.tgz", - "integrity": "sha512-puCDz0CzydiSYOrnXpz/PKd69zRrribezjtE9yd4zvytoRc8+RY/KJPvtPFKZS3E3wP6neGyMe0vOTlHO5L3Pw==", - "dev": true + "integrity": "sha512-puCDz0CzydiSYOrnXpz/PKd69zRrribezjtE9yd4zvytoRc8+RY/KJPvtPFKZS3E3wP6neGyMe0vOTlHO5L3Pw==" }, "combined-stream": { "version": "1.0.8", @@ -3744,21 +3669,21 @@ "dev": true }, "conventional-changelog": { - "version": "3.1.23", - "resolved": "https://registry.npmjs.org/conventional-changelog/-/conventional-changelog-3.1.23.tgz", - "integrity": "sha512-sScUu2NHusjRC1dPc5p8/b3kT78OYr95/Bx7Vl8CPB8tF2mG1xei5iylDTRjONV5hTlzt+Cn/tBWrKdd299b7A==", - "dev": true, - "requires": { - "conventional-changelog-angular": "^5.0.11", - "conventional-changelog-atom": "^2.0.7", - "conventional-changelog-codemirror": "^2.0.7", - "conventional-changelog-conventionalcommits": "^4.4.0", - "conventional-changelog-core": "^4.2.0", - "conventional-changelog-ember": "^2.0.8", - "conventional-changelog-eslint": "^3.0.8", - "conventional-changelog-express": "^2.0.5", - "conventional-changelog-jquery": "^3.0.10", - "conventional-changelog-jshint": "^2.0.8", + "version": "3.1.24", + "resolved": "https://registry.npmjs.org/conventional-changelog/-/conventional-changelog-3.1.24.tgz", + "integrity": "sha512-ed6k8PO00UVvhExYohroVPXcOJ/K1N0/drJHx/faTH37OIZthlecuLIRX/T6uOp682CAoVoFpu+sSEaeuH6Asg==", + "dev": true, + "requires": { + "conventional-changelog-angular": "^5.0.12", + "conventional-changelog-atom": "^2.0.8", + "conventional-changelog-codemirror": "^2.0.8", + "conventional-changelog-conventionalcommits": "^4.5.0", + "conventional-changelog-core": "^4.2.1", + "conventional-changelog-ember": "^2.0.9", + "conventional-changelog-eslint": "^3.0.9", + "conventional-changelog-express": "^2.0.6", + "conventional-changelog-jquery": "^3.0.11", + "conventional-changelog-jshint": "^2.0.9", "conventional-changelog-preset-loader": "^2.3.4" } }, @@ -3808,9 +3733,9 @@ } }, "conventional-changelog-core": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/conventional-changelog-core/-/conventional-changelog-core-4.2.1.tgz", - "integrity": "sha512-8cH8/DEoD3e5Q6aeogdR5oaaKs0+mG6+f+Om0ZYt3PNv7Zo0sQhu4bMDRsqAF+UTekTAtP1W/C41jH/fkm8Jtw==", + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/conventional-changelog-core/-/conventional-changelog-core-4.2.2.tgz", + "integrity": "sha512-7pDpRUiobQDNkwHyJG7k9f6maPo9tfPzkSWbRq97GGiZqisElhnvUZSvyQH20ogfOjntB5aadvv6NNcKL1sReg==", "dev": true, "requires": { "add-stream": "^1.0.0", @@ -3818,7 +3743,7 @@ "conventional-commits-parser": "^3.2.0", "dateformat": "^3.0.0", "get-pkg-repo": "^1.0.0", - "git-raw-commits": "2.0.0", + "git-raw-commits": "^2.0.8", "git-remote-origin-url": "^2.0.0", "git-semver-tags": "^4.1.1", "lodash": "^4.17.15", @@ -3830,32 +3755,6 @@ "through2": "^4.0.0" }, "dependencies": { - "camelcase": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", - "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", - "dev": true - }, - "camelcase-keys": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-4.2.0.tgz", - "integrity": "sha1-oqpfsa9oh1glnDLBQUJteJI7m3c=", - "dev": true, - "requires": { - "camelcase": "^4.1.0", - "map-obj": "^2.0.0", - "quick-lru": "^1.0.0" - } - }, - "dargs": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/dargs/-/dargs-4.1.0.tgz", - "integrity": "sha1-A6nbtLXC8Tm/FK5T8LiipqhvThc=", - "dev": true, - "requires": { - "number-is-nan": "^1.0.0" - } - }, "find-up": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", @@ -3865,43 +3764,12 @@ "locate-path": "^2.0.0" } }, - "git-raw-commits": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/git-raw-commits/-/git-raw-commits-2.0.0.tgz", - "integrity": "sha512-w4jFEJFgKXMQJ0H0ikBk2S+4KP2VEjhCvLCNqbNRQC8BgGWgLKNCO7a9K9LI+TVT7Gfoloje502sEnctibffgg==", - "dev": true, - "requires": { - "dargs": "^4.0.1", - "lodash.template": "^4.0.2", - "meow": "^4.0.0", - "split2": "^2.0.0", - "through2": "^2.0.0" - }, - "dependencies": { - "through2": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", - "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", - "dev": true, - "requires": { - "readable-stream": "~2.3.6", - "xtend": "~4.0.1" - } - } - } - }, "hosted-git-info": { "version": "2.8.8", "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz", "integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==", "dev": true }, - "indent-string": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-3.2.0.tgz", - "integrity": "sha1-Sl/W0nzDMvN+VBmlBNu4NxBckok=", - "dev": true - }, "load-json-file": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", @@ -3924,53 +3792,6 @@ "path-exists": "^3.0.0" } }, - "map-obj": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-2.0.0.tgz", - "integrity": "sha1-plzSkIepJZi4eRJXpSPgISIqwfk=", - "dev": true - }, - "meow": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/meow/-/meow-4.0.1.tgz", - "integrity": "sha512-xcSBHD5Z86zaOc+781KrupuHAzeGXSLtiAOmBsiLDiPSaYSB6hdew2ng9EBAnZ62jagG9MHAOdxpDi/lWBFJ/A==", - "dev": true, - "requires": { - "camelcase-keys": "^4.0.0", - "decamelize-keys": "^1.0.0", - "loud-rejection": "^1.0.0", - "minimist": "^1.1.3", - "minimist-options": "^3.0.1", - "normalize-package-data": "^2.3.4", - "read-pkg-up": "^3.0.0", - "redent": "^2.0.0", - "trim-newlines": "^2.0.0" - }, - "dependencies": { - "normalize-package-data": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", - "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", - "dev": true, - "requires": { - "hosted-git-info": "^2.1.4", - "resolve": "^1.10.0", - "semver": "2 || 3 || 4 || 5", - "validate-npm-package-license": "^3.0.1" - } - } - } - }, - "minimist-options": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-3.0.2.tgz", - "integrity": "sha512-FyBrT/d0d4+uiZRbqznPXqw3IpZZG3gl3wKWiX784FycUKVwBt0uLBFkQrtE4tZOrgo78nZp2jnKz3L65T5LdQ==", - "dev": true, - "requires": { - "arrify": "^1.0.1", - "is-plain-obj": "^1.1.0" - } - }, "p-limit": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", @@ -4026,12 +3847,6 @@ "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", "dev": true }, - "quick-lru": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-1.1.0.tgz", - "integrity": "sha1-Q2CxfGETatOAeDl/8RQW4Ybc+7g=", - "dev": true - }, "read-pkg": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", @@ -4066,28 +3881,6 @@ "find-up": "^2.0.0", "read-pkg": "^3.0.0" } - }, - "redent": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/redent/-/redent-2.0.0.tgz", - "integrity": "sha1-wbIAe0LVfrE4kHmzyDM2OdXhzKo=", - "dev": true, - "requires": { - "indent-string": "^3.0.0", - "strip-indent": "^2.0.0" - } - }, - "strip-indent": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-2.0.0.tgz", - "integrity": "sha1-XvjbKV0B5u1sv3qrlpmNeCJSe2g=", - "dev": true - }, - "trim-newlines": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-2.0.0.tgz", - "integrity": "sha1-tAPQuRvlDDMd/EuC7s6yLD3hbSA=", - "dev": true } } }, @@ -4144,9 +3937,9 @@ "dev": true }, "conventional-changelog-writer": { - "version": "4.0.18", - "resolved": "https://registry.npmjs.org/conventional-changelog-writer/-/conventional-changelog-writer-4.0.18.tgz", - "integrity": "sha512-mAQDCKyB9HsE8Ko5cCM1Jn1AWxXPYV0v8dFPabZRkvsiWUul2YyAqbIaoMKF88Zf2ffnOPSvKhboLf3fnjo5/A==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/conventional-changelog-writer/-/conventional-changelog-writer-4.1.0.tgz", + "integrity": "sha512-WwKcUp7WyXYGQmkLsX4QmU42AZ1lqlvRW9mqoyiQzdD+rJWbTepdWoKJuwXTS+yq79XKnQNa93/roViPQrAQgw==", "dev": true, "requires": { "compare-func": "^2.0.0", @@ -4195,18 +3988,18 @@ } }, "conventional-recommended-bump": { - "version": "6.0.10", - "resolved": "https://registry.npmjs.org/conventional-recommended-bump/-/conventional-recommended-bump-6.0.10.tgz", - "integrity": "sha512-2ibrqAFMN3ZA369JgVoSbajdD/BHN6zjY7DZFKTHzyzuQejDUCjQ85S5KHxCRxNwsbDJhTPD5hOKcis/jQhRgg==", + "version": "6.0.11", + "resolved": "https://registry.npmjs.org/conventional-recommended-bump/-/conventional-recommended-bump-6.0.11.tgz", + "integrity": "sha512-FciYBMwzwwBZ1K4NS8c57rsOfSc51e1V6UVSNIosrjH+A6xXkyiA4ELwoWyRKdMhJ+m3O6ru9ZJ7F2QFjjYJdQ==", "dev": true, "requires": { "concat-stream": "^2.0.0", "conventional-changelog-preset-loader": "^2.3.4", - "conventional-commits-filter": "^2.0.6", - "conventional-commits-parser": "^3.1.0", + "conventional-commits-filter": "^2.0.7", + "conventional-commits-parser": "^3.2.0", "git-raw-commits": "2.0.0", - "git-semver-tags": "^4.1.0", - "meow": "^7.0.0", + "git-semver-tags": "^4.1.1", + "meow": "^8.0.0", "q": "^1.5.1" }, "dependencies": { @@ -4317,198 +4110,6 @@ "integrity": "sha1-plzSkIepJZi4eRJXpSPgISIqwfk=", "dev": true }, - "meow": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/meow/-/meow-7.1.1.tgz", - "integrity": "sha512-GWHvA5QOcS412WCo8vwKDlTelGLsCGBVevQB5Kva961rmNfun0PCbv5+xta2kUMFJyR8/oWnn7ddeKdosbAPbA==", - "dev": true, - "requires": { - "@types/minimist": "^1.2.0", - "camelcase-keys": "^6.2.2", - "decamelize-keys": "^1.1.0", - "hard-rejection": "^2.1.0", - "minimist-options": "4.1.0", - "normalize-package-data": "^2.5.0", - "read-pkg-up": "^7.0.1", - "redent": "^3.0.0", - "trim-newlines": "^3.0.0", - "type-fest": "^0.13.1", - "yargs-parser": "^18.1.3" - }, - "dependencies": { - "camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true - }, - "camelcase-keys": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-6.2.2.tgz", - "integrity": "sha512-YrwaA0vEKazPBkn0ipTiMpSajYDSe+KjQfrjhcBMxJt/znbvlHd8Pw/Vamaz5EB4Wfhs3SUR3Z9mwRu/P3s3Yg==", - "dev": true, - "requires": { - "camelcase": "^5.3.1", - "map-obj": "^4.0.0", - "quick-lru": "^4.0.1" - } - }, - "find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "dev": true, - "requires": { - "locate-path": "^5.0.0", - "path-exists": "^4.0.0" - } - }, - "indent-string": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", - "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", - "dev": true - }, - "locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "dev": true, - "requires": { - "p-locate": "^4.1.0" - } - }, - "map-obj": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-4.1.0.tgz", - "integrity": "sha512-glc9y00wgtwcDmp7GaE/0b0OnxpNJsVf3ael/An6Fe2Q51LLwN1er6sdomLRzz5h0+yMpiYLhWYF5R7HeqVd4g==", - "dev": true - }, - "minimist-options": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-4.1.0.tgz", - "integrity": "sha512-Q4r8ghd80yhO/0j1O3B2BjweX3fiHg9cdOwjJd2J76Q135c+NDxGCqdYKQ1SKBuFfgWbAUzBfvYjPUEeNgqN1A==", - "dev": true, - "requires": { - "arrify": "^1.0.1", - "is-plain-obj": "^1.1.0", - "kind-of": "^6.0.3" - } - }, - "p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dev": true, - "requires": { - "p-try": "^2.0.0" - } - }, - "p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "dev": true, - "requires": { - "p-limit": "^2.2.0" - } - }, - "p-try": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", - "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", - "dev": true - }, - "parse-json": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.1.0.tgz", - "integrity": "sha512-+mi/lmVVNKFNVyLXV31ERiy2CY5E1/F6QtJFEzoChPRwwngMNXRDQ9GJ5WdE2Z2P4AujsOi0/+2qHID68KwfIQ==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.0.0", - "error-ex": "^1.3.1", - "json-parse-even-better-errors": "^2.3.0", - "lines-and-columns": "^1.1.6" - } - }, - "path-exists": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", - "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", - "dev": true - }, - "quick-lru": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-4.0.1.tgz", - "integrity": "sha512-ARhCpm70fzdcvNQfPoy49IaanKkTlRWF2JMzqhcJbhSFRZv7nPTvZJdcY7301IPmvW+/p0RgIWnQDLJxifsQ7g==", - "dev": true - }, - "read-pkg": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-5.2.0.tgz", - "integrity": "sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==", - "dev": true, - "requires": { - "@types/normalize-package-data": "^2.4.0", - "normalize-package-data": "^2.5.0", - "parse-json": "^5.0.0", - "type-fest": "^0.6.0" - }, - "dependencies": { - "type-fest": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.6.0.tgz", - "integrity": "sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg==", - "dev": true - } - } - }, - "read-pkg-up": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-7.0.1.tgz", - "integrity": "sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg==", - "dev": true, - "requires": { - "find-up": "^4.1.0", - "read-pkg": "^5.2.0", - "type-fest": "^0.8.1" - }, - "dependencies": { - "type-fest": { - "version": "0.8.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", - "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", - "dev": true - } - } - }, - "redent": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/redent/-/redent-3.0.0.tgz", - "integrity": "sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg==", - "dev": true, - "requires": { - "indent-string": "^4.0.0", - "strip-indent": "^3.0.0" - } - }, - "strip-indent": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz", - "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==", - "dev": true, - "requires": { - "min-indent": "^1.0.0" - } - }, - "trim-newlines": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-3.0.0.tgz", - "integrity": "sha512-C4+gOpvmxaSMKuEf9Qc134F1ZuOHVXKRbtEflf4NTtuuJDEIJ9p5PXsalL8SkeRw+qit1Mo+yuvMPAKwWg/1hA==", - "dev": true - } - } - }, "minimist-options": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-3.0.2.tgz", @@ -4644,30 +4245,6 @@ "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-2.0.0.tgz", "integrity": "sha1-tAPQuRvlDDMd/EuC7s6yLD3hbSA=", "dev": true - }, - "type-fest": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.13.1.tgz", - "integrity": "sha512-34R7HTnG0XIJcBSn5XhDd7nNFPRcXYRZrBB2O2jdKqYODldSzBAqzsWoZYYvduky73toYS/ESqxPvkDf/F0XMg==", - "dev": true - }, - "yargs-parser": { - "version": "18.1.3", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", - "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", - "dev": true, - "requires": { - "camelcase": "^5.0.0", - "decamelize": "^1.2.0" - }, - "dependencies": { - "camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true - } - } } } }, @@ -4705,18 +4282,18 @@ "dev": true }, "core-js": { - "version": "3.7.0", - "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.7.0.tgz", - "integrity": "sha512-NwS7fI5M5B85EwpWuIwJN4i/fbisQUwLwiSNUWeXlkAZ0sbBjLEvLvFLf1uzAUV66PcEPt4xCGCmOZSxVf3xzA==", + "version": "3.8.2", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.8.2.tgz", + "integrity": "sha512-FfApuSRgrR6G5s58casCBd9M2k+4ikuu4wbW6pJyYU7bd9zvFc9qf7vr5xmrZOhT9nn+8uwlH1oRR9jTnFoA3A==", "dev": true }, "core-js-compat": { - "version": "3.7.0", - "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.7.0.tgz", - "integrity": "sha512-V8yBI3+ZLDVomoWICO6kq/CD28Y4r1M7CWeO4AGpMdMfseu8bkSubBmUPySMGKRTS+su4XQ07zUkAsiu9FCWTg==", + "version": "3.8.2", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.8.2.tgz", + "integrity": "sha512-LO8uL9lOIyRRrQmZxHZFl1RV+ZbcsAkFWTktn5SmH40WgLtSNYN4m4W2v9ONT147PxBY/XrRhrWq8TlvObyUjQ==", "dev": true, "requires": { - "browserslist": "^4.14.6", + "browserslist": "^4.16.0", "semver": "7.0.0" }, "dependencies": { @@ -4748,9 +4325,9 @@ } }, "cross-env": { - "version": "7.0.2", - "resolved": "https://registry.npmjs.org/cross-env/-/cross-env-7.0.2.tgz", - "integrity": "sha512-KZP/bMEOJEDCkDQAyRhu3RL2ZO/SUVrxQVI0G3YEQ+OLbRA3c6zgixe8Mq8a/z7+HKlNEjo8oiLUs8iRijY2Rw==", + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-env/-/cross-env-7.0.3.tgz", + "integrity": "sha512-+/HKd6EgcQCJGh2PSjZuUitQBQynKor4wrFbRg4DtAgS1aWO+gU52xpH7M9ScGgXSYmAVS9bIJ8EzuaGw0oNAw==", "dev": true, "requires": { "cross-spawn": "^7.0.1" @@ -5310,9 +4887,9 @@ "dev": true }, "electron-to-chromium": { - "version": "1.3.591", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.591.tgz", - "integrity": "sha512-ol/0WzjL4NS4Kqy9VD6xXQON91xIihDT36sYCew/G/bnd1v0/4D+kahp26JauQhgFUjrdva3kRSo7URcUmQ+qw==", + "version": "1.3.634", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.634.tgz", + "integrity": "sha512-QPrWNYeE/A0xRvl/QP3E0nkaEvYUvH3gM04ZWYtIa6QlSpEetRlRI1xvQ7hiMIySHHEV+mwDSX8Kj4YZY6ZQAw==", "dev": true }, "emittery": { @@ -5349,13 +4926,13 @@ } }, "enhanced-resolve": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.3.1.tgz", - "integrity": "sha512-G1XD3MRGrGfNcf6Hg0LVZG7GIKcYkbfHa5QMxt1HDUTdYoXH0JR1xXyg+MaKLF73E9A27uWNVxvFivNRYeUB6w==", + "version": "5.6.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.6.0.tgz", + "integrity": "sha512-C3GGDfFZmqUa21o10YRKbZN60DPl0HyXKXxoEnQMWso9u7KMU23L7CBHfr/rVxORddY/8YQZaU2MZ1ewTS8Pcw==", "dev": true, "requires": { "graceful-fs": "^4.2.4", - "tapable": "^2.0.0" + "tapable": "^2.2.0" } }, "enquirer": { @@ -5377,9 +4954,9 @@ } }, "es-abstract": { - "version": "1.17.7", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.7.tgz", - "integrity": "sha512-VBl/gnfcJ7OercKA9MVaegWsBHFjV492syMudcnQZvt/Dw8ezpcOHYZXa/J96O8vx+g4x65YKhxOwDUh63aS5g==", + "version": "1.18.0-next.1", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.1.tgz", + "integrity": "sha512-I4UGspA0wpZXWENrdA0uHbnhte683t3qT/1VFH9aX2dA5PPSf6QW5HHXf5HImaqPmjXaVeVk4RGWnaylmV7uAA==", "dev": true, "requires": { "es-to-primitive": "^1.2.1", @@ -5387,6 +4964,7 @@ "has": "^1.0.3", "has-symbols": "^1.0.1", "is-callable": "^1.2.2", + "is-negative-zero": "^2.0.0", "is-regex": "^1.1.1", "object-inspect": "^1.8.0", "object-keys": "^1.1.1", @@ -5492,13 +5070,13 @@ } }, "eslint": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.13.0.tgz", - "integrity": "sha512-uCORMuOO8tUzJmsdRtrvcGq5qposf7Rw0LwkTJkoDbOycVQtQjmnhZSuLQnozLE4TmAzlMVV45eCHmQ1OpDKUQ==", + "version": "7.17.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.17.0.tgz", + "integrity": "sha512-zJk08MiBgwuGoxes5sSQhOtibZ75pz0J35XTRlZOk9xMffhpA9BTbQZxoXZzOl5zMbleShbGwtw+1kGferfFwQ==", "dev": true, "requires": { "@babel/code-frame": "^7.0.0", - "@eslint/eslintrc": "^0.2.1", + "@eslint/eslintrc": "^0.2.2", "ajv": "^6.10.0", "chalk": "^4.0.0", "cross-spawn": "^7.0.2", @@ -5508,10 +5086,10 @@ "eslint-scope": "^5.1.1", "eslint-utils": "^2.1.0", "eslint-visitor-keys": "^2.0.0", - "espree": "^7.3.0", + "espree": "^7.3.1", "esquery": "^1.2.0", "esutils": "^2.0.2", - "file-entry-cache": "^5.0.1", + "file-entry-cache": "^6.0.0", "functional-red-black-tree": "^1.0.1", "glob-parent": "^5.0.0", "globals": "^12.1.0", @@ -5531,7 +5109,7 @@ "semver": "^7.2.1", "strip-ansi": "^6.0.0", "strip-json-comments": "^3.1.0", - "table": "^5.2.3", + "table": "^6.0.4", "text-table": "^0.2.0", "v8-compile-cache": "^2.0.3" }, @@ -5582,9 +5160,9 @@ } }, "debug": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", - "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", "dev": true, "requires": { "ms": "2.1.2" @@ -5633,10 +5211,13 @@ "dev": true }, "semver": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", - "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", - "dev": true + "version": "7.3.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", + "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } }, "shebang-command": { "version": "2.0.0", @@ -5686,21 +5267,10 @@ } }, "eslint-config-prettier": { - "version": "6.15.0", - "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.15.0.tgz", - "integrity": "sha512-a1+kOYLR8wMGustcgAjdydMsQ2A/2ipRPwRKUmfYaSxc9ZPcrku080Ctl6zrZzZNs/U82MjSv+qKREkoq3bJaw==", - "dev": true, - "requires": { - "get-stdin": "^6.0.0" - }, - "dependencies": { - "get-stdin": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", - "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", - "dev": true - } - } + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-7.1.0.tgz", + "integrity": "sha512-9sm5/PxaFG7qNJvJzTROMM1Bk1ozXVTKI0buKOyb0Bsr1hrwi0H/TzxF/COtf1uxikIK8SwhX7K6zg78jAzbeA==", + "dev": true }, "eslint-import-resolver-node": { "version": "0.3.4", @@ -5859,9 +5429,9 @@ } }, "eslint-plugin-prettier": { - "version": "3.1.4", - "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.1.4.tgz", - "integrity": "sha512-jZDa8z76klRqo+TdGDTFJSavwbnWK2ZpqGKNZ+VvweMW516pDUMmQ2koXvxEE4JhzNvTv+radye/bWGBmA6jmg==", + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.3.1.tgz", + "integrity": "sha512-Rq3jkcFY8RYeQLgk2cCwuc0P7SEFwDravPhsJZOQ5N4YI4DSg50NyqJ/9gdZHzQlHf8MvafSesbNJCcP/FF6pQ==", "dev": true, "requires": { "prettier-linter-helpers": "^1.0.0" @@ -5901,13 +5471,13 @@ "dev": true }, "espree": { - "version": "7.3.0", - "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.0.tgz", - "integrity": "sha512-dksIWsvKCixn1yrEXO8UosNSxaDoSYpq9reEjZSbHLpT5hpaCAKTLBwq0RHtLrIr+c0ByiYzWT8KTMRzoRCNlw==", + "version": "7.3.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", + "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", "dev": true, "requires": { "acorn": "^7.4.0", - "acorn-jsx": "^5.2.0", + "acorn-jsx": "^5.3.1", "eslint-visitor-keys": "^1.3.0" }, "dependencies": { @@ -5990,18 +5560,84 @@ "dev": true }, "execa": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", - "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-5.0.0.tgz", + "integrity": "sha512-ov6w/2LCiuyO4RLYGdpFGjkcs0wMTgGE8PrkTHikeUy5iJekXyPIKUjifk5CsE0pt7sMCrMZ3YNqoCj6idQOnQ==", "dev": true, "requires": { - "cross-spawn": "^6.0.0", - "get-stream": "^4.0.0", - "is-stream": "^1.1.0", - "npm-run-path": "^2.0.0", - "p-finally": "^1.0.0", - "signal-exit": "^3.0.0", - "strip-eof": "^1.0.0" + "cross-spawn": "^7.0.3", + "get-stream": "^6.0.0", + "human-signals": "^2.1.0", + "is-stream": "^2.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^4.0.1", + "onetime": "^5.1.2", + "signal-exit": "^3.0.3", + "strip-final-newline": "^2.0.0" + }, + "dependencies": { + "cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "get-stream": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.0.tgz", + "integrity": "sha512-A1B3Bh1UmL0bidM/YX2NsCOTnGJePL9rO/M+Mw3m9f2gUpfokS0hi5Eah0WSUEWZdZhIZtMjkIYS7mDfOqNHbg==", + "dev": true + }, + "is-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", + "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", + "dev": true + }, + "npm-run-path": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", + "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", + "dev": true, + "requires": { + "path-key": "^3.0.0" + } + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } } }, "exit": { @@ -6318,9 +5954,9 @@ "dev": true }, "fastq": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.9.0.tgz", - "integrity": "sha512-i7FVWL8HhVY+CTkwFxkN2mk3h+787ixS5S63eb78diVRc1MCssarHq3W5cj0av7YDSwmaV928RNag+U1etRQ7w==", + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.10.0.tgz", + "integrity": "sha512-NL2Qc5L3iQEsyYzweq7qfgy5OtXCmGzGvhElGEd/SoFWEMOEczNh5s5ocaF01HDetxz+p8ecjNPA6cZxxIHmzA==", "dev": true, "requires": { "reusify": "^1.0.4" @@ -6345,12 +5981,12 @@ } }, "file-entry-cache": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", - "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.0.tgz", + "integrity": "sha512-fqoO76jZ3ZnYrXLDRxBR1YvOvc0k844kcOg40bgsPrE25LAb/PDqTY+ho64Xh2c8ZXgIKldchCFHczG2UVRcWA==", "dev": true, "requires": { - "flat-cache": "^2.0.1" + "flat-cache": "^3.0.4" } }, "file-loader": { @@ -6376,13 +6012,6 @@ } } }, - "file-uri-to-path": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", - "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", - "dev": true, - "optional": true - }, "fill-range": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", @@ -6432,40 +6061,28 @@ } }, "find-versions": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/find-versions/-/find-versions-3.2.0.tgz", - "integrity": "sha512-P8WRou2S+oe222TOCHitLy8zj+SIsVJh52VP4lvXkaFVnOFFdoWv1H1Jjvel1aI6NCFOAaeAVm8qrI0odiLcww==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/find-versions/-/find-versions-4.0.0.tgz", + "integrity": "sha512-wgpWy002tA+wgmO27buH/9KzyEOQnKsG/R0yrcjPT9BOFm0zRBVQbZ95nRGXWMywS8YR5knRbpohio0bcJABxQ==", "dev": true, "requires": { - "semver-regex": "^2.0.0" + "semver-regex": "^3.1.2" } }, "flat-cache": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", - "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", + "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", "dev": true, "requires": { - "flatted": "^2.0.0", - "rimraf": "2.6.3", - "write": "1.0.3" - }, - "dependencies": { - "rimraf": { - "version": "2.6.3", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", - "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", - "dev": true, - "requires": { - "glob": "^7.1.3" - } - } + "flatted": "^3.1.0", + "rimraf": "^3.0.2" } }, "flatted": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", - "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.0.tgz", + "integrity": "sha512-tW+UkmtNg/jv9CSofAKvgVcO7c2URjhTdW1ZTkcAritblu8tajiYy7YisnIflEwtKssCtOxpnBRoCB7iap0/TA==", "dev": true }, "for-in": { @@ -6563,15 +6180,11 @@ "dev": true }, "fsevents": { - "version": "1.2.13", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz", - "integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==", + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.1.tgz", + "integrity": "sha512-YR47Eg4hChJGAB1O3yEAOkGO+rlzutoICGqGo9EZ4lKWokzZRSyIW1QmTzqjtw8MJdj9srP869CuWw/hyzSiBw==", "dev": true, - "optional": true, - "requires": { - "bindings": "^1.5.0", - "nan": "^2.12.1" - } + "optional": true }, "function-bind": { "version": "1.1.1", @@ -6598,9 +6211,9 @@ "dev": true }, "get-intrinsic": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.0.1.tgz", - "integrity": "sha512-ZnWP+AmS1VUaLgTRy47+zKtjTxz+0xMpx3I52i+aalBK1QP19ggLF3Db89KJX7kjfOfP2eoa01qc++GwPgufPg==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.0.2.tgz", + "integrity": "sha512-aeX0vrFm21ILl3+JpFFRNe9aUvp6VFZb2/CTbgLb8j75kOhvoNYjt9d8KA/tJG4gSo8nzEDedRl0h7vDmBYRVg==", "dev": true, "requires": { "function-bind": "^1.1.1", @@ -6884,16 +6497,38 @@ } }, "git-raw-commits": { - "version": "2.0.8", - "resolved": "https://registry.npmjs.org/git-raw-commits/-/git-raw-commits-2.0.8.tgz", - "integrity": "sha512-6Gk7tQHGMLEL1bSnrMJTCVt2AQl4EmCcJDtzs/JJacCb2+TNEyHM67Gp7Ri9faF7OcGpjGGRjHLvs/AG7QKZ2Q==", + "version": "2.0.9", + "resolved": "https://registry.npmjs.org/git-raw-commits/-/git-raw-commits-2.0.9.tgz", + "integrity": "sha512-hSpNpxprVno7IOd4PZ93RQ+gNdzPAIrW0x8av6JQDJGV4k1mR9fE01dl8sEqi2P7aKmmwiGUn1BCPuf16Ae0Qw==", "dev": true, "requires": { "dargs": "^7.0.0", "lodash.template": "^4.0.2", "meow": "^8.0.0", - "split2": "^2.0.0", + "split2": "^3.0.0", "through2": "^4.0.0" + }, + "dependencies": { + "readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", + "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + }, + "split2": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/split2/-/split2-3.2.2.tgz", + "integrity": "sha512-9NThjpgZnifTkJpzTZ7Eue85S49QwpNhZTq6GRJwObb6jnLFNGB7Qm73V5HewTROPyxD0C29xqmaI68bQtV+hg==", + "dev": true, + "requires": { + "readable-stream": "^3.0.0" + } + } } }, "git-remote-origin-url": { @@ -7010,9 +6645,9 @@ "dev": true }, "globby": { - "version": "11.0.1", - "resolved": "https://registry.npmjs.org/globby/-/globby-11.0.1.tgz", - "integrity": "sha512-iH9RmgwCmUJHi2z5o2l3eTtGBtXek1OYlHrbcxOYugyHLmAsZrPj43OtHThd62Buh/Vv6VyCBD2bdyWcGNQqoQ==", + "version": "11.0.2", + "resolved": "https://registry.npmjs.org/globby/-/globby-11.0.2.tgz", + "integrity": "sha512-2ZThXDvvV8fYFRVIxnrMQBipZQDr7MxKAmQK1vujaj9/7eF0efG7BPUKJ7jP7G5SLF37xKDXvO4S/KKLj/Z0og==", "dev": true, "requires": { "array-union": "^2.1.0", @@ -7223,24 +6858,24 @@ } }, "human-signals": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz", - "integrity": "sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", + "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", "dev": true }, "husky": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/husky/-/husky-4.3.0.tgz", - "integrity": "sha512-tTMeLCLqSBqnflBZnlVDhpaIMucSGaYyX6855jM4AguGeWCeSzNdb1mfyWduTZ3pe3SJVvVWGL0jO1iKZVPfTA==", + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/husky/-/husky-4.3.7.tgz", + "integrity": "sha512-0fQlcCDq/xypoyYSJvEuzbDPHFf8ZF9IXKJxlrnvxABTSzK1VPT2RKYQKrcgJ+YD39swgoB6sbzywUqFxUiqjw==", "dev": true, "requires": { "chalk": "^4.0.0", "ci-info": "^2.0.0", "compare-versions": "^3.6.0", "cosmiconfig": "^7.0.0", - "find-versions": "^3.2.0", + "find-versions": "^4.0.0", "opencollective-postinstall": "^2.0.2", - "pkg-dir": "^4.2.0", + "pkg-dir": "^5.0.0", "please-upgrade-node": "^3.2.0", "slash": "^3.0.0", "which-pm-runs": "^1.0.0" @@ -7280,19 +6915,56 @@ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", "dev": true }, + "find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "requires": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + } + }, "has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", "dev": true }, + "locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "requires": { + "p-locate": "^5.0.0" + } + }, + "p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "requires": { + "yocto-queue": "^0.1.0" + } + }, + "p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "requires": { + "p-limit": "^3.0.2" + } + }, "pkg-dir": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", - "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-5.0.0.tgz", + "integrity": "sha512-NPE8TDbzl/3YQYY7CSS228s3g2ollTFnc+Qi3tqmqJp9Vg2ovUpixcJEo2HJScN2Ez+kEaal6y70c0ehqJBJeA==", "dev": true, "requires": { - "find-up": "^4.0.0" + "find-up": "^5.0.0" } }, "slash": { @@ -7328,9 +7000,9 @@ "dev": true }, "import-fresh": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.2.tgz", - "integrity": "sha512-cTPNrlvJT6twpYy+YmKUKrTSjWFs3bjYjAhCwm+z4EOCubZxAuO+hHpRN64TqjEaYSHs7tJAE0w1CKMGmsG/lw==", + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", "dev": true, "requires": { "parent-module": "^1.0.0", @@ -7395,9 +7067,9 @@ "dev": true }, "ini": { - "version": "1.3.5", - "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", - "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", + "version": "1.3.8", + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", + "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", "dev": true }, "interpret": { @@ -7476,9 +7148,9 @@ } }, "is-core-module": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.1.0.tgz", - "integrity": "sha512-YcV7BgVMRFRua2FqQzKtTDMz8iCuLEyGKjr70q8Zm1yy2qKcurbFEd79PAdHV77oL3NrAaOVQIbMmiHQCHB7ZA==", + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.2.0.tgz", + "integrity": "sha512-XRAfAdyyY5F5cOXn7hYQDqh2Xmii+DEfIcQGxK/uNwMHhIkPWO0g8msXcbzLe+MpGoR951MlqM/2iIlU4vKDdQ==", "dev": true, "requires": { "has": "^1.0.3" @@ -7576,9 +7248,9 @@ } }, "is-negative-zero": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.0.tgz", - "integrity": "sha1-lVOxIbD6wohp2p7UWeIMdUN4hGE=", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.1.tgz", + "integrity": "sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w==", "dev": true }, "is-number": { @@ -7818,9 +7490,9 @@ }, "dependencies": { "debug": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", - "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", "dev": true, "requires": { "ms": "2.1.2" @@ -7981,6 +7653,12 @@ "pump": "^3.0.0" } }, + "human-signals": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz", + "integrity": "sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw==", + "dev": true + }, "is-stream": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", @@ -8369,13 +8047,6 @@ "to-regex-range": "^5.0.1" } }, - "fsevents": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.2.1.tgz", - "integrity": "sha512-bTLYHSeC0UH/EFXS9KqWnXuOl/wHK5Z/d+ghd5AsFMYN7wIGkUCOJyzy88+wJKkZPGON8u4Z9f6U4FdgURE9qA==", - "dev": true, - "optional": true - }, "is-number": { "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", @@ -9028,10 +8699,13 @@ "dev": true }, "semver": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", - "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", - "dev": true + "version": "7.3.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", + "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } }, "supports-color": { "version": "7.2.0", @@ -9324,9 +8998,9 @@ "dev": true }, "js-yaml": { - "version": "3.14.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", - "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", "dev": true, "requires": { "argparse": "^1.0.7", @@ -9511,9 +9185,9 @@ "dev": true }, "lint-staged": { - "version": "10.5.1", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-10.5.1.tgz", - "integrity": "sha512-fTkTGFtwFIJJzn/PbUO3RXyEBHIhbfYBE7+rJyLcOXabViaO/h6OslgeK6zpeUtzkDrzkgyAYDTLAwx6JzDTHw==", + "version": "10.5.3", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-10.5.3.tgz", + "integrity": "sha512-TanwFfuqUBLufxCc3RUtFEkFraSPNR3WzWcGF39R3f2J7S9+iF9W0KTVLfSy09lYGmZS5NDCxjNvhGMSJyFCWg==", "dev": true, "requires": { "chalk": "^4.1.0", @@ -9577,9 +9251,9 @@ "dev": true }, "commander": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-6.2.0.tgz", - "integrity": "sha512-zP4jEKbe8SHzKJYQmq8Y9gYjtO/POJLgIdKgV7B9qNmABVFVc+ctqSX6iXh4mCpJfRBOabiZ2YKPg8ciDw6C+Q==", + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-6.2.1.tgz", + "integrity": "sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA==", "dev": true }, "cross-spawn": { @@ -9594,9 +9268,9 @@ } }, "debug": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", - "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", "dev": true, "requires": { "ms": "2.1.2" @@ -9643,6 +9317,12 @@ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", "dev": true }, + "human-signals": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz", + "integrity": "sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw==", + "dev": true + }, "is-number": { "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", @@ -9737,9 +9417,9 @@ "dev": true }, "listr2": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-3.2.2.tgz", - "integrity": "sha512-AajqcZEUikF2ioph6PfH3dIuxJclhr3i3kHgTOP0xeXdWQohrvJAAmqVcV43/GI987HFY/vzT73jYXoa4esDHg==", + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-3.2.3.tgz", + "integrity": "sha512-vUb80S2dSUi8YxXahO8/I/s29GqnOL8ozgHVLjfWQXa03BNEeS1TpBLjh2ruaqq5ufx46BRGvfymdBSuoXET5w==", "dev": true, "requires": { "chalk": "^4.1.0", @@ -9833,9 +9513,9 @@ } }, "loader-runner": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.1.0.tgz", - "integrity": "sha512-oR4lB4WvwFoC70ocraKhn5nkKSs23t57h9udUgw8o0iH8hMXeEoRuUgfcvgUwAJ1ZpRqBvcou4N2SMvM1DwMrA==", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.2.0.tgz", + "integrity": "sha512-92+huvxMvYlMzMt0iIOukcwYBFpkYJdpl2xsZ7LrlayO7E8SOv+JJUEK17B/dJIHAOLMfh2dZZ/Y18WgmGtYNw==", "dev": true }, "loader-utils": { @@ -9960,73 +9640,30 @@ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", "dev": true - }, - "supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "requires": { - "has-flag": "^4.0.0" - } - } - } - }, - "log-update": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", - "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", - "dev": true, - "requires": { - "ansi-escapes": "^4.3.0", - "cli-cursor": "^3.1.0", - "slice-ansi": "^4.0.0", - "wrap-ansi": "^6.2.0" - }, - "dependencies": { - "ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "requires": { - "color-convert": "^2.0.1" - } - }, - "astral-regex": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", - "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", - "dev": true - }, - "color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "requires": { - "color-name": "~1.1.4" - } - }, - "color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "slice-ansi": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", - "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", "dev": true, "requires": { - "ansi-styles": "^4.0.0", - "astral-regex": "^2.0.0", - "is-fullwidth-code-point": "^3.0.0" + "has-flag": "^4.0.0" } } } }, + "log-update": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", + "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", + "dev": true, + "requires": { + "ansi-escapes": "^4.3.0", + "cli-cursor": "^3.1.0", + "slice-ansi": "^4.0.0", + "wrap-ansi": "^6.2.0" + } + }, "loud-rejection": { "version": "1.6.0", "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", @@ -10124,9 +9761,9 @@ "dev": true }, "meow": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/meow/-/meow-8.0.0.tgz", - "integrity": "sha512-nbsTRz2fwniJBFgUkcdISq8y/q9n9VbiHYbfwklFh5V4V2uAcxtKQkDc0yCLPM/kP0d+inZBewn3zJqewHE7kg==", + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/meow/-/meow-8.1.0.tgz", + "integrity": "sha512-fNWkgM1UVMey2kf24yLiccxLihc5W+6zVus3/N0b+VfnJgxV99E9u04X6NAiKdg6ED7DAQBX5sy36NM0QJZkWA==", "dev": true, "requires": { "@types/minimist": "^1.2.0", @@ -10194,16 +9831,16 @@ "dev": true }, "mime-db": { - "version": "1.44.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz", - "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==" + "version": "1.45.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.45.0.tgz", + "integrity": "sha512-CkqLUxUk15hofLoLyljJSrukZi8mAtgd+yE5uO4tqRZsdsAJKv0O+rFMhVDRJgozy+yG6md5KwuXhD4ocIoP+w==" }, "mime-types": { - "version": "2.1.27", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz", - "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==", + "version": "2.1.28", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.28.tgz", + "integrity": "sha512-0TO2yJ5YHYr7M2zzT7gDU1tbwHxEUWBCLt0lscSNpcdAfFyJOVEpRYNS7EXVcTLNj/25QO8gulHC5JtTzSE2UQ==", "requires": { - "mime-db": "1.44.0" + "mime-db": "1.45.0" } }, "mimic-fn": { @@ -10264,15 +9901,6 @@ } } }, - "mkdirp": { - "version": "0.5.5", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", - "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", - "dev": true, - "requires": { - "minimist": "^1.2.5" - } - }, "modify-values": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/modify-values/-/modify-values-1.0.1.tgz", @@ -10373,13 +10001,6 @@ "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", "dev": true }, - "nan": { - "version": "2.14.2", - "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz", - "integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==", - "dev": true, - "optional": true - }, "nanomatch": { "version": "1.2.13", "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", @@ -10436,9 +10057,9 @@ "dev": true }, "node-notifier": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/node-notifier/-/node-notifier-8.0.0.tgz", - "integrity": "sha512-46z7DUmcjoYdaWyXouuFNNfUo6eFa94t23c53c+lG/9Cvauk4a98rAUp9672X5dxGdQmLpPzTxzu8f/OeEPaFA==", + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/node-notifier/-/node-notifier-8.0.1.tgz", + "integrity": "sha512-BvEXF+UmsnAfYfoapKM9nGxnP+Wn7P91YfXmrKnfcYCx6VBeoN5Ez5Ogck6I8Bi5k4RlpqRYaw75pAwzX9OphA==", "dev": true, "optional": true, "requires": { @@ -10451,11 +10072,14 @@ }, "dependencies": { "semver": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", - "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", + "version": "7.3.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", + "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", "dev": true, - "optional": true + "optional": true, + "requires": { + "lru-cache": "^6.0.0" + } }, "which": { "version": "2.0.2", @@ -10470,9 +10094,9 @@ } }, "node-releases": { - "version": "1.1.66", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.66.tgz", - "integrity": "sha512-JHEQ1iWPGK+38VLB2H9ef2otU4l8s3yAMt9Xf934r6+ojCYDMHPMqvCc9TnzfeFSP1QEOeU6YZEd3+De0LTCgg==", + "version": "1.1.69", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.69.tgz", + "integrity": "sha512-DGIjo79VDEyAnRlfSqYTsy+yoHd2IOjJiKUozD2MV2D85Vso6Bug56mb9tT/fY5Urt0iqk01H7x+llAruDR2zA==", "dev": true }, "normalize-package-data": { @@ -10488,10 +10112,13 @@ }, "dependencies": { "semver": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", - "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", - "dev": true + "version": "7.3.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", + "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } } } }, @@ -10657,9 +10284,9 @@ } }, "object-inspect": { - "version": "1.8.0", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", - "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.9.0.tgz", + "integrity": "sha512-i3Bp9iTqwhaLZBxGkRfo5ZbE07BQRT7MGu8+nNgwW9ItGp1TzCTw2DLEoWwjClxBjOFI/hWljTAmYGCEwmtnOw==", "dev": true }, "object-keys": { @@ -10699,14 +10326,14 @@ } }, "object.values": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.1.tgz", - "integrity": "sha512-WTa54g2K8iu0kmS/us18jEmdv1a4Wi//BZ/DTVYEcH0XhLM5NYdpDHja3gt57VrZLcNAO2WGA+KpWsDBaHt6eA==", + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.2.tgz", + "integrity": "sha512-MYC0jvJopr8EK6dPBiO8Nb9mvjdypOachO5REGk6MXzujbBrAisKo3HmdEI6kZDL6fC31Mwee/5YbtMebixeag==", "dev": true, "requires": { + "call-bind": "^1.0.0", "define-properties": "^1.1.3", - "es-abstract": "^1.17.0-next.1", - "function-bind": "^1.1.1", + "es-abstract": "^1.18.0-next.1", "has": "^1.0.3" } }, @@ -10771,9 +10398,9 @@ "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=" }, "p-each-series": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/p-each-series/-/p-each-series-2.1.0.tgz", - "integrity": "sha512-ZuRs1miPT4HrjFa+9fRfOFXxGJfORgelKV9f9nNOWw2gl6gVsRaVDOQP0+MI0G0wGKns1Yacsu0GjOFbTK0JFQ==", + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-each-series/-/p-each-series-2.2.0.tgz", + "integrity": "sha512-ycIL2+1V32th+8scbpTvyHNaHe02z0sjgh91XXjAk+ZeXoPN4Z46DVUnzdso0aX4KckKw0FNNFHdjZ2UsZvxiA==", "dev": true }, "p-finally": { @@ -11068,9 +10695,9 @@ "dev": true }, "prettier": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.1.2.tgz", - "integrity": "sha512-16c7K+x4qVlJg9rEbXl7HEGmQyZlG4R9AgP+oHKRMsMsuk8s+ATStlf1NpDqyBI1HpVyfjLOeMhH2LvuNvV5Vg==", + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.2.1.tgz", + "integrity": "sha512-PqyhM2yCjg/oKkFPtTGUojv7gnZAoG80ttl45O6x2Ug/rMJw4wcc9k6aaf2hibP7BGVCCM33gZoGjyvt9mm16Q==", "dev": true }, "prettier-linter-helpers": { @@ -11579,6 +11206,12 @@ "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", "dev": true }, + "require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "dev": true + }, "require-main-filename": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", @@ -11586,12 +11219,12 @@ "dev": true }, "resolve": { - "version": "1.18.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.18.1.tgz", - "integrity": "sha512-lDfCPaMKfOJXjy0dPayzPdF1phampNWr3qFCjAu+rw/qbQmr5jWH5xN2hwh9QKfw9E5v4hwV7A+jrCmL8yjjqA==", + "version": "1.19.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.19.0.tgz", + "integrity": "sha512-rArEXAgsBG4UgRGcynxWIWKFvh/XZCcS8UJdHhwy91zwAvCZIbcs+vAbflgBnNjYMs/i/i+/Ux6IZhML1yPvxg==", "dev": true, "requires": { - "is-core-module": "^2.0.0", + "is-core-module": "^2.1.0", "path-parse": "^1.0.6" } }, @@ -11713,6 +11346,23 @@ "micromatch": "^3.1.4", "minimist": "^1.1.1", "walker": "~1.0.5" + }, + "dependencies": { + "execa": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", + "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", + "dev": true, + "requires": { + "cross-spawn": "^6.0.0", + "get-stream": "^4.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + } } }, "saxes": { @@ -11747,9 +11397,9 @@ "dev": true }, "semver-regex": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/semver-regex/-/semver-regex-2.0.0.tgz", - "integrity": "sha512-mUdIBBvdn0PLOeP3TEkMH7HHeUP3GjsXCwKarjv/kGmUFOYg1VqEemKhoQpWMu6X2I8kHeuVdGibLGkVK+/5Qw==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/semver-regex/-/semver-regex-3.1.2.tgz", + "integrity": "sha512-bXWyL6EAKOJa81XG1OZ/Yyuq+oT0b2YLlxx7c+mrdYPaPbnj6WgVULXhinMIeZGufuUBu/eVRqXEhiv4imfwxA==", "dev": true }, "send": { @@ -11901,20 +11551,38 @@ "dev": true }, "slice-ansi": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", - "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", + "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", "dev": true, "requires": { - "ansi-styles": "^3.2.0", - "astral-regex": "^1.0.0", - "is-fullwidth-code-point": "^2.0.0" + "ansi-styles": "^4.0.0", + "astral-regex": "^2.0.0", + "is-fullwidth-code-point": "^3.0.0" }, "dependencies": { - "is-fullwidth-code-point": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", - "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", "dev": true } } @@ -12111,9 +11779,9 @@ } }, "spdx-license-ids": { - "version": "3.0.6", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.6.tgz", - "integrity": "sha512-+orQK83kyMva3WyPf59k1+Y525csj5JejicWut55zeTWANuN17qSiSLUXWtzHeNWORSvT7GLDJ/E/XiIWoXBTw==", + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.7.tgz", + "integrity": "sha512-U+MTEOO0AiDzxwFvoa4JVnMV6mZlJKk2sBLt90s7G0Gd0Mlknc7kxEn3nuDPNZRta7O2uy8oLcZLVT+4sqNZHQ==", "dev": true }, "split": { @@ -12185,9 +11853,9 @@ } }, "stack-utils": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.2.tgz", - "integrity": "sha512-0H7QK2ECz3fyZMzQ8rH0j2ykpfbnd20BFtfg/SqVC2+sCTtcw0aDTGB7dk+de4U4uUeuz6nOtJcrkFFLG1B0Rg==", + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.3.tgz", + "integrity": "sha512-gL//fkxfWUsIlFL2Tl42Cl6+HFALEaB1FU76I/Fy+oZjRreP7OPMXFlGbxM7NQsI0ZpUfw76sHnv0WNYuTb7Iw==", "dev": true, "requires": { "escape-string-regexp": "^2.0.0" @@ -12202,21 +11870,21 @@ } }, "standard-version": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/standard-version/-/standard-version-9.0.0.tgz", - "integrity": "sha512-eRR04IscMP3xW9MJTykwz13HFNYs8jS33AGuDiBKgfo5YrO0qX0Nxb4rjupVwT5HDYL/aR+MBEVLjlmVFmFEDQ==", + "version": "9.1.0", + "resolved": "https://registry.npmjs.org/standard-version/-/standard-version-9.1.0.tgz", + "integrity": "sha512-EJcbKUGKBuHjiDSUL5XjPhT1KGVM+UCvv/ti70fHnJwJyJqTSJWl0mWj/Wj0WwsoskyvKWURESzBsZmCCMUZzg==", "dev": true, "requires": { "chalk": "^2.4.2", - "conventional-changelog": "3.1.23", + "conventional-changelog": "3.1.24", "conventional-changelog-config-spec": "2.1.0", - "conventional-changelog-conventionalcommits": "4.4.0", - "conventional-recommended-bump": "6.0.10", + "conventional-changelog-conventionalcommits": "4.5.0", + "conventional-recommended-bump": "6.0.11", "detect-indent": "^6.0.0", "detect-newline": "^3.1.0", "dotgitignore": "^2.1.0", "figures": "^3.1.0", - "find-up": "^4.1.0", + "find-up": "^5.0.0", "fs-access": "^1.0.1", "git-semver-tags": "^4.0.0", "semver": "^7.1.1", @@ -12224,28 +11892,57 @@ "yargs": "^15.3.1" }, "dependencies": { - "conventional-changelog-conventionalcommits": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/conventional-changelog-conventionalcommits/-/conventional-changelog-conventionalcommits-4.4.0.tgz", - "integrity": "sha512-ybvx76jTh08tpaYrYn/yd0uJNLt5yMrb1BphDe4WBredMlvPisvMghfpnJb6RmRNcqXeuhR6LfGZGewbkRm9yA==", - "dev": true, - "requires": { - "compare-func": "^2.0.0", - "lodash": "^4.17.15", - "q": "^1.5.1" - } - }, "detect-indent": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-6.0.0.tgz", "integrity": "sha512-oSyFlqaTHCItVRGK5RmrmjB+CmaMOW7IaNA/kdxqhoa6d17j/5ce9O9eWXmV/KEdRwqpQA+Vqe8a8Bsybu4YnA==", "dev": true }, + "find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "requires": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + } + }, + "locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "requires": { + "p-locate": "^5.0.0" + } + }, + "p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "requires": { + "yocto-queue": "^0.1.0" + } + }, + "p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "requires": { + "p-limit": "^3.0.2" + } + }, "semver": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", - "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", - "dev": true + "version": "7.3.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", + "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } } } }, @@ -12310,77 +12007,34 @@ } }, "string.prototype.padend": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.0.tgz", - "integrity": "sha512-3aIv8Ffdp8EZj8iLwREGpQaUZiPyrWrpzMBHvkiSW/bK/EGve9np07Vwy7IJ5waydpGXzQZu/F8Oze2/IWkBaA==", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.1.tgz", + "integrity": "sha512-eCzTASPnoCr5Ht+Vn1YXgm8SB015hHKgEIMu9Nr9bQmLhRBxKRfmzSj/IQsxDFc8JInJDDFA0qXwK+xxI7wDkg==", "dev": true, "requires": { + "call-bind": "^1.0.0", "define-properties": "^1.1.3", - "es-abstract": "^1.17.0-next.1" + "es-abstract": "^1.18.0-next.1" } }, "string.prototype.trimend": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.2.tgz", - "integrity": "sha512-8oAG/hi14Z4nOVP0z6mdiVZ/wqjDtWSLygMigTzAb+7aPEDTleeFf+WrF+alzecxIRkckkJVn+dTlwzJXORATw==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.3.tgz", + "integrity": "sha512-ayH0pB+uf0U28CtjlLvL7NaohvR1amUvVZk+y3DYb0Ey2PUV5zPkkKy9+U1ndVEIXO8hNg18eIv9Jntbii+dKw==", "dev": true, "requires": { - "define-properties": "^1.1.3", - "es-abstract": "^1.18.0-next.1" - }, - "dependencies": { - "es-abstract": { - "version": "1.18.0-next.1", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.1.tgz", - "integrity": "sha512-I4UGspA0wpZXWENrdA0uHbnhte683t3qT/1VFH9aX2dA5PPSf6QW5HHXf5HImaqPmjXaVeVk4RGWnaylmV7uAA==", - "dev": true, - "requires": { - "es-to-primitive": "^1.2.1", - "function-bind": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.1", - "is-callable": "^1.2.2", - "is-negative-zero": "^2.0.0", - "is-regex": "^1.1.1", - "object-inspect": "^1.8.0", - "object-keys": "^1.1.1", - "object.assign": "^4.1.1", - "string.prototype.trimend": "^1.0.1", - "string.prototype.trimstart": "^1.0.1" - } - } + "call-bind": "^1.0.0", + "define-properties": "^1.1.3" } }, "string.prototype.trimstart": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.2.tgz", - "integrity": "sha512-7F6CdBTl5zyu30BJFdzSTlSlLPwODC23Od+iLoVH8X6+3fvDPPuBVVj9iaB1GOsSTSIgVfsfm27R2FGrAPznWg==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.3.tgz", + "integrity": "sha512-oBIBUy5lea5tt0ovtOFiEQaBkoBBkyJhZXzJYrSmDo5IUUqbOPvVezuRs/agBIdZ2p2Eo1FD6bD9USyBLfl3xg==", "dev": true, "requires": { - "define-properties": "^1.1.3", - "es-abstract": "^1.18.0-next.1" - }, - "dependencies": { - "es-abstract": { - "version": "1.18.0-next.1", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.1.tgz", - "integrity": "sha512-I4UGspA0wpZXWENrdA0uHbnhte683t3qT/1VFH9aX2dA5PPSf6QW5HHXf5HImaqPmjXaVeVk4RGWnaylmV7uAA==", - "dev": true, - "requires": { - "es-to-primitive": "^1.2.1", - "function-bind": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.1", - "is-callable": "^1.2.2", - "is-negative-zero": "^2.0.0", - "is-regex": "^1.1.1", - "object-inspect": "^1.8.0", - "object-keys": "^1.1.1", - "object.assign": "^4.1.1", - "string.prototype.trimend": "^1.0.1", - "string.prototype.trimstart": "^1.0.1" - } - } + "call-bind": "^1.0.0", + "define-properties": "^1.1.3" } }, "string_decoder": { @@ -12479,9 +12133,9 @@ }, "dependencies": { "debug": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", - "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", "dev": true, "requires": { "ms": "2.1.2" @@ -12499,9 +12153,9 @@ } }, "mime": { - "version": "2.4.6", - "resolved": "https://registry.npmjs.org/mime/-/mime-2.4.6.tgz", - "integrity": "sha512-RZKhC3EmpBchfTGBVb8fb+RL2cWyw/32lshnsETttkBAyAUXSGHxbEJWWRXc751DrIxG1q04b8QwMbAwkRPpUA==", + "version": "2.4.7", + "resolved": "https://registry.npmjs.org/mime/-/mime-2.4.7.tgz", + "integrity": "sha512-dhNd1uA2u397uQk3Nv5LM4lm93WYDUXFn3Fu291FJerns4jyTudqhIWe4W04YLy7Uk1tm1Ore04NpjRvQp/NPA==", "dev": true }, "ms": { @@ -12528,10 +12182,13 @@ } }, "semver": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", - "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", - "dev": true + "version": "7.3.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", + "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } } } }, @@ -12588,61 +12245,41 @@ "dev": true }, "table": { - "version": "5.4.6", - "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", - "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", + "version": "6.0.7", + "resolved": "https://registry.npmjs.org/table/-/table-6.0.7.tgz", + "integrity": "sha512-rxZevLGTUzWna/qBLObOe16kB2RTnnbhciwgPbMMlazz1yZGVEgnZK762xyVdVznhqxrfCeBMmMkgOOaPwjH7g==", "dev": true, "requires": { - "ajv": "^6.10.2", - "lodash": "^4.17.14", - "slice-ansi": "^2.1.0", - "string-width": "^3.0.0" + "ajv": "^7.0.2", + "lodash": "^4.17.20", + "slice-ansi": "^4.0.0", + "string-width": "^4.2.0" }, "dependencies": { - "ansi-regex": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", - "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", - "dev": true - }, - "emoji-regex": { + "ajv": { "version": "7.0.3", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", - "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", - "dev": true - }, - "is-fullwidth-code-point": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", - "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", - "dev": true - }, - "string-width": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", - "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-7.0.3.tgz", + "integrity": "sha512-R50QRlXSxqXcQP5SvKUrw8VZeypvo12i2IX0EeR5PiZ7bEKeHWgzgo264LDadUsCU42lTJVhFikTqJwNeH34gQ==", "dev": true, "requires": { - "emoji-regex": "^7.0.1", - "is-fullwidth-code-point": "^2.0.0", - "strip-ansi": "^5.1.0" + "fast-deep-equal": "^3.1.1", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2", + "uri-js": "^4.2.2" } }, - "strip-ansi": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", - "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", - "dev": true, - "requires": { - "ansi-regex": "^4.1.0" - } + "json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "dev": true } } }, "tapable": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.1.1.tgz", - "integrity": "sha512-Wib1S8m2wdpLbmQz0RBEVosIyvb/ykfKXf3ZIDqvWoMg/zTNm6G/tDSuUM61J1kNCDXWJrLHGSFeMhAG+gAGpQ==", + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.0.tgz", + "integrity": "sha512-FBk4IesMV1rBxX2tfiK8RAmogtWn53puLOQlvO8XuwlgxcYbP4mVPS9Ph4aeamSyyVjOl24aYWAuc8U5kCVwMw==", "dev": true }, "terminal-link": { @@ -12656,9 +12293,9 @@ } }, "terser": { - "version": "5.3.8", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.3.8.tgz", - "integrity": "sha512-zVotuHoIfnYjtlurOouTazciEfL7V38QMAOhGqpXDEg6yT13cF4+fEP9b0rrCEQTn+tT46uxgFsTZzhygk+CzQ==", + "version": "5.5.1", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.5.1.tgz", + "integrity": "sha512-6VGWZNVP2KTUcltUQJ25TtNjx/XgdDsBDKGt8nN0MpydU36LmbPPcMBd2kmtZNNGVVDLg44k7GKeHHj+4zPIBQ==", "dev": true, "requires": { "commander": "^2.20.0", @@ -12681,26 +12318,26 @@ } }, "terser-webpack-plugin": { - "version": "5.0.3", - "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.0.3.tgz", - "integrity": "sha512-zFdGk8Lh9ZJGPxxPE6jwysOlATWB8GMW8HcfGULWA/nPal+3VdATflQvSBSLQJRCmYZnfFJl6vkRTiwJGNgPiQ==", + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.1.1.tgz", + "integrity": "sha512-5XNNXZiR8YO6X6KhSGXfY0QrGrCRlSwAEjIIrlRQR4W8nP69TaJUlh3bkuac6zzgspiGPfKEHcY295MMVExl5Q==", "dev": true, "requires": { - "jest-worker": "^26.6.1", - "p-limit": "^3.0.2", + "jest-worker": "^26.6.2", + "p-limit": "^3.1.0", "schema-utils": "^3.0.0", "serialize-javascript": "^5.0.1", "source-map": "^0.6.1", - "terser": "^5.3.8" + "terser": "^5.5.1" }, "dependencies": { "p-limit": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.0.2.tgz", - "integrity": "sha512-iwqZSOoWIW+Ew4kAGUlN16J4M7OB3ysMLSZtnhmqx7njIHFPlxWBX8xo3lVTyFVq6mI/lL9qt2IsN1sHwaxJkg==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", "dev": true, "requires": { - "p-try": "^2.0.0" + "yocto-queue": "^0.1.0" } }, "source-map": { @@ -12920,9 +12557,9 @@ "dev": true }, "type-fest": { - "version": "0.18.0", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.18.0.tgz", - "integrity": "sha512-fbDukFPnJBdn2eZ3RR+5mK2slHLFd6gYHY7jna1KWWy4Yr4XysHuCdXRzy+RiG/HwG4WJat00vdC2UHky5eKiQ==", + "version": "0.18.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.18.1.tgz", + "integrity": "sha512-OIAYXk8+ISY+qTOwkHtKqzAuxchoMiD9Udx+FSGQDuiRR+PJKJHc2NJAXlbhkGwTt/4/nKZxELY1w3ReWOL8mw==", "dev": true }, "type-is": { @@ -12951,9 +12588,9 @@ } }, "uglify-js": { - "version": "3.11.5", - "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.11.5.tgz", - "integrity": "sha512-btvv/baMqe7HxP7zJSF7Uc16h1mSfuuSplT0/qdjxseesDU+yYzH33eHBH+eMdeRXwujXspaCTooWHQVVBh09w==", + "version": "3.12.4", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.12.4.tgz", + "integrity": "sha512-L5i5jg/SHkEqzN18gQMTWsZk3KelRsfD1wUVNqtq0kzqWQqcJjyL8yc1o8hJgRrWqrAl2mUFbhfznEIoi7zi2A==", "dev": true, "optional": true }, @@ -13098,9 +12735,9 @@ "dev": true }, "uuid": { - "version": "8.3.1", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.1.tgz", - "integrity": "sha512-FOmRr+FmWEIG8uhZv6C2bTgEVXsHk08kE7mPlrBbEe+c3r9pjceVPgupIfNIhc4yx55H69OXANrUaSuu9eInKg==", + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", "dev": true, "optional": true }, @@ -13111,9 +12748,9 @@ "dev": true }, "v8-to-istanbul": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-7.0.0.tgz", - "integrity": "sha512-fLL2rFuQpMtm9r8hrAV2apXX/WqHJ6+IC4/eQVdMDGBUgH/YMV4Gv3duk3kjmyg6uiQWBAA9nJwue4iJUOkHeA==", + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-7.1.0.tgz", + "integrity": "sha512-uXUVqNUCLa0AH1vuVxzi+MI4RfxEOKt9pBgKwHbgH7st8Kv2P1m+jvWNnektzBh5QShF3ODgKmUFCf38LnVz1g==", "dev": true, "requires": { "@types/istanbul-lib-coverage": "^2.0.1", @@ -13184,9 +12821,9 @@ } }, "watchpack": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.0.1.tgz", - "integrity": "sha512-vO8AKGX22ZRo6PiOFM9dC0re8IcKh8Kd/aH2zeqUc6w4/jBGlTy2P7fTC6ekT0NjVeGjgU2dGC5rNstKkeLEQg==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.1.0.tgz", + "integrity": "sha512-UjgD1mqjkG99+3lgG36at4wPnUXNvis2v1utwTgQ43C22c4LD71LsYMExdWXh4HZ+RmW+B0t1Vrg2GpXAkTOQw==", "dev": true, "requires": { "glob-to-regexp": "^0.4.1", @@ -13200,33 +12837,32 @@ "dev": true }, "webpack": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.4.0.tgz", - "integrity": "sha512-udpYTyqz8toTTdaOsL2QKPLeZLt2IEm9qY7yTXuFEQhKu5bk0yQD9BtAdVQksmz4jFbbWOiWmm3NHarO0zr/ng==", + "version": "5.13.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.13.0.tgz", + "integrity": "sha512-NPhMEtfhSVegp1FNPkCM1MPygDm0GHwpreG10dh//0Gr0epfB0br9nlgEfxSghxJqrQ7j9XzgO91CGGLWZiHeA==", "dev": true, "requires": { "@types/eslint-scope": "^3.7.0", "@types/estree": "^0.0.45", - "@webassemblyjs/ast": "1.9.0", - "@webassemblyjs/helper-module-context": "1.9.0", - "@webassemblyjs/wasm-edit": "1.9.0", - "@webassemblyjs/wasm-parser": "1.9.0", + "@webassemblyjs/ast": "1.11.0", + "@webassemblyjs/wasm-edit": "1.11.0", + "@webassemblyjs/wasm-parser": "1.11.0", "acorn": "^8.0.4", "browserslist": "^4.14.5", "chrome-trace-event": "^1.0.2", - "enhanced-resolve": "^5.3.1", + "enhanced-resolve": "^5.6.0", "eslint-scope": "^5.1.1", "events": "^3.2.0", "glob-to-regexp": "^0.4.1", "graceful-fs": "^4.2.4", "json-parse-better-errors": "^1.0.2", - "loader-runner": "^4.1.0", + "loader-runner": "^4.2.0", "mime-types": "^2.1.27", "neo-async": "^2.6.2", - "pkg-dir": "^4.2.0", + "pkg-dir": "^5.0.0", "schema-utils": "^3.0.0", - "tapable": "^2.0.0", - "terser-webpack-plugin": "^5.0.3", + "tapable": "^2.1.1", + "terser-webpack-plugin": "^5.1.1", "watchpack": "^2.0.0", "webpack-sources": "^2.1.1" }, @@ -13237,13 +12873,50 @@ "integrity": "sha512-XNP0PqF1XD19ZlLKvB7cMmnZswW4C/03pRHgirB30uSJTaS3A3V1/P4sS3HPvFmjoriPCJQs+JDSbm4bL1TxGQ==", "dev": true }, + "find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "requires": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + } + }, + "locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "requires": { + "p-locate": "^5.0.0" + } + }, + "p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "requires": { + "yocto-queue": "^0.1.0" + } + }, + "p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "requires": { + "p-limit": "^3.0.2" + } + }, "pkg-dir": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", - "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-5.0.0.tgz", + "integrity": "sha512-NPE8TDbzl/3YQYY7CSS228s3g2ollTFnc+Qi3tqmqJp9Vg2ovUpixcJEo2HJScN2Ez+kEaal6y70c0ehqJBJeA==", "dev": true, "requires": { - "find-up": "^4.0.0" + "find-up": "^5.0.0" } } } @@ -13377,15 +13050,6 @@ "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", "dev": true }, - "write": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", - "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", - "dev": true, - "requires": { - "mkdirp": "^0.5.1" - } - }, "write-file-atomic": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", @@ -13399,9 +13063,9 @@ } }, "ws": { - "version": "7.4.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.0.tgz", - "integrity": "sha512-kyFwXuV/5ymf+IXhS6f0+eAFvydbaBW3zjpT6hUdAh/hbVjTIB5EHBGi0bPoCLSK2wcuz3BrEkB9LrYv1Nm4NQ==", + "version": "7.4.2", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.2.tgz", + "integrity": "sha512-T4tewALS3+qsrpGI/8dqNMLIVdq/g/85U98HPMa6F0m6xTbvhXU6RCQLqPH3+SlomNV/LdY6RXEbBpMH6EOJnA==", "dev": true }, "xml-name-validator": { @@ -13423,9 +13087,9 @@ "dev": true }, "y18n": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", - "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", + "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==", "dev": true }, "yallist": { @@ -13476,6 +13140,12 @@ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", "dev": true + }, + "yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "dev": true } } } diff --git a/package.json b/package.json index 738f7cd5f..8e7a2d198 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "webpack-dev-middleware", - "version": "4.0.1", + "version": "4.0.3", "description": "A development middleware for webpack", "license": "MIT", "repository": "webpack/webpack-dev-middleware", @@ -38,40 +38,44 @@ "webpack": "^4.0.0 || ^5.0.0" }, "dependencies": { + "colorette": "^1.2.1", "mem": "^8.0.0", "memfs": "^3.2.0", - "mime-types": "^2.1.27", + "mime-types": "^2.1.28", "range-parser": "^1.2.1", "schema-utils": "^3.0.0" }, "devDependencies": { - "@babel/cli": "^7.12.1", - "@babel/core": "^7.12.3", - "@babel/preset-env": "^7.12.1", + "@babel/cli": "^7.12.10", + "@babel/core": "^7.12.10", + "@babel/preset-env": "^7.12.11", "@commitlint/cli": "^11.0.0", "@commitlint/config-conventional": "^11.0.0", "@webpack-contrib/defaults": "^6.3.0", "@webpack-contrib/eslint-config-webpack": "^3.0.0", "babel-jest": "^26.6.3", - "chokidar": "^3.4.3", + "chokidar": "^3.5.0", "connect": "^3.7.0", - "cross-env": "^7.0.2", + "cross-env": "^7.0.3", + "deepmerge": "^4.2.2", "del": "^6.0.0", "del-cli": "^3.0.1", - "eslint": "^7.13.0", - "eslint-config-prettier": "^6.15.0", + "eslint": "^7.17.0", + "eslint-config-prettier": "^7.1.0", "eslint-plugin-import": "^2.22.1", - "eslint-plugin-prettier": "^3.1.4", + "eslint-plugin-prettier": "^3.3.0", + "execa": "^5.0.0", "express": "^4.17.1", "file-loader": "^6.2.0", - "husky": "^4.3.0", + "husky": "^4.3.7", "jest": "^26.6.3", - "lint-staged": "^10.5.1", + "lint-staged": "^10.5.3", "npm-run-all": "^4.1.5", - "prettier": "^2.1.2", - "standard-version": "^9.0.0", + "prettier": "^2.2.1", + "standard-version": "^9.1.0", + "strip-ansi": "^6.0.0", "supertest": "^6.0.1", - "webpack": "^5.4.0" + "webpack": "^5.13.0" }, "keywords": [ "webpack", diff --git a/src/middleware.js b/src/middleware.js index 0c5566946..e22393db1 100644 --- a/src/middleware.js +++ b/src/middleware.js @@ -65,22 +65,32 @@ export default function wrapper(context) { // content-type name(like application/javascript; charset=utf-8) or false const contentType = mime.contentType(path.extname(filename)); - // Express API - if (res.set && contentType) { - res.set('Content-Type', contentType); - } - // Node.js API - else { - res.setHeader( - 'Content-Type', - contentType || 'application/octet-stream' - ); + // Only set content-type header if media type is known + // https://tools.ietf.org/html/rfc7231#section-3.1.1.5 + if (contentType) { + // Express API + if (res.set) { + res.set('Content-Type', contentType); + } + // Node.js API + else { + res.setHeader('Content-Type', contentType); + } } } if (headers) { - for (const name of Object.keys(headers)) { - res.setHeader(name, headers[name]); + const names = Object.keys(headers); + + for (const name of names) { + // Express API + if (res.set) { + res.set(name, headers[name]); + } + // Node.js API + else { + res.setHeader(name, headers[name]); + } } } diff --git a/src/options.json b/src/options.json index eeb27dd1a..f5d9a0baf 100644 --- a/src/options.json +++ b/src/options.json @@ -2,9 +2,11 @@ "type": "object", "properties": { "mimeTypes": { + "description": "Allows a user to register custom mime types or extension mappings.", "type": "object" }, "writeToDisk": { + "description": "Allows to write generated files on disk.", "anyOf": [ { "type": "boolean" @@ -15,30 +17,47 @@ ] }, "methods": { + "description": "Allows to pass the list of HTTP request methods accepted by the middleware.", "type": "array", "items": { - "type": "string" + "type": "string", + "minlength": "1" } }, "headers": { "type": "object" }, "publicPath": { - "type": "string" + "description": "The `publicPath` specifies the public URL address of the output files when referenced in a browser.", + "anyOf": [ + { + "enum": ["auto"] + }, + { + "type": "string" + }, + { + "instanceof": "Function" + } + ] }, "serverSideRender": { + "description": "Instructs the module to enable or disable the server-side rendering mode.", "type": "boolean" }, "outputFileSystem": { + "description": "Set the default file system which will be used by webpack as primary destination of generated files.", "type": "object" }, "index": { + "description": "Allows to serve an index of the directory.", "anyOf": [ { "type": "boolean" }, { - "type": "string" + "type": "string", + "minlength": "1" } ] } diff --git a/src/utils/setupHooks.js b/src/utils/setupHooks.js index 68bbc0e82..2fff96255 100644 --- a/src/utils/setupHooks.js +++ b/src/utils/setupHooks.js @@ -1,7 +1,10 @@ +import webpack from 'webpack'; +import colorette from 'colorette'; + export default function setupHooks(context) { function invalid() { if (context.state) { - context.logger.info('Compiling...'); + context.logger.log('Compilation starting...'); } // We are now in invalid state @@ -20,47 +23,71 @@ export default function setupHooks(context) { // Do the stuff in nextTick, because bundle may be invalidated if a change happened while compiling process.nextTick(() => { - const { state, compiler, callbacks, logger } = context; + const { compiler, logger, state, callbacks } = context; // Check if still in valid state if (!state) { return; } - // Print webpack output - const printStats = (childCompiler, childStats) => { - const statsString = childStats.toString(childCompiler.options.stats); - const name = childCompiler.options.name - ? `Child "${childCompiler.options.name}": ` - : ''; - - if (statsString.length) { - if (childStats.hasErrors()) { - logger.error(`${name}${statsString}`); - } else if (childStats.hasWarnings()) { - logger.warn(`${name}${statsString}`); - } else { - logger.info(`${name}${statsString}`); + logger.log('Compilation finished'); + + let statsOptions = compiler.compilers + ? { + children: compiler.compilers.map((child) => + // eslint-disable-next-line no-undefined + child.options ? child.options.stats : undefined + ), } - } + : compiler.options + ? compiler.options.stats + : // eslint-disable-next-line no-undefined + undefined; + + const statsForWebpack4 = webpack.Stats && webpack.Stats.presetToOptions; + + if (compiler.compilers) { + statsOptions.children = statsOptions.children.map( + (childStatsOptions) => { + if (statsForWebpack4) { + // eslint-disable-next-line no-param-reassign + childStatsOptions = webpack.Stats.presetToOptions( + childStatsOptions + ); + } - let message = `${name}Compiled successfully.`; + if (typeof childStatsOptions.colors === 'undefined') { + // eslint-disable-next-line no-param-reassign + childStatsOptions.colors = Boolean(colorette.options.enabled); + } - if (childStats.hasErrors()) { - message = `${name}Failed to compile.`; - } else if (childStats.hasWarnings()) { - message = `${name}Compiled with warnings.`; + return childStatsOptions; + } + ); + } else if ( + typeof statsOptions.colors === 'undefined' || + typeof statsOptions === 'string' + ) { + if (statsForWebpack4) { + statsOptions = webpack.Stats.presetToOptions(statsOptions); } - logger.info(message); - }; + statsOptions.colors = Boolean(colorette.options.enabled); + } - if (compiler.compilers) { - compiler.compilers.forEach((compilerFromMultiCompileMode, index) => { - printStats(compilerFromMultiCompileMode, stats.stats[index]); - }); - } else { - printStats(compiler, stats); + // TODO webpack@4 doesn't support `{ children: [{ colors: true }, { colors: true }] }` for stats + if (compiler.compilers && statsForWebpack4) { + statsOptions.colors = statsOptions.children.some( + (child) => child.colors + ); + } + + const printedStats = stats.toString(statsOptions); + + // Avoid extra empty line when `stats: 'none'` + if (printedStats) { + // eslint-disable-next-line no-console + console.log(printedStats); } // eslint-disable-next-line no-param-reassign @@ -73,7 +100,10 @@ export default function setupHooks(context) { }); } - context.compiler.hooks.watchRun.tap('DevMiddleware', invalid); - context.compiler.hooks.invalid.tap('DevMiddleware', invalid); - context.compiler.hooks.done.tap('DevMiddleware', done); + context.compiler.hooks.watchRun.tap('webpack-dev-middleware', invalid); + context.compiler.hooks.invalid.tap('webpack-dev-middleware', invalid); + (context.compiler.webpack + ? context.compiler.hooks.afterDone + : context.compiler.hooks.done + ).tap('webpack-dev-middleware', done); } diff --git a/test/__snapshots__/logging.test.js.snap.webpack4 b/test/__snapshots__/logging.test.js.snap.webpack4 new file mode 100644 index 000000000..444ff8b7d --- /dev/null +++ b/test/__snapshots__/logging.test.js.snap.webpack4 @@ -0,0 +1,287 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`logging should logging an error in "watch" method: stderr 1`] = `"Error: Watch error"`; + +exports[`logging should logging an warning: stderr 1`] = `""`; + +exports[`logging should logging an warning: stdout 1`] = ` +" +WARNING in Warning" +`; + +exports[`logging should logging in multi-compiler and respect the "stats" option from configuration #2: stderr 1`] = `""`; + +exports[`logging should logging in multi-compiler and respect the "stats" option from configuration #2: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Child broken: + Hash: xxxx + Time: Xms + Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main + Entrypoint main = bundle.js + [./broken.js] x bytes {main} [built] [failed] [1 error] + + ERROR in ./broken.js 1:3 + Module parse failed: Unexpected token (1:3) + You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders + > 1()2()3() + | +Child warning: + Hash: xxxx + Time: Xms + Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main + Entrypoint main = bundle.js + [./warning.js] x bytes {main} [built] + + WARNING in Warning +Child success: + Hash: xxxx + Time: Xms + Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main + index.html x bytes [emitted] + svg.svg x KiB [emitted] + Entrypoint main = bundle.js + [./foo.js] x bytes {main} [built] + [./index.html] x bytes {main} [built] + [./svg.svg] x bytes {main} [built]" +`; + +exports[`logging should logging in multi-compiler and respect the "stats" option from configuration: stderr 1`] = `""`; + +exports[`logging should logging in multi-compiler and respect the "stats" option from configuration: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Child + Hash: xxxx + Time: Xms + Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main + Entrypoint main = bundle.js + [./broken.js] x bytes {main} [built] [failed] [1 error] + + ERROR in ./broken.js 1:3 + Module parse failed: Unexpected token (1:3) + You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders + > 1()2()3() + | +Child + Hash: xxxx + Time: Xms + Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main + Entrypoint main = bundle.js + [./warning.js] x bytes {main} [built] + + WARNING in Warning +Child + Hash: xxxx + Time: Xms + Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main + index.html x bytes [emitted] + svg.svg x KiB [emitted] + Entrypoint main = bundle.js + [./foo.js] x bytes {main} [built] + [./index.html] x bytes {main} [built] + [./svg.svg] x bytes {main} [built]" +`; + +exports[`logging should logging on successfully build and respect colors #2: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect colors #2: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Time: Xms +Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main +index.html x bytes [emitted] + svg.svg x KiB [emitted] +Entrypoint main = bundle.js +[./foo.js] x bytes {main} [built] +[./index.html] x bytes {main} [built] +[./svg.svg] x bytes {main} [built]" +`; + +exports[`logging should logging on successfully build and respect colors: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect colors: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Time: Xms +Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main +index.html x bytes [emitted] + svg.svg x KiB [emitted] +Entrypoint main = bundle.js +[./foo.js] x bytes {main} [built] +[./index.html] x bytes {main} [built] +[./svg.svg] x bytes {main} [built]" +`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with custom object value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with custom object value: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Time: Xms +Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main +index.html x bytes [emitted] + svg.svg x KiB [emitted] +Entrypoint main = bundle.js +[./foo.js] x bytes {main} [built] +[./index.html] x bytes {main} [built] +[./svg.svg] x bytes {main} [built]" +`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "false" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "false" value: stdout 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "minimal" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "minimal" value: stdout 1`] = `" x modules"`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "none" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "none" value: stdout 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "true" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "true" value: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Time: Xms +Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main +index.html x bytes [emitted] + svg.svg x KiB [emitted] +Entrypoint main = bundle.js +[./foo.js] x bytes {main} [built] +[./index.html] x bytes {main} [built] +[./svg.svg] x bytes {main} [built]" +`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "verbose" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "verbose" value: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Time: Xms +Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main +index.html x bytes [emitted] + svg.svg x KiB [emitted] +Entrypoint main = bundle.js +chunk {main} bundle.js (xxxx) x bytes [entry] [rendered] + > ./foo.js main + [./foo.js] x bytes {main} [depth 0] [built] + single entry ./foo.js main + [./index.html] x bytes {main} [depth 1] [built] + [exports: default] + cjs require ./index.html [./foo.js] 4:0-23 + [./svg.svg] x bytes {main} [depth 1] [built] + [exports: default] + cjs require ./svg.svg [./foo.js] 3:0-20 + +LOG from xxx" +`; + +exports[`logging should logging on successfully build in multi-compiler mode: stderr 1`] = `""`; + +exports[`logging should logging on successfully build in multi-compiler mode: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Child + Hash: xxxx + Time: Xms + Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main + index.html x bytes [emitted] + svg.svg x KiB [emitted] + Entrypoint main = bundle.js + [./foo.js] x bytes {main} [built] + [./index.html] x bytes {main} [built] + [./svg.svg] x bytes {main} [built] +Child + Hash: xxxx + Time: Xms + Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main + Entrypoint main = bundle.js + [./bar.js] x bytes {main} [built]" +`; + +exports[`logging should logging on successfully build: stderr 1`] = `""`; + +exports[`logging should logging on successfully build: stdout 1`] = ` +"Hash: xxxx +Version: webpack x.x.x +Time: Xms +Built at: x + Asset Size Chunks Chunk Names + bundle.js x KiB main [emitted] main +index.html x bytes [emitted] + svg.svg x KiB [emitted] +Entrypoint main = bundle.js +[./foo.js] x bytes {main} [built] +[./index.html] x bytes {main} [built] +[./svg.svg] x bytes {main} [built]" +`; + +exports[`logging should logging on unsuccessful build in multi-compiler: stderr 1`] = `""`; + +exports[`logging should logging on unsuccessful build in multi-compiler: stdout 1`] = ` +"Child + + ERROR in ./broken.js 1:3 + Module parse failed: Unexpected token (1:3) + You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders + > 1()2()3() + | +Child + + ERROR in ./broken.js 1:3 + Module parse failed: Unexpected token (1:3) + You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders + > 1()2()3() + |" +`; + +exports[`logging should logging on unsuccessful build: stderr 1`] = `""`; + +exports[`logging should logging on unsuccessful build: stdout 1`] = ` +" +ERROR in ./broken.js 1:3 +Module parse failed: Unexpected token (1:3) +You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders +> 1()2()3() +|" +`; + +exports[`logging should logging warnings in multi-compiler mode: stderr 1`] = `""`; + +exports[`logging should logging warnings in multi-compiler mode: stdout 1`] = ` +"Child + + WARNING in Warning +Child + + WARNING in Warning" +`; diff --git a/test/__snapshots__/logging.test.js.snap.webpack5 b/test/__snapshots__/logging.test.js.snap.webpack5 new file mode 100644 index 000000000..e8e897a90 --- /dev/null +++ b/test/__snapshots__/logging.test.js.snap.webpack5 @@ -0,0 +1,263 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`logging should logging an error in "watch" method: stderr 1`] = `"Error: Watch error"`; + +exports[`logging should logging an warning: stderr 1`] = `""`; + +exports[`logging should logging an warning: stdout 1`] = ` +"WARNING in Warning + +webpack compiled with 1 warning" +`; + +exports[`logging should logging in multi-compiler and respect the "stats" option from configuration #2: stderr 1`] = `""`; + +exports[`logging should logging in multi-compiler and respect the "stats" option from configuration #2: stdout 1`] = ` +"broken: + asset bundle.js x bytes [emitted] (name: main) + ./broken.js x bytes [built] [code generated] [1 error] + + ERROR in ./broken.js 1:3 + Module parse failed: Unexpected token (1:3) + You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders + > 1()2()3() + | + + broken (webpack x.x.x) compiled with 1 error in x ms + +warning: + asset bundle.js x bytes [emitted] (name: main) + ./warning.js x bytes [built] [code generated] + + WARNING in Warning + + warning (webpack x.x.x) compiled with 1 warning in x ms + +success: + asset svg.svg x KiB [emitted] [from: svg.svg] (auxiliary name: main) + asset bundle.js x KiB [emitted] (name: main) + asset index.html x bytes [emitted] [from: index.html] (auxiliary name: main) + runtime modules x bytes x modules + cacheable modules x bytes + ./foo.js x bytes [built] [code generated] + ./svg.svg x bytes [built] [code generated] + ./index.html x bytes [built] [code generated] + success (webpack x.x.x) compiled successfully in x ms" +`; + +exports[`logging should logging in multi-compiler and respect the "stats" option from configuration: stderr 1`] = `""`; + +exports[`logging should logging in multi-compiler and respect the "stats" option from configuration: stdout 1`] = ` +"asset bundle.js x bytes [emitted] (name: main) +./broken.js x bytes [built] [code generated] [1 error] + +ERROR in ./broken.js 1:3 +Module parse failed: Unexpected token (1:3) +You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders +> 1()2()3() +| + +webpack x.x.x compiled with 1 error in x ms + +asset bundle.js x bytes [emitted] (name: main) +./warning.js x bytes [built] [code generated] + +WARNING in Warning + +webpack x.x.x compiled with 1 warning in x ms + +asset svg.svg x KiB [emitted] [from: svg.svg] (auxiliary name: main) +asset bundle.js x KiB [emitted] (name: main) +asset index.html x bytes [emitted] [from: index.html] (auxiliary name: main) +runtime modules x bytes x modules +cacheable modules x bytes + ./foo.js x bytes [built] [code generated] + ./svg.svg x bytes [built] [code generated] + ./index.html x bytes [built] [code generated] +webpack x.x.x compiled successfully in x ms" +`; + +exports[`logging should logging on successfully build and respect colors #2: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect colors #2: stdout 1`] = ` +"asset bundle.js x KiB [emitted] (name: main) +asset svg.svg x KiB [emitted] [from: svg.svg] (auxiliary name: main) +asset index.html x bytes [emitted] [from: index.html] (auxiliary name: main) +runtime modules x KiB x modules +cacheable modules x bytes + ./foo.js x bytes [built] [code generated] + ./svg.svg x bytes [built] [code generated] + ./index.html x bytes [built] [code generated] +webpack x.x.x compiled successfully in x ms" +`; + +exports[`logging should logging on successfully build and respect colors: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect colors: stdout 1`] = ` +"asset bundle.js x KiB [emitted] (name: main) +asset svg.svg x KiB [emitted] [from: svg.svg] (auxiliary name: main) +asset index.html x bytes [emitted] [from: index.html] (auxiliary name: main) +runtime modules x KiB x modules +cacheable modules x bytes + ./foo.js x bytes [built] [code generated] + ./svg.svg x bytes [built] [code generated] + ./index.html x bytes [built] [code generated] +webpack x.x.x compiled successfully in x ms" +`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with custom object value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with custom object value: stdout 1`] = ` +"asset bundle.js x KiB [emitted] (name: main) +asset svg.svg x KiB [emitted] [from: svg.svg] (auxiliary name: main) +asset index.html x bytes [emitted] [from: index.html] (auxiliary name: main)" +`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "false" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "false" value: stdout 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "minimal" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "minimal" value: stdout 1`] = ` +"x assets +x modules +webpack x.x.x compiled successfully in x ms" +`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "none" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "none" value: stdout 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "true" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "true" value: stdout 1`] = ` +"asset bundle.js x KiB [emitted] (name: main) +asset svg.svg x KiB [emitted] [from: svg.svg] (auxiliary name: main) +asset index.html x bytes [emitted] [from: index.html] (auxiliary name: main) +runtime modules x KiB x modules +cacheable modules x bytes + ./foo.js x bytes [built] [code generated] + ./svg.svg x bytes [built] [code generated] + ./index.html x bytes [built] [code generated] +webpack x.x.x compiled successfully in x ms" +`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "verbose" value: stderr 1`] = `""`; + +exports[`logging should logging on successfully build and respect the "stats" option from configuration with the "verbose" value: stdout 1`] = ` +"PublicPath: auto +asset bundle.js x KiB {main} [emitted] (name: main) +asset svg.svg x KiB ({main}) [emitted] [from: svg.svg] (auxiliary name: main) +asset index.html x bytes ({main}) [emitted] [from: index.html] (auxiliary name: main) +Entrypoint main x KiB (x KiB) = bundle.js 2 auxiliary assets +chunk {main} (runtime: main) bundle.js (xxxx) x bytes (xxxx) x KiB (xxxx) [entry] [rendered] + > ./foo.js main + runtime modules x KiB + webpack/runtime/define property getters x bytes {main} [code generated] + [no exports] + [used exports unknown] + webpack/runtime/global x bytes {main} [code generated] + [no exports] + [used exports unknown] + webpack/runtime/hasOwnProperty shorthand x bytes {main} [code generated] + [no exports] + [used exports unknown] + webpack/runtime/make namespace object x bytes {main} [code generated] + [no exports] + [used exports unknown] + webpack/runtime/publicPath x bytes {main} [code generated] + [no exports] + [used exports unknown] + cacheable modules x bytes + ./foo.js x bytes {main} [depth 0] [built] [code generated] + [used exports unknown] + entry ./foo.js main + ./index.html x bytes {main} [depth 1] [dependent] [built] [code generated] + [exports: default] + [used exports unknown] + cjs require ./index.html [./foo.js] 4:0-23 + ./svg.svg x bytes {main} [depth 1] [dependent] [built] [code generated] + [exports: default] + [used exports unknown] + cjs require ./svg.svg [./foo.js] 3:0-20 + + +LOG from xxx" +`; + +exports[`logging should logging on successfully build in multi-compiler mode: stderr 1`] = `""`; + +exports[`logging should logging on successfully build in multi-compiler mode: stdout 1`] = ` +"asset svg.svg x KiB [emitted] [from: svg.svg] (auxiliary name: main) +asset bundle.js x KiB [emitted] (name: main) +asset index.html x bytes [emitted] [from: index.html] (auxiliary name: main) +runtime modules x bytes x modules +cacheable modules x bytes + ./foo.js x bytes [built] [code generated] + ./svg.svg x bytes [built] [code generated] + ./index.html x bytes [built] [code generated] +webpack x.x.x compiled successfully in x ms + +asset bundle.js x bytes [emitted] (name: main) +./bar.js x bytes [built] [code generated] +webpack x.x.x compiled successfully in x ms" +`; + +exports[`logging should logging on successfully build: stderr 1`] = `""`; + +exports[`logging should logging on successfully build: stdout 1`] = ` +"asset bundle.js x KiB [emitted] (name: main) +asset svg.svg x KiB [emitted] [from: svg.svg] (auxiliary name: main) +asset index.html x bytes [emitted] [from: index.html] (auxiliary name: main) +runtime modules x KiB x modules +cacheable modules x bytes + ./foo.js x bytes [built] [code generated] + ./svg.svg x bytes [built] [code generated] + ./index.html x bytes [built] [code generated] +webpack x.x.x compiled successfully in x ms" +`; + +exports[`logging should logging on unsuccessful build in multi-compiler: stderr 1`] = `""`; + +exports[`logging should logging on unsuccessful build in multi-compiler: stdout 1`] = ` +"ERROR in ./broken.js 1:3 +Module parse failed: Unexpected token (1:3) +You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders +> 1()2()3() +| + +webpack compiled with 1 error + +ERROR in ./broken.js 1:3 +Module parse failed: Unexpected token (1:3) +You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders +> 1()2()3() +| + +webpack compiled with 1 error" +`; + +exports[`logging should logging on unsuccessful build: stderr 1`] = `""`; + +exports[`logging should logging on unsuccessful build: stdout 1`] = ` +"ERROR in ./broken.js 1:3 +Module parse failed: Unexpected token (1:3) +You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders +> 1()2()3() +| + +webpack compiled with 1 error" +`; + +exports[`logging should logging warnings in multi-compiler mode: stderr 1`] = `""`; + +exports[`logging should logging warnings in multi-compiler mode: stdout 1`] = ` +"WARNING in Warning + +webpack compiled with 1 warning + +WARNING in Warning + +webpack compiled with 1 warning" +`; diff --git a/test/__snapshots__/middleware.test.js.snap b/test/__snapshots__/middleware.test.js.snap deleted file mode 100644 index a81f32a95..000000000 --- a/test/__snapshots__/middleware.test.js.snap +++ /dev/null @@ -1,1261 +0,0 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP - -exports[`connect framework: middleware basic should respect the "stats" option from the configuration in multi-compiler mode and use the "name" option should return the "200" code for "GET" requests to bundle files 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Child \\"broken\\": Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Child \\"warning\\": Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Child \\"success\\": Compiled successfully.", - ], - ], -] -`; - -exports[`connect framework: middleware basic should respect the "stats" option from the configuration in multi-compiler mode should return the "200" code for the "GET" request to bundle files 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], -] -`; - -exports[`connect framework: middleware basic should respect the "stats" option in multi-compiler mode should return the "200" code for the "GET" requests to bundles file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`connect framework: middleware basic should respect the "stats" option with the "{ all: false, entrypoints: true }" value from the configuration should return the "200" code for the "GET" request to the bundle file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Entrypoint main = bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`connect framework: middleware basic should respect the "stats" option with the "false" value from the configuration should return the "200" code for the "GET" request to the bundle file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`connect framework: middleware basic should respect the "stats" option with the "minimal" value from the configuration should return the "200" code for the "GET" request to the bundle file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "compiled successfully", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`connect framework: middleware basic should respect the "stats" option with the "none" value from the configuration should return the "200" code for the "GET" request to the bundle file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`connect framework: middleware basic should throw an error on "run" when we watching should logging an error 1`] = `"You ran Webpack twice. Each instance only supports a single concurrent compilation at a time."`; - -exports[`connect framework: middleware basic should throw an error on "watch" when we watching should logging an error 1`] = `"You ran Webpack twice. Each instance only supports a single concurrent compilation at a time."`; - -exports[`connect framework: middleware logger should logging an error from the "fs.mkdir" method when the "writeToDisk" option is "true" should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], -] -`; - -exports[`connect framework: middleware logger should logging an error from the "fs.writeFile" method when the "writeToDisk" option is "true" should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], -] -`; - -exports[`connect framework: middleware logger should logging an error in "watch" method should logging on startup 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], -] -`; - -exports[`connect framework: middleware logger should logging an warning should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], -] -`; - -exports[`connect framework: middleware logger should logging on successfully build in multi-compiler mode should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`connect framework: middleware logger should logging on successfully build should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`connect framework: middleware logger should logging on unsuccessful build in multi-compiler should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], -] -`; - -exports[`connect framework: middleware logger should logging on unsuccessful build should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], -] -`; - -exports[`connect framework: middleware logger should logging warnings in multi-compiler mode should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], -] -`; - -exports[`express framework: middleware basic should respect the "stats" option from the configuration in multi-compiler mode and use the "name" option should return the "200" code for "GET" requests to bundle files 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Child \\"broken\\": Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Child \\"warning\\": Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Child \\"success\\": Compiled successfully.", - ], - ], -] -`; - -exports[`express framework: middleware basic should respect the "stats" option from the configuration in multi-compiler mode should return the "200" code for the "GET" request to bundle files 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], -] -`; - -exports[`express framework: middleware basic should respect the "stats" option in multi-compiler mode should return the "200" code for the "GET" requests to bundles file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`express framework: middleware basic should respect the "stats" option with the "{ all: false, entrypoints: true }" value from the configuration should return the "200" code for the "GET" request to the bundle file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Entrypoint main = bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`express framework: middleware basic should respect the "stats" option with the "false" value from the configuration should return the "200" code for the "GET" request to the bundle file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`express framework: middleware basic should respect the "stats" option with the "minimal" value from the configuration should return the "200" code for the "GET" request to the bundle file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "compiled successfully", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`express framework: middleware basic should respect the "stats" option with the "none" value from the configuration should return the "200" code for the "GET" request to the bundle file 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`express framework: middleware basic should throw an error on "run" when we watching should logging an error 1`] = `"You ran Webpack twice. Each instance only supports a single concurrent compilation at a time."`; - -exports[`express framework: middleware basic should throw an error on "watch" when we watching should logging an error 1`] = `"You ran Webpack twice. Each instance only supports a single concurrent compilation at a time."`; - -exports[`express framework: middleware logger should logging an error from the "fs.mkdir" method when the "writeToDisk" option is "true" should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], -] -`; - -exports[`express framework: middleware logger should logging an error from the "fs.writeFile" method when the "writeToDisk" option is "true" should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], -] -`; - -exports[`express framework: middleware logger should logging an error in "watch" method should logging on startup 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], -] -`; - -exports[`express framework: middleware logger should logging an warning should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], -] -`; - -exports[`express framework: middleware logger should logging on successfully build in multi-compiler mode should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`express framework: middleware logger should logging on successfully build should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled successfully.", - ], - ], -] -`; - -exports[`express framework: middleware logger should logging on unsuccessful build in multi-compiler should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], -] -`; - -exports[`express framework: middleware logger should logging on unsuccessful build should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "error", - Array [ - "ERROR", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Failed to compile.", - ], - ], -] -`; - -exports[`express framework: middleware logger should logging warnings in multi-compiler mode should logging 1`] = ` -Array [ - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished: /static-one/bundle.js", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiling...", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "wait until bundle finished", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], - Array [ - "webpack-dev-middleware", - "warn", - Array [ - "WARNING", - ], - ], - Array [ - "webpack-dev-middleware", - "info", - Array [ - "Compiled with warnings.", - ], - ], -] -`; diff --git a/test/__snapshots__/validation-options.test.js.snap b/test/__snapshots__/validation-options.test.js.snap.webpack4 similarity index 72% rename from test/__snapshots__/validation-options.test.js.snap rename to test/__snapshots__/validation-options.test.js.snap.webpack4 index e88d5b1a8..891567ffe 100644 --- a/test/__snapshots__/validation-options.test.js.snap +++ b/test/__snapshots__/validation-options.test.js.snap.webpack4 @@ -10,6 +10,7 @@ exports[`validation should throw an error on the "index" option with "{}" value "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - options.index should be one of these: boolean | string + -> Allows to serve an index of the directory. Details: * options.index should be a boolean. * options.index should be a string." @@ -19,6 +20,7 @@ exports[`validation should throw an error on the "index" option with "0" value 1 "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - options.index should be one of these: boolean | string + -> Allows to serve an index of the directory. Details: * options.index should be a boolean. * options.index should be a string." @@ -27,46 +29,59 @@ exports[`validation should throw an error on the "index" option with "0" value 1 exports[`validation should throw an error on the "methods" option with "{}" value 1`] = ` "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - options.methods should be an array: - [string, ...]" + [string, ...] + -> Allows to pass the list of HTTP request methods accepted by the middleware." `; exports[`validation should throw an error on the "methods" option with "true" value 1`] = ` "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - options.methods should be an array: - [string, ...]" + [string, ...] + -> Allows to pass the list of HTTP request methods accepted by the middleware." `; exports[`validation should throw an error on the "mimeTypes" option with "foo" value 1`] = ` "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - options.mimeTypes should be an object: - object { … }" + object { … } + -> Allows a user to register custom mime types or extension mappings." `; exports[`validation should throw an error on the "outputFileSystem" option with "false" value 1`] = ` "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - options.outputFileSystem should be an object: - object { … }" + object { … } + -> Set the default file system which will be used by webpack as primary destination of generated files." `; exports[`validation should throw an error on the "publicPath" option with "false" value 1`] = ` "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - - options.publicPath should be a string." + - options.publicPath should be one of these: + \\"auto\\" | string | function + -> The \`publicPath\` specifies the public URL address of the output files when referenced in a browser. + Details: + * options.publicPath should be \\"auto\\". + * options.publicPath should be a string. + * options.publicPath should be an instance of function." `; exports[`validation should throw an error on the "serverSideRender" option with "0" value 1`] = ` "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - - options.serverSideRender should be a boolean." + - options.serverSideRender should be a boolean. + -> Instructs the module to enable or disable the server-side rendering mode." `; exports[`validation should throw an error on the "serverSideRender" option with "foo" value 1`] = ` "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - - options.serverSideRender should be a boolean." + - options.serverSideRender should be a boolean. + -> Instructs the module to enable or disable the server-side rendering mode." `; exports[`validation should throw an error on the "writeToDisk" option with "{}" value 1`] = ` "Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. - options.writeToDisk should be one of these: boolean | function + -> Allows to write generated files on disk. Details: * options.writeToDisk should be a boolean. * options.writeToDisk should be an instance of function." diff --git a/test/__snapshots__/validation-options.test.js.snap.webpack5 b/test/__snapshots__/validation-options.test.js.snap.webpack5 new file mode 100644 index 000000000..891567ffe --- /dev/null +++ b/test/__snapshots__/validation-options.test.js.snap.webpack5 @@ -0,0 +1,88 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`validation should throw an error on the "headers" option with "true" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.headers should be an object: + object { … }" +`; + +exports[`validation should throw an error on the "index" option with "{}" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.index should be one of these: + boolean | string + -> Allows to serve an index of the directory. + Details: + * options.index should be a boolean. + * options.index should be a string." +`; + +exports[`validation should throw an error on the "index" option with "0" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.index should be one of these: + boolean | string + -> Allows to serve an index of the directory. + Details: + * options.index should be a boolean. + * options.index should be a string." +`; + +exports[`validation should throw an error on the "methods" option with "{}" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.methods should be an array: + [string, ...] + -> Allows to pass the list of HTTP request methods accepted by the middleware." +`; + +exports[`validation should throw an error on the "methods" option with "true" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.methods should be an array: + [string, ...] + -> Allows to pass the list of HTTP request methods accepted by the middleware." +`; + +exports[`validation should throw an error on the "mimeTypes" option with "foo" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.mimeTypes should be an object: + object { … } + -> Allows a user to register custom mime types or extension mappings." +`; + +exports[`validation should throw an error on the "outputFileSystem" option with "false" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.outputFileSystem should be an object: + object { … } + -> Set the default file system which will be used by webpack as primary destination of generated files." +`; + +exports[`validation should throw an error on the "publicPath" option with "false" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.publicPath should be one of these: + \\"auto\\" | string | function + -> The \`publicPath\` specifies the public URL address of the output files when referenced in a browser. + Details: + * options.publicPath should be \\"auto\\". + * options.publicPath should be a string. + * options.publicPath should be an instance of function." +`; + +exports[`validation should throw an error on the "serverSideRender" option with "0" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.serverSideRender should be a boolean. + -> Instructs the module to enable or disable the server-side rendering mode." +`; + +exports[`validation should throw an error on the "serverSideRender" option with "foo" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.serverSideRender should be a boolean. + -> Instructs the module to enable or disable the server-side rendering mode." +`; + +exports[`validation should throw an error on the "writeToDisk" option with "{}" value 1`] = ` +"Invalid options object. Dev Middleware has been initialized using an options object that does not match the API schema. + - options.writeToDisk should be one of these: + boolean | function + -> Allows to write generated files on disk. + Details: + * options.writeToDisk should be a boolean. + * options.writeToDisk should be an instance of function." +`; diff --git a/test/api.test.js b/test/api.test.js index 89601189b..bf8fec3be 100644 --- a/test/api.test.js +++ b/test/api.test.js @@ -8,6 +8,9 @@ import getCompiler from './helpers/getCompiler'; import getCompilerHooks from './helpers/getCompilerHooks'; import webpackConfig from './fixtures/webpack.config'; +// Suppress unnecessary stats output +global.console.log = jest.fn(); + describe.each([ ['express', express], ['connect', connect], @@ -58,7 +61,12 @@ describe.each([ }); it('should work', (done) => { - const doneSpy = jest.spyOn(getCompilerHooks(compiler).done[0], 'fn'); + const doneSpy = jest.spyOn( + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], + 'fn' + ); instance.waitUntilValid(() => { instance.close(); @@ -121,7 +129,9 @@ describe.each([ it('should work', (done) => { const doneSpy = jest.spyOn( - getCompilerHooks(compiler).done[0], + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], 'fn' ); @@ -179,7 +189,12 @@ describe.each([ }); it('should work without callback', (done) => { - const doneSpy = jest.spyOn(getCompilerHooks(compiler).done[0], 'fn'); + const doneSpy = jest.spyOn( + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], + 'fn' + ); instance.waitUntilValid(); @@ -200,7 +215,12 @@ describe.each([ }); it('should work with callback', (done) => { - const doneSpy = jest.spyOn(getCompilerHooks(compiler).done[0], 'fn'); + const doneSpy = jest.spyOn( + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], + 'fn' + ); let callbackCounter = 0; instance.waitUntilValid(() => { @@ -224,7 +244,12 @@ describe.each([ }); it('should run callback immediately when state already valid', (done) => { - const doneSpy = jest.spyOn(getCompilerHooks(compiler).done[0], 'fn'); + const doneSpy = jest.spyOn( + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], + 'fn' + ); let callbackCounter = 0; let validToCheck = false; @@ -293,7 +318,12 @@ describe.each([ }); it('should work without callback', (done) => { - const doneSpy = jest.spyOn(getCompilerHooks(compiler).done[0], 'fn'); + const doneSpy = jest.spyOn( + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], + 'fn' + ); instance.invalidate(); @@ -313,7 +343,12 @@ describe.each([ }); it('should work with callback', (done) => { - const doneSpy = jest.spyOn(getCompilerHooks(compiler).done[0], 'fn'); + const doneSpy = jest.spyOn( + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], + 'fn' + ); let callbackCounter = 0; instance.invalidate(() => { @@ -376,7 +411,12 @@ describe.each([ }); it('should work without callback', (done) => { - const doneSpy = jest.spyOn(getCompilerHooks(compiler).done[0], 'fn'); + const doneSpy = jest.spyOn( + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], + 'fn' + ); instance.waitUntilValid(() => { instance.close(); @@ -391,7 +431,12 @@ describe.each([ }); it('should work with callback', (done) => { - const doneSpy = jest.spyOn(getCompilerHooks(compiler).done[0], 'fn'); + const doneSpy = jest.spyOn( + (webpack.webpack + ? getCompilerHooks(compiler).afterDone + : getCompilerHooks(compiler).done)[0], + 'fn' + ); instance.waitUntilValid(() => { instance.close(() => { @@ -453,9 +498,12 @@ describe.each([ // the compilation needs to finish, as it will still be running // after the test is done if not finished, potentially impacting other tests - compiler.hooks.done.tap('wdm-test', () => { - done(); - }); + (webpack.webpack ? compiler.hooks.afterDone : compiler.hooks.done).tap( + 'wdm-test', + () => { + done(); + } + ); }); }); }); diff --git a/test/fixtures/webpack.array.config.js b/test/fixtures/webpack.array.config.js index 2c1a164ff..3c4f6fd38 100644 --- a/test/fixtures/webpack.array.config.js +++ b/test/fixtures/webpack.array.config.js @@ -24,7 +24,7 @@ module.exports = [ infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }, { mode: 'development', @@ -38,6 +38,6 @@ module.exports = [ infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }, ]; diff --git a/test/fixtures/webpack.array.one-error-one-warning-one-success-with-names.js b/test/fixtures/webpack.array.one-error-one-warning-one-success-with-names.js index c32653330..482b80c97 100644 --- a/test/fixtures/webpack.array.one-error-one-warning-one-success-with-names.js +++ b/test/fixtures/webpack.array.one-error-one-warning-one-success-with-names.js @@ -16,7 +16,7 @@ module.exports = [ infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }, { name: "warning", @@ -42,7 +42,7 @@ module.exports = [ infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }, { name: "success", @@ -66,6 +66,6 @@ module.exports = [ infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }, ]; diff --git a/test/fixtures/webpack.array.one-error-one-warning-one-success.js b/test/fixtures/webpack.array.one-error-one-warning-one-success.js index f3a378dab..180839a13 100644 --- a/test/fixtures/webpack.array.one-error-one-warning-one-success.js +++ b/test/fixtures/webpack.array.one-error-one-warning-one-success.js @@ -15,7 +15,7 @@ module.exports = [ infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }, { mode: 'development', @@ -40,7 +40,7 @@ module.exports = [ infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }, { mode: 'development', @@ -63,6 +63,6 @@ module.exports = [ infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }, ]; diff --git a/test/fixtures/webpack.config.js b/test/fixtures/webpack.config.js index ec601b6e6..41ab27dd0 100644 --- a/test/fixtures/webpack.config.js +++ b/test/fixtures/webpack.config.js @@ -22,5 +22,5 @@ module.exports = { infrastructureLogging: { level: 'none' }, - stats: 'errors-warnings' + stats: 'normal' }; diff --git a/test/fixtures/webpack.stats-colors-false.config.js b/test/fixtures/webpack.stats-colors-false.config.js new file mode 100644 index 000000000..6407a6e2a --- /dev/null +++ b/test/fixtures/webpack.stats-colors-false.config.js @@ -0,0 +1,28 @@ +'use strict'; + +const path = require('path'); + +module.exports = { + mode: 'development', + context: path.resolve(__dirname), + entry: './foo.js', + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, '../outputs/basic'), + }, + module: { + rules: [ + { + test: /\.(svg|html)$/, + loader: 'file-loader', + options: { name: '[name].[ext]' }, + }, + ], + }, + infrastructureLogging: { + level: 'none' + }, + stats: { + colors: false + } +}; diff --git a/test/fixtures/webpack.stats-colors-true.config.js b/test/fixtures/webpack.stats-colors-true.config.js new file mode 100644 index 000000000..67274f28c --- /dev/null +++ b/test/fixtures/webpack.stats-colors-true.config.js @@ -0,0 +1,28 @@ +'use strict'; + +const path = require('path'); + +module.exports = { + mode: 'development', + context: path.resolve(__dirname), + entry: './foo.js', + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, '../outputs/basic'), + }, + module: { + rules: [ + { + test: /\.(svg|html)$/, + loader: 'file-loader', + options: { name: '[name].[ext]' }, + }, + ], + }, + infrastructureLogging: { + level: 'none' + }, + stats: { + colors: true + } +}; diff --git a/test/fixtures/webpack.stats-false.config.js b/test/fixtures/webpack.stats-false.config.js new file mode 100644 index 000000000..bbf3256bb --- /dev/null +++ b/test/fixtures/webpack.stats-false.config.js @@ -0,0 +1,26 @@ +'use strict'; + +const path = require('path'); + +module.exports = { + mode: 'development', + context: path.resolve(__dirname), + entry: './foo.js', + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, '../outputs/basic'), + }, + module: { + rules: [ + { + test: /\.(svg|html)$/, + loader: 'file-loader', + options: { name: '[name].[ext]' }, + }, + ], + }, + infrastructureLogging: { + level: 'none' + }, + stats: false +}; diff --git a/test/fixtures/webpack.stats-minimal.config.js b/test/fixtures/webpack.stats-minimal.config.js new file mode 100644 index 000000000..81e2ccc5c --- /dev/null +++ b/test/fixtures/webpack.stats-minimal.config.js @@ -0,0 +1,26 @@ +'use strict'; + +const path = require('path'); + +module.exports = { + mode: 'development', + context: path.resolve(__dirname), + entry: './foo.js', + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, '../outputs/basic'), + }, + module: { + rules: [ + { + test: /\.(svg|html)$/, + loader: 'file-loader', + options: { name: '[name].[ext]' }, + }, + ], + }, + infrastructureLogging: { + level: 'none' + }, + stats: 'minimal' +}; diff --git a/test/fixtures/webpack.stats-none.config.js b/test/fixtures/webpack.stats-none.config.js new file mode 100644 index 000000000..ad0dedf12 --- /dev/null +++ b/test/fixtures/webpack.stats-none.config.js @@ -0,0 +1,26 @@ +'use strict'; + +const path = require('path'); + +module.exports = { + mode: 'development', + context: path.resolve(__dirname), + entry: './foo.js', + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, '../outputs/basic'), + }, + module: { + rules: [ + { + test: /\.(svg|html)$/, + loader: 'file-loader', + options: { name: '[name].[ext]' }, + }, + ], + }, + infrastructureLogging: { + level: 'none' + }, + stats: 'none' +}; diff --git a/test/fixtures/webpack.stats-object.config.js b/test/fixtures/webpack.stats-object.config.js new file mode 100644 index 000000000..8f605735e --- /dev/null +++ b/test/fixtures/webpack.stats-object.config.js @@ -0,0 +1,26 @@ +'use strict'; + +const path = require('path'); + +module.exports = { + mode: 'development', + context: path.resolve(__dirname), + entry: './foo.js', + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, '../outputs/basic'), + }, + module: { + rules: [ + { + test: /\.(svg|html)$/, + loader: 'file-loader', + options: { name: '[name].[ext]' }, + }, + ], + }, + infrastructureLogging: { + level: 'none' + }, + stats: { all: false, assets: true } +}; diff --git a/test/fixtures/webpack.stats-true.config.js b/test/fixtures/webpack.stats-true.config.js new file mode 100644 index 000000000..30a4255e5 --- /dev/null +++ b/test/fixtures/webpack.stats-true.config.js @@ -0,0 +1,26 @@ +'use strict'; + +const path = require('path'); + +module.exports = { + mode: 'development', + context: path.resolve(__dirname), + entry: './foo.js', + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, '../outputs/basic'), + }, + module: { + rules: [ + { + test: /\.(svg|html)$/, + loader: 'file-loader', + options: { name: '[name].[ext]' }, + }, + ], + }, + infrastructureLogging: { + level: 'none' + }, + stats: true +}; diff --git a/test/fixtures/webpack.stats-verbose.config.js b/test/fixtures/webpack.stats-verbose.config.js new file mode 100644 index 000000000..30bfe6198 --- /dev/null +++ b/test/fixtures/webpack.stats-verbose.config.js @@ -0,0 +1,26 @@ +'use strict'; + +const path = require('path'); + +module.exports = { + mode: 'development', + context: path.resolve(__dirname), + entry: './foo.js', + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, '../outputs/basic'), + }, + module: { + rules: [ + { + test: /\.(svg|html)$/, + loader: 'file-loader', + options: { name: '[name].[ext]' }, + }, + ], + }, + infrastructureLogging: { + level: 'none' + }, + stats: 'verbose' +}; diff --git a/test/helpers/GetLogsPlugin.js b/test/helpers/GetLogsPlugin.js deleted file mode 100644 index ef6c7fa6a..000000000 --- a/test/helpers/GetLogsPlugin.js +++ /dev/null @@ -1,50 +0,0 @@ -export default class GetLogsPlugin { - constructor() { - this.logs = []; - } - - static normalizeLogs(log, type) { - if (Array.isArray(log)) { - return log.map((nestedLog) => - GetLogsPlugin.normalizeLogs(nestedLog, type) - ); - } - - // TODO remove after webpack@4 dropping - if (type === 'error') { - return 'ERROR'; - } - - // TODO remove after webpack@4 dropping - if (type === 'warn') { - return 'WARNING'; - } - - // TODO remove after webpack@4 dropping - if (log.includes('modules')) { - return 'compiled successfully'; - } - - // TODO remove after webpack@4 dropping - if (log.includes('Entrypoint')) { - return 'Entrypoint main = bundle.js'; - } - - return log - .toString() - .trim() - .replace(process.cwd(), '/absolute/path/to') - .replace(/\\/g, '/'); - } - - apply(compiler) { - const hook = - compiler.hooks.infrastructurelog || compiler.hooks.infrastructureLog; - - hook.tap('GetLogsPlugin', (name, type, args) => { - this.logs.push([name, type, GetLogsPlugin.normalizeLogs(args, type)]); - - return false; - }); - } -} diff --git a/test/helpers/clearDirectory.js b/test/helpers/clearDirectory.js new file mode 100644 index 000000000..e88400a4f --- /dev/null +++ b/test/helpers/clearDirectory.js @@ -0,0 +1,26 @@ +import fs from 'fs'; + +function clearDirectory(dirPath) { + let files; + + try { + files = fs.readdirSync(dirPath); + } catch (e) { + return; + } + if (files.length > 0) { + for (let i = 0; i < files.length; i++) { + const filePath = `${dirPath}/${files[i]}`; + + if (fs.statSync(filePath).isFile()) { + fs.unlinkSync(filePath); + } else { + clearDirectory(filePath); + } + } + } + + fs.rmdirSync(dirPath); +} + +export default clearDirectory; diff --git a/test/helpers/getCompilerHooks.js b/test/helpers/getCompilerHooks.js index ba48bcc19..81376abcb 100644 --- a/test/helpers/getCompilerHooks.js +++ b/test/helpers/getCompilerHooks.js @@ -3,7 +3,7 @@ export default (compiler) => { for (const hook of Object.keys(compiler.hooks)) { for (const tap of compiler.hooks[hook].taps) { - if (tap.name === 'DevMiddleware') { + if (tap.name === 'webpack-dev-middleware') { if (!result[hook]) { result[hook] = []; } diff --git a/test/helpers/isWebpack5.js b/test/helpers/isWebpack5.js index 19e650c27..0d094b60d 100644 --- a/test/helpers/isWebpack5.js +++ b/test/helpers/isWebpack5.js @@ -1,5 +1,3 @@ import webpack from 'webpack'; -export default () => { - return webpack.version[0] === '5'; -}; +export default () => webpack.version[0] === '5'; diff --git a/test/helpers/listenAndCompile.js b/test/helpers/listenAndCompile.js index 013c5f3cf..3b2d70fa6 100644 --- a/test/helpers/listenAndCompile.js +++ b/test/helpers/listenAndCompile.js @@ -17,9 +17,7 @@ export default (app, compiler, done) => { return progress(); }); - compiler.hooks.done.tap('wdm-test', () => { - return progress(); - }); + compiler.hooks.done.tap('wdm-test', () => progress()); return listen; }; diff --git a/test/helpers/runner.js b/test/helpers/runner.js new file mode 100755 index 000000000..2fc5366d0 --- /dev/null +++ b/test/helpers/runner.js @@ -0,0 +1,130 @@ +#!/usr/bin/env node + +const express = require('express'); +const webpack = require('webpack'); +const merge = require('deepmerge'); + +const middleware = require('../../dist').default; + +const defaultConfig = require('../fixtures/webpack.config'); + +const configEntries = []; +const configMiddlewareEntries = []; + +fillConfigEntries('WCF_', configEntries); +fillConfigEntries('WMC_', configMiddlewareEntries); + +const config = createConfig(configEntries); +const unionConfig = + Object.keys(config).length > 0 + ? merge(getWebpackConfig(process.env.WEBPACK_CONFIG), config) + : getWebpackConfig(process.env.WEBPACK_CONFIG); +const configMiddleware = createConfig(configMiddlewareEntries); +const compiler = webpack(unionConfig || defaultConfig); +let instance; + +if (process.env.WEBPACK_BREAK_WATCH) { + compiler.watch = function watch() { + const error = new Error('Watch error'); + error.code = 'watch error'; + + throw error; + }; +} + +compiler.hooks.done.tap('plugin-test', () => { + process.stdout.write('compiled-for-tests'); +}); + +try { + instance = middleware(compiler, configMiddleware); +} catch (error) { + throw error; +} + +const app = express(); + +try { + app.use(instance); +} catch (error) { + throw error; +} + +app.listen((error) => { + if (error) { + throw error; + } + + let commands = []; + let incompleteCommand = ''; + + process.stdin.on('data', (chunk) => { + const entries = chunk.toString().split('|'); + + incompleteCommand += entries.shift(); + commands.push(incompleteCommand); + incompleteCommand = entries.pop(); + commands = commands.concat(entries); + + while (commands.length > 0) { + // eslint-disable-next-line default-case + switch (commands.shift()) { + // case 'invalidate': + // stdinInput = ''; + // instance.waitUntilValid(() => { + // instance.invalidate(); + // }); + // break; + case 'exit': + process.exit(); + break; + } + } + }); +}); + +function getWebpackConfig(name) { + try { + // eslint-disable-next-line global-require,import/no-dynamic-require + return require(`../fixtures/${name}`); + } catch (error) { + // eslint-disable-next-line global-require + return require(`../fixtures/webpack.config`); + } +} + +function createConfig(data) { + function getObject(entry) { + return { [entry[0]]: entry[1] }; + } + + function reduceObject(arr) { + if (arr.length > 1) { + const temp = []; + temp.push(arr.pop()); + temp.push(arr.pop()); + + return reduceObject([...arr, getObject(temp.reverse())]); + } + + return arr[0]; + } + + const result = data.map((el) => reduceObject([...el])); + + return merge.all(result); +} + +function fillConfigEntries(NSKey, accumulator) { + Object.keys(process.env) + .filter((key) => key.indexOf(NSKey) === 0) + .forEach((key) => { + let value = process.env[key]; + const keys = key.replace(NSKey, '').split('_'); + + value = value === 'true' ? true : value === 'false' ? false : value; + + keys.push(value); + accumulator.push(keys); + }); +} diff --git a/test/helpers/snapshotResolver.js b/test/helpers/snapshotResolver.js new file mode 100644 index 000000000..742ee5b60 --- /dev/null +++ b/test/helpers/snapshotResolver.js @@ -0,0 +1,28 @@ +const path = require('path'); + +const webpack = require('webpack'); + +// eslint-disable-next-line global-require +const [webpackVersion] = webpack.version; +const snapshotExtension = `.snap.webpack${webpackVersion}`; + +// eslint-disable-next-line no-console +console.log('Current webpack version:', webpackVersion); + +module.exports = { + resolveSnapshotPath: (testPath) => + path.join( + path.dirname(testPath), + '__snapshots__', + `${path.basename(testPath)}${snapshotExtension}` + ), + resolveTestPath: (snapshotPath) => + snapshotPath + .replace(`${path.sep}__snapshots__`, '') + .slice(0, -snapshotExtension.length), + testPathForConsistencyCheck: path.join( + 'consistency_check', + '__tests__', + 'example.test.js' + ), +}; diff --git a/test/logging.test.js b/test/logging.test.js new file mode 100644 index 000000000..a8fa18b76 --- /dev/null +++ b/test/logging.test.js @@ -0,0 +1,763 @@ +import fs from 'fs'; +import path from 'path'; +import os from 'os'; + +import execa from 'execa'; +import stripAnsi from 'strip-ansi'; + +function extractErrorEntry(string) { + const matches = string.match(/error:\s\D[^:||\n||\r]+/gim); + + return matches === null ? null : matches[0]; +} + +function stdoutToSnapshot(stdout) { + let cleanedStdout = stripAnsi(stdout.trim()); + + // Bugs in `strip-ansi` + cleanedStdout = cleanedStdout.replace(/null main /g, 'main'); + cleanedStdout = cleanedStdout.replace(/(\d+):(\d+)-(\d+) /g, '$1:$2-$3'); + cleanedStdout = cleanedStdout.replace(/> (.+) {2}(.+)/g, '> $1 $2'); + + cleanedStdout = cleanedStdout.replace(/\| /g, '|'); + cleanedStdout = cleanedStdout.replace(/compiled-for-tests/g, ''); + cleanedStdout = cleanedStdout.replace(/\d+.\d+ KiB/g, 'x KiB'); + cleanedStdout = cleanedStdout.replace(/\d+ bytes/g, 'x bytes'); + cleanedStdout = cleanedStdout.replace(/\d+ assets/g, 'x assets'); + + cleanedStdout = cleanedStdout.replace(/\d+ modules/g, 'x modules'); + cleanedStdout = cleanedStdout.replace(/in \d+ ms/g, 'in x ms'); + + cleanedStdout = cleanedStdout.replace( + /LOG from .+webpack/s, + 'LOG from xxx\n...\nwebpack' + ); + cleanedStdout = cleanedStdout.replace( + /webpack \d+.\d+.\d+/g, + 'webpack x.x.x' + ); + cleanedStdout = cleanedStdout.replace(/\([0-9a-z]+\)/g, '(xxxx)'); + + // webpack@4 + cleanedStdout = cleanedStdout.replace(/Hash: [0-9a-z]+/g, 'Hash: xxxx'); + cleanedStdout = cleanedStdout.replace(/Time: \d+ms/g, 'Time: Xms'); + cleanedStdout = cleanedStdout.replace(/Built at: .+/g, 'Built at: x'); + cleanedStdout = cleanedStdout.replace(/LOG from .+$/s, 'LOG from xxx'); + cleanedStdout = cleanedStdout.replace( + / {3}([a-z]+)\.([a-z]+) +x KiB +\[emitted] +/s, + ' $1.$2 x KiB [emitted]' + ); + + return cleanedStdout; +} + +function stderrToSnapshot(stderr) { + const cleanedStderr = stderr.trim(); + + const matches = stderr.match(/error:\s\D[^:||\n||\r]+/gim); + + if (matches !== null) { + return matches[0]; + } + + return cleanedStderr; +} + +const runner = path.resolve(__dirname, './helpers/runner.js'); + +describe('logging', () => { + it('should logging on successfully build', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.config', + FORCE_COLOR: true, + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdout).toContain('\u001b[1m'); + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build and respect colors', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.stats-colors-true.config.js', + FORCE_COLOR: true, + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdout).toContain('\u001b[1m'); + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build and respect colors #2', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.stats-colors-false.config.js', + FORCE_COLOR: true, + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdout).not.toContain('\u001b[1m'); + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build and respect the "stats" option from configuration with the "none" value', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.stats-none.config.js', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build and respect the "stats" option from configuration with the "minimal" value', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.stats-minimal.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build and respect the "stats" option from configuration with the "verbose" value', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.stats-verbose.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build and respect the "stats" option from configuration with the "true" value', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.stats-true.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build and respect the "stats" option from configuration with the "false" value', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.stats-false.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build and respect the "stats" option from configuration with custom object value', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.stats-object.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on successfully build in multi-compiler mode', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + FORCE_COLOR: true, + WEBPACK_CONFIG: 'webpack.array.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdout).toContain('\u001b[1m'); + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on unsuccessful build', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.error.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging on unsuccessful build in multi-compiler', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.array.error.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging an warning', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.warning.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging warnings in multi-compiler mode', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.array.warning.config', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging in multi-compiler and respect the "stats" option from configuration', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.array.one-error-one-warning-one-success', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging in multi-compiler and respect the "stats" option from configuration #2', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: + 'webpack.array.one-error-one-warning-one-success-with-names', + }, + }); + } catch (error) { + throw error; + } + + let stdout = ''; + let stderr = ''; + + proc.stdout.on('data', (chunk) => { + stdout += chunk.toString(); + + if (/compiled-for-tests/gi.test(stdout)) { + proc.stdin.write('|exit|'); + } + }); + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stdoutToSnapshot(stdout)).toMatchSnapshot('stdout'); + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + it('should logging an error in "watch" method', (done) => { + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_BREAK_WATCH: true, + }, + }); + } catch (error) { + throw error; + } + + let stderr = ''; + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(stderrToSnapshot(stderr)).toMatchSnapshot('stderr'); + + done(); + }); + }); + + if (os.platform() !== 'win32') { + it('should logging an error from the fs error when the "writeToDisk" option is "true"', async (done) => { + // eslint-disable-next-line global-require + const clearDirectory = require('./helpers/clearDirectory').default; + const outputDir = path.resolve( + __dirname, + './outputs/write-to-disk-mkdir-error' + ); + + if (!fs.existsSync(outputDir)) { + fs.mkdirSync(outputDir); + } + + fs.chmodSync(outputDir, 0o400); + + let proc; + + try { + proc = execa(runner, [], { + stdio: 'pipe', + env: { + WEBPACK_CONFIG: 'webpack.simple.config', + WCF_output_filename: 'bundle.js', + WCF_output_path: outputDir, + WCF_infrastructureLogging_level: 'log', + WMC_writeToDisk: true, + }, + }); + } catch (error) { + throw error; + } + + let stderr = ''; + + proc.stderr.on('data', (chunk) => { + stderr += chunk.toString(); + proc.stdin.write('|exit|'); + }); + + proc.on('exit', () => { + expect(extractErrorEntry(stderr)).toMatch('Error: EACCES'); + + fs.chmodSync(outputDir, 0o700); + clearDirectory(outputDir); + + done(); + }); + }); + } +}); diff --git a/test/middleware.test.js b/test/middleware.test.js index 370e6f058..68debd56e 100644 --- a/test/middleware.test.js +++ b/test/middleware.test.js @@ -10,22 +10,17 @@ import del from 'del'; import middleware from '../src'; import getCompiler from './helpers/getCompiler'; -import GetLogsPlugin from './helpers/GetLogsPlugin'; import isWebpack5 from './helpers/isWebpack5'; import webpackConfig from './fixtures/webpack.config'; -import webpackSimpleConfig from './fixtures/webpack.simple.config'; import webpackMultiConfig from './fixtures/webpack.array.config'; import webpackWatchOptionsConfig from './fixtures/webpack.watch-options.config'; import webpackMultiWatchOptionsConfig from './fixtures/webpack.array.watch-options.config'; import webpackQueryStringConfig from './fixtures/webpack.querystring.config'; import webpackClientServerConfig from './fixtures/webpack.client.server.config'; -import webpackErrorConfig from './fixtures/webpack.error.config'; -import webpackMultiErrorConfig from './fixtures/webpack.array.error.config'; -import webpackWarningConfig from './fixtures/webpack.warning.config'; -import webpackMultiWarningConfig from './fixtures/webpack.array.warning.config'; -import webpackOneErrorOneWarningOneSuccessConfig from './fixtures/webpack.array.one-error-one-warning-one-success'; -import webpackOneErrorOneWarningOneSuccessWithNamesConfig from './fixtures/webpack.array.one-error-one-warning-one-success-with-names'; + +// Suppress unnecessary stats output +global.console.log = jest.fn(); describe.each([ ['express', express], @@ -290,7 +285,6 @@ describe.each([ request(app) .get('/unknown') .expect('Content-Length', fileData.byteLength.toString()) - .expect('Content-Type', 'application/octet-stream') .expect(200, done); }); }); @@ -584,7 +578,6 @@ describe.each([ urls: [ { value: 'filename-name-with-dots/mono-v6.x.x', - contentType: 'application/octet-stream', code: 200, }, ], @@ -595,7 +588,6 @@ describe.each([ urls: [ { value: 'noextension', - contentType: 'application/octet-stream', code: 200, }, ], @@ -812,12 +804,19 @@ describe.each([ it(`should return the "${code}" code for the "GET" request for the "${value}" url`, (done) => { request(app) .get(`${publicPathForRequest}${value}`) - .expect('Content-Type', contentType) .expect( 'Content-Length', data ? String(data.length) : /\d+/ ) - .expect(code, done); + .expect(code) + .then((res) => { + if (contentType) { + expect(res.headers['content-type']).toEqual( + contentType + ); + } + }) + .then(done); }); } } @@ -835,11 +834,14 @@ describe.each([ app.use((req, res, next) => { // Express API if (res.set) { - res.set('Content-Type', 'application/octet-stream'); + res.set('Content-Type', 'application/vnd.test+octet-stream'); } // Connect API else { - res.setHeader('Content-Type', 'application/octet-stream'); + res.setHeader( + 'Content-Type', + 'application/vnd.test+octet-stream' + ); } next(); }); @@ -850,10 +852,10 @@ describe.each([ afterAll(close); - it('should not guess a MIME type if the "Content-Type" header is found', (done) => { + it('should not modify the "Content-Type" header', (done) => { request(app) .get('/bundle.js') - .expect('Content-Type', 'application/octet-stream') + .expect('Content-Type', 'application/vnd.test+octet-stream') .expect(200, done); }); }); @@ -1583,18 +1585,22 @@ describe.each([ }); }); - describe('should respect the "stats" option with the "false" value from the configuration', () => { - let compiler; - let getLogsPlugin; - + describe('should handle an earlier request if a change happened while compiling', () => { beforeAll((done) => { - compiler = getCompiler({ ...webpackConfig, stats: false }); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const compiler = getCompiler(webpackConfig); instance = middleware(compiler); + let invalidated = false; + + compiler.hooks.done.tap('Invalidated', () => { + if (!invalidated) { + instance.invalidate(); + + invalidated = true; + } + }); + app = framework(); app.use(instance); @@ -1604,29 +1610,22 @@ describe.each([ afterAll(close); it('should return the "200" code for the "GET" request to the bundle file', (done) => { - request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - expect(getLogsPlugin.logs).toMatchSnapshot(); - - return done(); - }); + request(app).get('/bundle.js').expect(200, done); }); }); + }); - describe('should respect the "stats" option with the "none" value from the configuration', () => { - let compiler; - let getLogsPlugin; - + describe('mimeTypes option', () => { + describe('should set the correct value for "Content-Type" header to known MIME type', () => { beforeAll((done) => { - compiler = getCompiler({ ...webpackConfig, stats: 'none' }); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: outputPath, + }, + }); instance = middleware(compiler); @@ -1634,123 +1633,163 @@ describe.each([ app.use(instance); listen = listenShorthand(done); + + instance.context.outputFileSystem.mkdirSync(outputPath, { + recursive: true, + }); + instance.context.outputFileSystem.writeFileSync( + path.resolve(outputPath, 'file.html'), + 'welcome' + ); }); afterAll(close); - it('should return the "200" code for the "GET" request to the bundle file', (done) => { + it('should return the "200" code for the "GET" request to "file.html"', (done) => { request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - expect(getLogsPlugin.logs).toMatchSnapshot(); - - return done(); - }); + .get('/file.html') + .expect('Content-Type', 'text/html; charset=utf-8') + .expect(200, 'welcome', done); }); }); - describe('should respect the "stats" option with the "minimal" value from the configuration', () => { - let compiler; - let getLogsPlugin; - + describe('should set the correct value for "Content-Type" header to specified MIME type', () => { beforeAll((done) => { - compiler = getCompiler({ ...webpackConfig, stats: 'minimal' }); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: outputPath, + }, + }); - instance = middleware(compiler); + instance = middleware(compiler, { + mimeTypes: { + myhtml: 'text/html', + }, + }); app = framework(); app.use(instance); listen = listenShorthand(done); + + instance.context.outputFileSystem.mkdirSync(outputPath, { + recursive: true, + }); + instance.context.outputFileSystem.writeFileSync( + path.resolve(outputPath, 'file.myhtml'), + 'welcome' + ); }); afterAll(close); - it('should return the "200" code for the "GET" request to the bundle file', (done) => { + it('should return the "200" code for the "GET" request "file.phtml"', (done) => { request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - expect(getLogsPlugin.logs).toMatchSnapshot(); - - return done(); - }); + .get('/file.myhtml') + .expect('Content-Type', 'text/html; charset=utf-8') + .expect(200, 'welcome', done); }); }); - describe('should respect the "stats" option in multi-compiler mode', () => { - let compiler; - let getLogsPlugin; - + describe('should override value for "Content-Type" header for known MIME type', () => { beforeAll((done) => { - compiler = getCompiler(webpackOneErrorOneWarningOneSuccessConfig); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: outputPath, + }, + }); - instance = middleware(compiler); + instance = middleware(compiler, { + mimeTypes: { + jpg: 'image/vnd.test+jpeg', + }, + }); app = framework(); app.use(instance); listen = listenShorthand(done); + + instance.context.outputFileSystem.mkdirSync(outputPath, { + recursive: true, + }); + instance.context.outputFileSystem.writeFileSync( + path.resolve(outputPath, 'file.jpg'), + 'welcome' + ); }); afterAll(close); - it('should return the "200" code for the "GET" requests to bundles file', (done) => { + it('should return the "200" code for the "GET" request "file.jpg"', (done) => { request(app) - .get('/static-one/bundle.js') - .expect(200, (firstError) => { - if (firstError) { - return done(firstError); - } + .get('/file.jpg') + .expect('Content-Type', 'image/vnd.test+jpeg') + .expect(200, done); + }); + }); - return request(app) - .get('/static-two/bundle.js') - .expect(200, (secondError) => { - if (secondError) { - return done(secondError); - } + describe('should not set "Content-Type" header for route not from outputFileSystem', () => { + beforeAll((done) => { + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: outputPath, + }, + }); - return request(app) - .get('/static-three/bundle.js') - .expect(200, (thirdError) => { - if (thirdError) { - return done(thirdError); - } + instance = middleware(compiler, { + mimeTypes: { + jpg: 'image/vnd.test+jpeg', + }, + }); - expect(getLogsPlugin.logs).toMatchSnapshot(); + app = framework(); + app.use(instance); - return done(); - }); - }); - }); + app.use('/file.jpg', (req, res) => { + // Express API + if (res.send) { + res.send('welcome'); + } + // Connect API + else { + res.setHeader('Content-Type', 'text/html'); + res.end('welcome'); + } + }); + + listen = listenShorthand(done); + }); + + afterAll(close); + + it('should return the "200" code for the "GET" request "file.jpg" with default content type', (done) => { + request(app) + .get('/file.jpg') + .expect('Content-Type', /text\/html/) + .expect(200, done); }); }); + }); - describe('should respect the "stats" option with the "{ all: false, entrypoints: true }" value from the configuration', () => { + describe('watchOptions option', () => { + describe('should work without value', () => { let compiler; - let getLogsPlugin; + let spy; beforeAll((done) => { - compiler = getCompiler({ - ...webpackConfig, - stats: { all: false, entrypoints: true }, - }); + compiler = getCompiler(webpackConfig); - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + spy = jest.spyOn(compiler, 'watch'); instance = middleware(compiler); @@ -1760,9 +1799,13 @@ describe.each([ listen = listenShorthand(done); }); - afterAll(close); + afterAll((done) => { + spy.mockRestore(); - it('should return the "200" code for the "GET" request to the bundle file', (done) => { + close(done); + }); + + it('should pass arguments to the "watch" method', (done) => { request(app) .get('/bundle.js') .expect(200, (error) => { @@ -1770,22 +1813,22 @@ describe.each([ return done(error); } - expect(getLogsPlugin.logs).toMatchSnapshot(); + expect(spy).toHaveBeenCalledTimes(1); + expect(spy.mock.calls[0][0]).toEqual({}); return done(); }); }); }); - describe('should respect the "stats" option from the configuration in multi-compiler mode', () => { + describe('should respect options from the configuration', () => { let compiler; - let getLogsPlugin; + let spy; beforeAll((done) => { - compiler = getCompiler(webpackMultiWarningConfig); + compiler = getCompiler(webpackWatchOptionsConfig); - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + spy = jest.spyOn(compiler, 'watch'); instance = middleware(compiler); @@ -1795,42 +1838,39 @@ describe.each([ listen = listenShorthand(done); }); - afterAll(close); + afterAll((done) => { + spy.mockRestore(); + + close(done); + }); - it('should return the "200" code for the "GET" request to bundle files', (done) => { + it('should pass arguments to the "watch" method', (done) => { request(app) - .get('/static-one/bundle.js') - .expect(200, (firstError) => { - if (firstError) { - return done(firstError); + .get('/bundle.js') + .expect(200, (error) => { + if (error) { + return done(done); } - return request(app) - .get('/static-two/bundle.js') - .expect(200, (secondError) => { - if (secondError) { - return done(secondError); - } - - expect(getLogsPlugin.logs).toMatchSnapshot(); + expect(spy).toHaveBeenCalledTimes(1); + expect(spy.mock.calls[0][0]).toEqual({ + aggregateTimeout: 300, + poll: true, + }); - return done(); - }); + return done(error); }); }); }); - describe('should respect the "stats" option from the configuration in multi-compiler mode and use the "name" option', () => { + describe('should respect options from the configuration in multi-compile mode', () => { let compiler; - let getLogsPlugin; + let spy; beforeAll((done) => { - compiler = getCompiler( - webpackOneErrorOneWarningOneSuccessWithNamesConfig - ); + compiler = getCompiler(webpackMultiWatchOptionsConfig); - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + spy = jest.spyOn(compiler, 'watch'); instance = middleware(compiler); @@ -1840,9 +1880,13 @@ describe.each([ listen = listenShorthand(done); }); - afterAll(close); + afterAll((done) => { + spy.mockRestore(); - it('should return the "200" code for "GET" requests to bundle files', (done) => { + close(done); + }); + + it('should pass arguments to the "watch" method', (done) => { request(app) .get('/static-one/bundle.js') .expect(200, (firstError) => { @@ -1857,33 +1901,33 @@ describe.each([ return done(secondError); } - return request(app) - .get('/static-three/bundle.js') - .expect(200, (thirdError) => { - if (thirdError) { - return done(thirdError); - } - - expect(getLogsPlugin.logs).toMatchSnapshot(); - - return done(); - }); - }); + expect(spy).toHaveBeenCalledTimes(1); + expect(spy.mock.calls[0][0]).toEqual([ + { aggregateTimeout: 800, poll: false }, + { aggregateTimeout: 300, poll: true }, + ]); + + return done(); + }); }); }); }); + }); - describe('should throw an error on "run" when we watching', () => { + describe('writeToDisk option', () => { + describe('should work with "true" value', () => { let compiler; - let getLogsPlugin; beforeAll((done) => { - compiler = getCompiler(webpackConfig); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, './outputs/write-to-disk-true'), + }, + }); - instance = middleware(compiler); + instance = middleware(compiler, { writeToDisk: true }); app = framework(); app.use(instance); @@ -1891,9 +1935,15 @@ describe.each([ listen = listenShorthand(done); }); - afterAll(close); + afterAll((done) => { + del.sync( + path.posix.resolve(__dirname, './outputs/write-to-disk-true') + ); + + close(done); + }); - it('should logging an error', (done) => { + it('should find the bundle file on disk', (done) => { request(app) .get('/bundle.js') .expect(200, (error) => { @@ -1901,28 +1951,49 @@ describe.each([ return done(error); } - return compiler.run((runError) => { - expect(() => { - throw runError; - }).toThrowErrorMatchingSnapshot(); + const bundlePath = path.resolve( + __dirname, + './outputs/write-to-disk-true/bundle.js' + ); + + expect( + compiler.hooks.assetEmitted.taps.filter( + (hook) => hook.name === 'DevMiddleware' + ).length + ).toBe(1); + expect(fs.existsSync(bundlePath)).toBe(true); + + instance.invalidate(); - done(); - }); + return compiler.hooks.done.tap( + 'DevMiddlewareWriteToDiskTest', + () => { + expect( + compiler.hooks.assetEmitted.taps.filter( + (hook) => hook.name === 'DevMiddleware' + ).length + ).toBe(1); + + done(); + } + ); }); }); }); - describe('should throw an error on "watch" when we watching', () => { + describe('should work with "false" value', () => { let compiler; - let getLogsPlugin; beforeAll((done) => { - compiler = getCompiler(webpackConfig); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: path.resolve(__dirname, './outputs/write-to-disk-false'), + }, + }); - instance = middleware(compiler); + instance = middleware(compiler, { writeToDisk: false }); app = framework(); app.use(instance); @@ -1932,7 +2003,7 @@ describe.each([ afterAll(close); - it('should logging an error', (done) => { + it('should not find the bundle file on disk', (done) => { request(app) .get('/bundle.js') .expect(200, (error) => { @@ -1940,261 +2011,164 @@ describe.each([ return done(error); } - return compiler.watch({}, (watchError) => { - expect(() => { - throw watchError; - }).toThrowErrorMatchingSnapshot(); - - done(); - }); - }); - }); - }); - - describe('should handle an earlier request if a change happened while compiling', () => { - beforeAll((done) => { - const compiler = getCompiler(webpackConfig); - - instance = middleware(compiler); + const bundlePath = path.resolve( + __dirname, + './outputs/write-to-disk-false/bundle.js' + ); - let invalidated = false; + expect( + compiler.hooks.assetEmitted.taps.filter( + (hook) => hook.name === 'DevMiddleware' + ).length + ).toBe(0); + expect(fs.existsSync(bundlePath)).toBe(false); - compiler.hooks.done.tap('Invalidated', () => { - if (!invalidated) { instance.invalidate(); - invalidated = true; - } - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); + return compiler.hooks.done.tap( + 'DevMiddlewareWriteToDiskTest', + () => { + expect( + compiler.hooks.assetEmitted.taps.filter( + (hook) => hook.name === 'DevMiddleware' + ).length + ).toBe(0); - it('should return the "200" code for the "GET" request to the bundle file', (done) => { - request(app).get('/bundle.js').expect(200, done); + done(); + } + ); + }); }); }); - }); - describe('mimeTypes option', () => { - describe('should set the correct value for "Content-Type" header to known MIME type', () => { + describe('should work with "Function" value when it returns "true"', () => { + let compiler; + beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ + compiler = getCompiler({ ...webpackConfig, output: { filename: 'bundle.js', - path: outputPath, + path: path.resolve( + __dirname, + './outputs/write-to-disk-function-true' + ), }, }); - instance = middleware(compiler); + instance = middleware(compiler, { + writeToDisk: (filePath) => /bundle\.js$/.test(filePath), + }); app = framework(); app.use(instance); listen = listenShorthand(done); + }); - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, - }); - instance.context.outputFileSystem.writeFileSync( - path.resolve(outputPath, 'file.html'), - 'welcome' + afterAll((done) => { + del.sync( + path.posix.resolve( + __dirname, + './outputs/write-to-disk-function-true' + ) ); - }); - afterAll(close); + close(done); + }); - it('should return the "200" code for the "GET" request to "file.html"', (done) => { + it('should find the bundle file on disk', (done) => { request(app) - .get('/file.html') - .expect('Content-Type', 'text/html; charset=utf-8') - .expect(200, 'welcome', done); + .get('/bundle.js') + .expect(200, (error) => { + if (error) { + return done(error); + } + + const bundlePath = path.resolve( + __dirname, + './outputs/write-to-disk-function-true/bundle.js' + ); + + expect(fs.existsSync(bundlePath)).toBe(true); + + return done(); + }); }); }); - describe('should set the correct value for "Content-Type" header to unknown MIME type', () => { + describe('should work with "Function" value when it returns "false"', () => { + let compiler; + beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ + compiler = getCompiler({ ...webpackConfig, output: { filename: 'bundle.js', - path: outputPath, + path: path.resolve( + __dirname, + './outputs/write-to-disk-function-false' + ), }, }); - instance = middleware(compiler); + instance = middleware(compiler, { + writeToDisk: (filePath) => !/bundle\.js$/.test(filePath), + }); app = framework(); app.use(instance); listen = listenShorthand(done); + }); - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, - }); - instance.context.outputFileSystem.writeFileSync( - path.resolve(outputPath, 'file.phtml'), - 'welcome' + afterAll((done) => { + del.sync( + path.posix.resolve( + __dirname, + './outputs/write-to-disk-function-false' + ) ); - }); - afterAll(close); + close(done); + }); - it('should return the "200" code for the "GET" request to "file.phtml"', (done) => { + it('should not find the bundle file on disk', (done) => { request(app) - .get('/file.phtml') - .expect('Content-Type', 'application/octet-stream') - .expect(200, done); + .get('/bundle.js') + .expect(200, (error) => { + if (error) { + return done(error); + } + + const bundlePath = path.resolve( + __dirname, + './outputs/write-to-disk-function-false/bundle.js' + ); + + expect(fs.existsSync(bundlePath)).toBe(false); + + return done(); + }); }); }); - describe('should set the correct value for "Content-Type" header to specified MIME type', () => { + describe('should work when assets have query string', () => { + let compiler; + beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ - ...webpackConfig, + compiler = getCompiler({ + ...webpackQueryStringConfig, output: { - filename: 'bundle.js', - path: outputPath, + filename: 'bundle.js?[contenthash]', + path: path.resolve( + __dirname, + './outputs/write-to-disk-query-string' + ), }, }); - instance = middleware(compiler, { - mimeTypes: { - myhtml: 'text/html', - }, - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, - }); - instance.context.outputFileSystem.writeFileSync( - path.resolve(outputPath, 'file.myhtml'), - 'welcome' - ); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request "file.phtml"', (done) => { - request(app) - .get('/file.myhtml') - .expect('Content-Type', 'text/html; charset=utf-8') - .expect(200, 'welcome', done); - }); - }); - - describe('should override value for "Content-Type" header for known MIME type', () => { - beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: outputPath, - }, - }); - - instance = middleware(compiler, { - mimeTypes: { - jpg: 'application/octet-stream', - }, - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, - }); - instance.context.outputFileSystem.writeFileSync( - path.resolve(outputPath, 'file.jpg'), - 'welcome' - ); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request "file.jpg"', (done) => { - request(app) - .get('/file.jpg') - .expect('Content-Type', /application\/octet-stream/) - .expect(200, done); - }); - }); - - describe('should not set "Content-Type" header for route not from outputFileSystem', () => { - beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: outputPath, - }, - }); - - instance = middleware(compiler, { - mimeTypes: { - jpg: 'application/octet-stream', - }, - }); - - app = framework(); - app.use(instance); - - app.use('/file.jpg', (req, res) => { - // Express API - if (res.send) { - res.send('welcome'); - } - // Connect API - else { - res.setHeader('Content-Type', 'text/html'); - res.end('welcome'); - } - }); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request "file.jpg" with default content type', (done) => { - request(app) - .get('/file.jpg') - .expect('Content-Type', /text\/html/) - .expect(200, done); - }); - }); - }); - - describe('watchOptions option', () => { - describe('should work without value', () => { - let compiler; - let spy; - - beforeAll((done) => { - compiler = getCompiler(webpackConfig); - - spy = jest.spyOn(compiler, 'watch'); - - instance = middleware(compiler); + instance = middleware(compiler, { writeToDisk: true }); app = framework(); app.use(instance); @@ -2203,12 +2177,17 @@ describe.each([ }); afterAll((done) => { - spy.mockRestore(); + del.sync( + path.posix.resolve( + __dirname, + './outputs/write-to-disk-query-string' + ) + ); close(done); }); - it('should pass arguments to the "watch" method', (done) => { + it('should find the bundle file on disk with no querystring', (done) => { request(app) .get('/bundle.js') .expect(200, (error) => { @@ -2216,66 +2195,48 @@ describe.each([ return done(error); } - expect(spy).toHaveBeenCalledTimes(1); - expect(spy.mock.calls[0][0]).toEqual({}); - - return done(); - }); - }); - }); - - describe('should respect options from the configuration', () => { - let compiler; - let spy; - - beforeAll((done) => { - compiler = getCompiler(webpackWatchOptionsConfig); - - spy = jest.spyOn(compiler, 'watch'); - - instance = middleware(compiler); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll((done) => { - spy.mockRestore(); - - close(done); - }); - - it('should pass arguments to the "watch" method', (done) => { - request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(done); - } + const bundlePath = path.resolve( + __dirname, + './outputs/write-to-disk-query-string/bundle.js' + ); - expect(spy).toHaveBeenCalledTimes(1); - expect(spy.mock.calls[0][0]).toEqual({ - aggregateTimeout: 300, - poll: true, - }); + expect(fs.existsSync(bundlePath)).toBe(true); - return done(error); + return done(); }); }); }); - describe('should respect options from the configuration in multi-compile mode', () => { + describe('should work in multi-compiler mode', () => { let compiler; - let spy; beforeAll((done) => { - compiler = getCompiler(webpackMultiWatchOptionsConfig); - - spy = jest.spyOn(compiler, 'watch'); + compiler = getCompiler([ + { + ...webpackMultiWatchOptionsConfig[0], + output: { + filename: 'bundle.js', + path: path.resolve( + __dirname, + './outputs/write-to-disk-multi-compiler/static-one' + ), + publicPath: '/static-one/', + }, + }, + { + ...webpackMultiWatchOptionsConfig[1], + output: { + filename: 'bundle.js', + path: path.resolve( + __dirname, + './outputs/write-to-disk-multi-compiler/static-two' + ), + publicPath: '/static-two/', + }, + }, + ]); - instance = middleware(compiler); + instance = middleware(compiler, { writeToDisk: true }); app = framework(); app.use(instance); @@ -2284,12 +2245,17 @@ describe.each([ }); afterAll((done) => { - spy.mockRestore(); + del.sync( + path.posix.resolve( + __dirname, + './outputs/write-to-disk-multi-compiler/' + ) + ); close(done); }); - it('should pass arguments to the "watch" method', (done) => { + it('should find the bundle files on disk', (done) => { request(app) .get('/static-one/bundle.js') .expect(200, (firstError) => { @@ -2303,30 +2269,48 @@ describe.each([ if (secondError) { return done(secondError); } + const bundleFiles = [ + './outputs/write-to-disk-multi-compiler/static-one/bundle.js', + './outputs/write-to-disk-multi-compiler/static-one/index.html', + './outputs/write-to-disk-multi-compiler/static-one/svg.svg', + './outputs/write-to-disk-multi-compiler/static-two/bundle.js', + ]; - expect(spy).toHaveBeenCalledTimes(1); - expect(spy.mock.calls[0][0]).toEqual([ - { aggregateTimeout: 800, poll: false }, - { aggregateTimeout: 300, poll: true }, - ]); + for (const bundleFile of bundleFiles) { + const bundlePath = path.resolve(__dirname, bundleFile); + + expect(fs.existsSync(bundlePath)).toBe(true); + } return done(); }); }); }); }); - }); - describe('writeToDisk option', () => { - describe('should work with "true" value', () => { + describe('should work with "[hash]"/"[fullhash]" in the "output.path" and "output.publicPath" option', () => { let compiler; + let hash; beforeAll((done) => { compiler = getCompiler({ ...webpackConfig, - output: { - filename: 'bundle.js', - path: path.resolve(__dirname, './outputs/write-to-disk-true'), + ...{ + output: { + filename: 'bundle.js', + publicPath: isWebpack5() + ? '/static/[fullhash]/' + : '/static/[hash]/', + path: isWebpack5() + ? path.resolve( + __dirname, + './outputs/write-to-disk-with-hash/dist_[fullhash]' + ) + : path.resolve( + __dirname, + './outputs/write-to-disk-with-hash/dist_[hash]' + ), + }, }, }); @@ -2335,12 +2319,17 @@ describe.each([ app = framework(); app.use(instance); - listen = listenShorthand(done); + listen = listenShorthand(() => { + compiler.hooks.afterCompile.tap('wdm-test', ({ hash: h }) => { + hash = h; + done(); + }); + }); }); afterAll((done) => { del.sync( - path.posix.resolve(__dirname, './outputs/write-to-disk-true') + path.posix.resolve(__dirname, './outputs/write-to-disk-with-hash/') ); close(done); @@ -2348,7 +2337,7 @@ describe.each([ it('should find the bundle file on disk', (done) => { request(app) - .get('/bundle.js') + .get(`/static/${hash}/bundle.js`) .expect(200, (error) => { if (error) { return done(error); @@ -2356,168 +2345,98 @@ describe.each([ const bundlePath = path.resolve( __dirname, - './outputs/write-to-disk-true/bundle.js' + `./outputs/write-to-disk-with-hash/dist_${hash}/bundle.js` ); - expect( - compiler.hooks.assetEmitted.taps.filter( - (hook) => hook.name === 'DevMiddleware' - ).length - ).toBe(1); expect(fs.existsSync(bundlePath)).toBe(true); - instance.invalidate(); - - return compiler.hooks.done.tap( - 'DevMiddlewareWriteToDiskTest', - () => { - expect( - compiler.hooks.assetEmitted.taps.filter( - (hook) => hook.name === 'DevMiddleware' - ).length - ).toBe(1); - - done(); - } - ); + return done(); }); }); }); + }); - describe('should work with "false" value', () => { - let compiler; - - beforeAll((done) => { - compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: path.resolve(__dirname, './outputs/write-to-disk-false'), - }, - }); - - instance = middleware(compiler, { writeToDisk: false }); + describe('methods option', () => { + let compiler; - app = framework(); - app.use(instance); + beforeAll((done) => { + compiler = getCompiler(webpackConfig); - listen = listenShorthand(done); + instance = middleware(compiler, { + methods: ['POST'], + publicPath: '/public/', }); - afterAll(close); - - it('should not find the bundle file on disk', (done) => { - request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - const bundlePath = path.resolve( - __dirname, - './outputs/write-to-disk-false/bundle.js' - ); - - expect( - compiler.hooks.assetEmitted.taps.filter( - (hook) => hook.name === 'DevMiddleware' - ).length - ).toBe(0); - expect(fs.existsSync(bundlePath)).toBe(false); + app = framework(); + app.use(instance); - instance.invalidate(); + listen = listenShorthand(done); + }); - return compiler.hooks.done.tap( - 'DevMiddlewareWriteToDiskTest', - () => { - expect( - compiler.hooks.assetEmitted.taps.filter( - (hook) => hook.name === 'DevMiddleware' - ).length - ).toBe(0); + afterAll(close); - done(); - } - ); - }); - }); + it('should return the "200" code for the "POST" request to the bundle file', (done) => { + request(app).post('/public/bundle.js').expect(200, done); }); - describe('should work with "Function" value when it returns "true"', () => { - let compiler; - - beforeAll((done) => { - compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: path.resolve( - __dirname, - './outputs/write-to-disk-function-true' - ), - }, - }); + it('should return the "404" code for the "GET" request to the bundle file', (done) => { + request(app).get('/public/bundle.js').expect(404, done); + }); - instance = middleware(compiler, { - writeToDisk: (filePath) => /bundle\.js$/.test(filePath), - }); + it('should return the "200" code for the "HEAD" request to the bundle file', (done) => { + request(app).head('/public/bundle.js').expect(404, done); + }); + }); - app = framework(); - app.use(instance); + describe('headers option', () => { + beforeEach((done) => { + const compiler = getCompiler(webpackConfig); - listen = listenShorthand(done); + instance = middleware(compiler, { + headers: { 'X-nonsense-1': 'yes', 'X-nonsense-2': 'no' }, }); - afterAll((done) => { - del.sync( - path.posix.resolve( - __dirname, - './outputs/write-to-disk-function-true' - ) - ); - - close(done); - }); + app = framework(); + app.use(instance); - it('should find the bundle file on disk', (done) => { - request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } + listen = listenShorthand(done); + }); - const bundlePath = path.resolve( - __dirname, - './outputs/write-to-disk-function-true/bundle.js' - ); + afterEach(close); - expect(fs.existsSync(bundlePath)).toBe(true); + it('should return the "200" code for the "GET" request to the bundle file and return headers', (done) => { + request(app) + .get('/bundle.js') + .expect('X-nonsense-1', 'yes') + .expect('X-nonsense-2', 'no') + .expect(200, done); + }); - return done(); - }); + it('should return the "200" code for the "GET" request to path not in outputFileSystem but not return headers', async () => { + app.use('/file.jpg', (req, res) => { + // Express API + if (res.send) { + res.send('welcome'); + } + // Connect API + else { + res.end('welcome'); + } }); - }); - describe('should work with "Function" value when it returns "false"', () => { - let compiler; + const res = await request(app).get('/file.jpg'); + expect(res.statusCode).toEqual(200); + expect(res.headers['X-nonsense-1']).toBeUndefined(); + expect(res.headers['X-nonsense-2']).toBeUndefined(); + }); + }); + describe('publicPath option', () => { + describe('should work with "string" value', () => { beforeAll((done) => { - compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: path.resolve( - __dirname, - './outputs/write-to-disk-function-false' - ), - }, - }); + const compiler = getCompiler(webpackConfig); - instance = middleware(compiler, { - writeToDisk: (filePath) => !/bundle\.js$/.test(filePath), - }); + instance = middleware(compiler, { publicPath: '/public/' }); app = framework(); app.use(instance); @@ -2525,53 +2444,18 @@ describe.each([ listen = listenShorthand(done); }); - afterAll((done) => { - del.sync( - path.posix.resolve( - __dirname, - './outputs/write-to-disk-function-false' - ) - ); - - close(done); - }); - - it('should not find the bundle file on disk', (done) => { - request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - const bundlePath = path.resolve( - __dirname, - './outputs/write-to-disk-function-false/bundle.js' - ); - - expect(fs.existsSync(bundlePath)).toBe(false); + afterAll(close); - return done(); - }); + it('should return the "200" code for the "GET" request to the bundle file', (done) => { + request(app).get('/public/bundle.js').expect(200, done); }); }); - describe('should work when assets have query string', () => { - let compiler; - + describe('should work with "auto" value', () => { beforeAll((done) => { - compiler = getCompiler({ - ...webpackQueryStringConfig, - output: { - filename: 'bundle.js?[contenthash]', - path: path.resolve( - __dirname, - './outputs/write-to-disk-query-string' - ), - }, - }); + const compiler = getCompiler(webpackConfig); - instance = middleware(compiler, { writeToDisk: true }); + instance = middleware(compiler, { publicPath: 'auto' }); app = framework(); app.use(instance); @@ -2579,826 +2463,172 @@ describe.each([ listen = listenShorthand(done); }); - afterAll((done) => { - del.sync( - path.posix.resolve( - __dirname, - './outputs/write-to-disk-query-string' - ) - ); + afterAll(close); - close(done); + it('should return the "200" code for the "GET" request to the bundle file', (done) => { + request(app).get('/bundle.js').expect(200, done); }); + }); + }); - it('should find the bundle file on disk with no querystring', (done) => { - request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - const bundlePath = path.resolve( - __dirname, - './outputs/write-to-disk-query-string/bundle.js' - ); - - expect(fs.existsSync(bundlePath)).toBe(true); - - return done(); - }); - }); - }); - - describe('should work in multi-compiler mode', () => { - let compiler; - - beforeAll((done) => { - compiler = getCompiler([ - { - ...webpackMultiWatchOptionsConfig[0], - output: { - filename: 'bundle.js', - path: path.resolve( - __dirname, - './outputs/write-to-disk-multi-compiler/static-one' - ), - publicPath: '/static-one/', - }, - }, - { - ...webpackMultiWatchOptionsConfig[1], - output: { - filename: 'bundle.js', - path: path.resolve( - __dirname, - './outputs/write-to-disk-multi-compiler/static-two' - ), - publicPath: '/static-two/', - }, - }, - ]); - - instance = middleware(compiler, { writeToDisk: true }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll((done) => { - del.sync( - path.posix.resolve( - __dirname, - './outputs/write-to-disk-multi-compiler/' - ) - ); - - close(done); - }); - - it('should find the bundle files on disk', (done) => { - request(app) - .get('/static-one/bundle.js') - .expect(200, (firstError) => { - if (firstError) { - return done(firstError); - } - - return request(app) - .get('/static-two/bundle.js') - .expect(200, (secondError) => { - if (secondError) { - return done(secondError); - } - const bundleFiles = [ - './outputs/write-to-disk-multi-compiler/static-one/bundle.js', - './outputs/write-to-disk-multi-compiler/static-one/index.html', - './outputs/write-to-disk-multi-compiler/static-one/svg.svg', - './outputs/write-to-disk-multi-compiler/static-two/bundle.js', - ]; - - for (const bundleFile of bundleFiles) { - const bundlePath = path.resolve(__dirname, bundleFile); - - expect(fs.existsSync(bundlePath)).toBe(true); - } - - return done(); - }); - }); - }); - }); - - describe('should work with "[hash]"/"[fullhash]" in the "output.path" and "output.publicPath" option', () => { - let compiler; - let hash; - - beforeAll((done) => { - compiler = getCompiler({ - ...webpackConfig, - ...{ - output: { - filename: 'bundle.js', - publicPath: isWebpack5() - ? '/static/[fullhash]/' - : '/static/[hash]/', - path: isWebpack5() - ? path.resolve( - __dirname, - './outputs/write-to-disk-with-hash/dist_[fullhash]' - ) - : path.resolve( - __dirname, - './outputs/write-to-disk-with-hash/dist_[hash]' - ), - }, - }, - }); - - instance = middleware(compiler, { writeToDisk: true }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(() => { - compiler.hooks.afterCompile.tap('wdm-test', ({ hash: h }) => { - hash = h; - done(); - }); - }); - }); - - afterAll((done) => { - del.sync( - path.posix.resolve(__dirname, './outputs/write-to-disk-with-hash/') - ); - - close(done); - }); - - it('should find the bundle file on disk', (done) => { - request(app) - .get(`/static/${hash}/bundle.js`) - .expect(200, (error) => { - if (error) { - return done(error); - } - - const bundlePath = path.resolve( - __dirname, - `./outputs/write-to-disk-with-hash/dist_${hash}/bundle.js` - ); - - expect(fs.existsSync(bundlePath)).toBe(true); - - return done(); - }); - }); - }); - }); - - describe('methods option', () => { - let compiler; + describe('serverSideRender option', () => { + let locals; beforeAll((done) => { - compiler = getCompiler(webpackConfig); - - instance = middleware(compiler, { - methods: ['POST'], - publicPath: '/public/', - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should return the "200" code for the "POST" request to the bundle file', (done) => { - request(app).post('/public/bundle.js').expect(200, done); - }); - - it('should return the "404" code for the "GET" request to the bundle file', (done) => { - request(app).get('/public/bundle.js').expect(404, done); - }); - - it('should return the "200" code for the "HEAD" request to the bundle file', (done) => { - request(app).head('/public/bundle.js').expect(404, done); - }); - }); - - describe('headers option', () => { - beforeEach((done) => { const compiler = getCompiler(webpackConfig); - instance = middleware(compiler, { - headers: { 'X-nonsense-1': 'yes', 'X-nonsense-2': 'no' }, - }); + instance = middleware(compiler, { serverSideRender: true }); app = framework(); app.use(instance); + app.use((req, res) => { + // eslint-disable-next-line prefer-destructuring + locals = res.locals; - listen = listenShorthand(done); - }); - - afterEach(close); - - it('should return the "200" code for the "GET" request to the bundle file and return headers', (done) => { - request(app) - .get('/bundle.js') - .expect('X-nonsense-1', 'yes') - .expect('X-nonsense-2', 'no') - .expect(200, done); - }); - - it('should return the "200" code for the "GET" request to path not in outputFileSystem but not return headers', async () => { - app.use('/file.jpg', (req, res) => { // Express API - if (res.send) { - res.send('welcome'); + if (res.sendStatus) { + res.sendStatus(200); } // Connect API else { - res.end('welcome'); + // eslint-disable-next-line no-param-reassign + res.statusCode = 200; + res.end(); } }); - const res = await request(app).get('/file.jpg'); - expect(res.statusCode).toEqual(200); - expect(res.headers['X-nonsense-1']).toBeUndefined(); - expect(res.headers['X-nonsense-2']).toBeUndefined(); - }); - }); - - describe('publicPath option', () => { - describe('should work with "string" value', () => { - beforeAll((done) => { - const compiler = getCompiler(webpackConfig); - - instance = middleware(compiler, { publicPath: '/public/' }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request to the bundle file', (done) => { - request(app).get('/public/bundle.js').expect(200, done); - }); - }); - - describe('should work with "auto" value', () => { - beforeAll((done) => { - const compiler = getCompiler(webpackConfig); - - instance = middleware(compiler, { publicPath: 'auto' }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request to the bundle file', (done) => { - request(app).get('/bundle.js').expect(200, done); - }); - }); - }); - - describe('serverSideRender option', () => { - let locals; - - beforeAll((done) => { - const compiler = getCompiler(webpackConfig); - - instance = middleware(compiler, { serverSideRender: true }); - - app = framework(); - app.use(instance); - app.use((req, res) => { - // eslint-disable-next-line prefer-destructuring - locals = res.locals; - - // Express API - if (res.sendStatus) { - res.sendStatus(200); - } - // Connect API - else { - // eslint-disable-next-line no-param-reassign - res.statusCode = 200; - res.end(); - } - }); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request', (done) => { - request(app) - .get('/foo/bar') - .expect(200, (error) => { - if (error) { - return done(error); - } - - expect(locals.webpack.devMiddleware).toBeDefined(); - - return done(); - }); - }); - }); - - describe('outputFileSystem option', () => { - describe('should work with an unspecified value', () => { - let compiler; - - beforeAll((done) => { - compiler = getCompiler(webpackConfig); - - instance = middleware(compiler); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should use the "memfs" package by default', () => { - const { Stats } = memfs; - - expect(new compiler.outputFileSystem.Stats()).toBeInstanceOf(Stats); - expect(new instance.context.outputFileSystem.Stats()).toBeInstanceOf( - Stats - ); - expect(compiler.outputFileSystem).toHaveProperty('join'); - expect(compiler.outputFileSystem).toHaveProperty('mkdirp'); - }); - }); - - describe('should work with the configured value (native fs)', () => { - let compiler; - - beforeAll((done) => { - compiler = getCompiler(webpackConfig); - - const configuredFs = fs; - - configuredFs.join = path.join.bind(path); - configuredFs.mkdirp = () => {}; - - instance = middleware(compiler, { - outputFileSystem: configuredFs, - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should use the configurated output filesystem', () => { - const { Stats } = fs; - - expect(new compiler.outputFileSystem.Stats()).toBeInstanceOf(Stats); - expect(new instance.context.outputFileSystem.Stats()).toBeInstanceOf( - Stats - ); - expect(compiler.outputFileSystem).toHaveProperty('join'); - expect(compiler.outputFileSystem).toHaveProperty('mkdirp'); - }); - }); - - describe('should work with the configured value (memfs)', () => { - let compiler; - - beforeAll((done) => { - compiler = getCompiler(webpackConfig); - - const configuredFs = createFsFromVolume(new Volume()); - - configuredFs.join = path.join.bind(path); - - instance = middleware(compiler, { - outputFileSystem: configuredFs, - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should use the configured output filesystem', () => { - const { Stats } = memfs; - - expect(new compiler.outputFileSystem.Stats()).toBeInstanceOf(Stats); - expect(new instance.context.outputFileSystem.Stats()).toBeInstanceOf( - Stats - ); - expect(compiler.outputFileSystem).toHaveProperty('join'); - expect(compiler.outputFileSystem).toHaveProperty('mkdirp'); - }); - }); - - describe('should work with the configured value in multi-compiler mode (native fs)', () => { - let compiler; - - beforeAll((done) => { - compiler = getCompiler(webpackMultiConfig); - - const configuredFs = fs; - - configuredFs.join = path.join.bind(path); - configuredFs.mkdirp = () => {}; - - instance = middleware(compiler, { - outputFileSystem: configuredFs, - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should use configured output filesystems', () => { - const { Stats } = fs; - - for (const childCompiler of compiler.compilers) { - expect(new childCompiler.outputFileSystem.Stats()).toBeInstanceOf( - Stats - ); - expect(childCompiler.outputFileSystem).toHaveProperty('join'); - expect(childCompiler.outputFileSystem).toHaveProperty('mkdirp'); - } - - expect(new instance.context.outputFileSystem.Stats()).toBeInstanceOf( - Stats - ); - expect(instance.context.outputFileSystem).toHaveProperty('join'); - expect(instance.context.outputFileSystem).toHaveProperty('mkdirp'); - }); - }); - - describe('should throw an error on the invalid fs value - no join method', () => { - it('should throw an error', () => { - expect(() => { - const compiler = getCompiler(webpackConfig); - - middleware(compiler, { - outputFileSystem: { - mkdirp: () => {}, - }, - }); - }).toThrow( - 'Invalid options: options.outputFileSystem.join() method is expected' - ); - }); - }); - - describe('should throw an error on the invalid fs value - no mkdirp method', () => { - it('should throw an error', () => { - expect(() => { - const compiler = getCompiler(webpackConfig); - - middleware(compiler, { - outputFileSystem: { - join: () => {}, - }, - }); - }).toThrow( - 'Invalid options: options.outputFileSystem.mkdirp() method is expected' - ); - }); - }); - }); - - describe('index option', () => { - describe('should work with "false" value', () => { - beforeAll((done) => { - const compiler = getCompiler(webpackConfig); - - instance = middleware(compiler, { index: false, publicPath: '/' }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should return the "404" code for the "GET" request to the public path', (done) => { - request(app) - .get('/') - .expect('Content-Type', 'text/html; charset=utf-8') - .expect(404, done); - }); - - it('should return the "200" code for the "GET" request to the "index.html" file', (done) => { - request(app) - .get('/index.html') - .expect('Content-Type', 'text/html; charset=utf-8') - .expect(200, done); - }); - }); - - describe('should work with "true" value', () => { - beforeAll((done) => { - const compiler = getCompiler(webpackConfig); - - instance = middleware(compiler, { index: true, publicPath: '/' }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request to the public path', (done) => { - request(app) - .get('/') - .expect('Content-Type', 'text/html; charset=utf-8') - .expect(200, done); - }); - - it('should return the "200" code for the "GET" request to the public path', (done) => { - request(app) - .get('/index.html') - .expect('Content-Type', 'text/html; charset=utf-8') - .expect(200, done); - }); - }); - - describe('should work with "string" value', () => { - beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: outputPath, - }, - }); - - instance = middleware(compiler, { - index: 'default.html', - publicPath: '/', - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, - }); - instance.context.outputFileSystem.writeFileSync( - path.resolve(outputPath, 'default.html'), - 'hello' - ); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request to the public path', (done) => { - request(app) - .get('/') - .expect('Content-Type', 'text/html; charset=utf-8') - .expect(200, done); - }); - }); - - describe('should work with "string" value with a custom extension', () => { - beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: outputPath, - }, - }); - - instance = middleware(compiler, { - index: 'index.custom', - publicPath: '/', - }); - - app = framework(); - app.use(instance); - - listen = listenShorthand(done); - - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, - }); - instance.context.outputFileSystem.writeFileSync( - path.resolve(outputPath, 'index.custom'), - 'hello' - ); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request to the public path', (done) => { - request(app) - .get('/') - .expect('Content-Type', 'application/octet-stream') - .expect(200, done); - }); + listen = listenShorthand(done); }); - describe('should work with "string" value with a custom extension and defined a custom MIME type', () => { - beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: outputPath, - }, - }); - - instance = middleware(compiler, { - index: 'index.mycustom', - mimeTypes: { - mycustom: 'text/html', - }, - publicPath: '/', - }); + afterAll(close); - app = framework(); - app.use(instance); + it('should return the "200" code for the "GET" request', (done) => { + request(app) + .get('/foo/bar') + .expect(200, (error) => { + if (error) { + return done(error); + } - listen = listenShorthand(done); + expect(locals.webpack.devMiddleware).toBeDefined(); - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, + return done(); }); - instance.context.outputFileSystem.writeFileSync( - path.resolve(outputPath, 'index.mycustom'), - 'hello' - ); - }); - - afterAll(close); - - it('should return the "200" code for the "GET" request to the public path', (done) => { - request(app) - .get('/') - .expect('Content-Type', 'text/html; charset=utf-8') - .expect(200, done); - }); }); + }); + + describe('outputFileSystem option', () => { + describe('should work with an unspecified value', () => { + let compiler; - describe('should work with "string" value without an extension', () => { beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: outputPath, - }, - }); + compiler = getCompiler(webpackConfig); - instance = middleware(compiler, { index: 'noextension' }); + instance = middleware(compiler); app = framework(); app.use(instance); listen = listenShorthand(done); - - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, - }); - instance.context.outputFileSystem.writeFileSync( - path.resolve(outputPath, 'noextension'), - 'hello' - ); }); afterAll(close); - it('should return the "200" code for the "GET" request to the public path', (done) => { - request(app) - .get('/') - .expect('Content-Type', 'application/octet-stream') - .expect(200, done); + it('should use the "memfs" package by default', () => { + const { Stats } = memfs; + + expect(new compiler.outputFileSystem.Stats()).toBeInstanceOf(Stats); + expect(new instance.context.outputFileSystem.Stats()).toBeInstanceOf( + Stats + ); + expect(compiler.outputFileSystem).toHaveProperty('join'); + expect(compiler.outputFileSystem).toHaveProperty('mkdirp'); }); }); - describe('should work with "string" value but the "index" option is a directory', () => { + describe('should work with the configured value (native fs)', () => { + let compiler; + beforeAll((done) => { - const outputPath = path.resolve(__dirname, './outputs/basic'); - const compiler = getCompiler({ - ...webpackConfig, - output: { - filename: 'bundle.js', - path: outputPath, - }, - }); + compiler = getCompiler(webpackConfig); + + const configuredFs = fs; + + configuredFs.join = path.join.bind(path); + configuredFs.mkdirp = () => {}; instance = middleware(compiler, { - index: 'custom.html', - publicPath: '/', + outputFileSystem: configuredFs, }); app = framework(); app.use(instance); listen = listenShorthand(done); - - instance.context.outputFileSystem.mkdirSync(outputPath, { - recursive: true, - }); - instance.context.outputFileSystem.mkdirSync( - path.resolve(outputPath, 'custom.html') - ); }); afterAll(close); - it('should return the "404" code for the "GET" request to the public path', (done) => { - request(app).get('/').expect(404, done); + it('should use the configurated output filesystem', () => { + const { Stats } = fs; + + expect(new compiler.outputFileSystem.Stats()).toBeInstanceOf(Stats); + expect(new instance.context.outputFileSystem.Stats()).toBeInstanceOf( + Stats + ); + expect(compiler.outputFileSystem).toHaveProperty('join'); + expect(compiler.outputFileSystem).toHaveProperty('mkdirp'); }); }); - describe('should not handle request when index is neither a file nor a directory', () => { + describe('should work with the configured value (memfs)', () => { let compiler; - let isDirectory; beforeAll((done) => { compiler = getCompiler(webpackConfig); + const configuredFs = createFsFromVolume(new Volume()); + + configuredFs.join = path.join.bind(path); + instance = middleware(compiler, { - index: 'default.html', - publicPath: '/', + outputFileSystem: configuredFs, }); - isDirectory = jest - .spyOn(instance.context.outputFileSystem, 'statSync') - .mockImplementation(() => { - return { - isFile: () => false, - isDirectory: () => false, - }; - }); - app = framework(); app.use(instance); listen = listenShorthand(done); }); - afterAll((done) => { - isDirectory.mockRestore(); + afterAll(close); - close(done); - }); + it('should use the configured output filesystem', () => { + const { Stats } = memfs; - it('should return the "404" code for the "GET" request to the public path', (done) => { - request(app).get('/').expect(404, done); + expect(new compiler.outputFileSystem.Stats()).toBeInstanceOf(Stats); + expect(new instance.context.outputFileSystem.Stats()).toBeInstanceOf( + Stats + ); + expect(compiler.outputFileSystem).toHaveProperty('join'); + expect(compiler.outputFileSystem).toHaveProperty('mkdirp'); }); }); - }); - describe('logger', () => { - describe('should logging on successfully build', () => { + describe('should work with the configured value in multi-compiler mode (native fs)', () => { let compiler; - let getLogsPlugin; beforeAll((done) => { - compiler = getCompiler(webpackConfig); + compiler = getCompiler(webpackMultiConfig); - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const configuredFs = fs; - instance = middleware(compiler); + configuredFs.join = path.join.bind(path); + configuredFs.mkdirp = () => {}; + + instance = middleware(compiler, { + outputFileSystem: configuredFs, + }); app = framework(); app.use(instance); @@ -3408,36 +2638,64 @@ describe.each([ afterAll(close); - it('should logging', (done) => { - request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } + it('should use configured output filesystems', () => { + const { Stats } = fs; - instance.invalidate(); + for (const childCompiler of compiler.compilers) { + expect(new childCompiler.outputFileSystem.Stats()).toBeInstanceOf( + Stats + ); + expect(childCompiler.outputFileSystem).toHaveProperty('join'); + expect(childCompiler.outputFileSystem).toHaveProperty('mkdirp'); + } + + expect(new instance.context.outputFileSystem.Stats()).toBeInstanceOf( + Stats + ); + expect(instance.context.outputFileSystem).toHaveProperty('join'); + expect(instance.context.outputFileSystem).toHaveProperty('mkdirp'); + }); + }); - return instance.waitUntilValid(() => { - expect(getLogsPlugin.logs).toMatchSnapshot(); + describe('should throw an error on the invalid fs value - no join method', () => { + it('should throw an error', () => { + expect(() => { + const compiler = getCompiler(webpackConfig); - done(); - }); + middleware(compiler, { + outputFileSystem: { + mkdirp: () => {}, + }, }); + }).toThrow( + 'Invalid options: options.outputFileSystem.join() method is expected' + ); }); }); - describe('should logging on successfully build in multi-compiler mode', () => { - let compiler; - let getLogsPlugin; + describe('should throw an error on the invalid fs value - no mkdirp method', () => { + it('should throw an error', () => { + expect(() => { + const compiler = getCompiler(webpackConfig); - beforeAll((done) => { - compiler = getCompiler(webpackMultiConfig); + middleware(compiler, { + outputFileSystem: { + join: () => {}, + }, + }); + }).toThrow( + 'Invalid options: options.outputFileSystem.mkdirp() method is expected' + ); + }); + }); + }); - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + describe('index option', () => { + describe('should work with "false" value', () => { + beforeAll((done) => { + const compiler = getCompiler(webpackConfig); - instance = middleware(compiler); + instance = middleware(compiler, { index: false, publicPath: '/' }); app = framework(); app.use(instance); @@ -3447,36 +2705,26 @@ describe.each([ afterAll(close); - it('should logging', (done) => { + it('should return the "404" code for the "GET" request to the public path', (done) => { request(app) - .get('/static-one/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - instance.invalidate(); - - return instance.waitUntilValid(() => { - expect(getLogsPlugin.logs).toMatchSnapshot(); + .get('/') + .expect('Content-Type', 'text/html; charset=utf-8') + .expect(404, done); + }); - done(); - }); - }); + it('should return the "200" code for the "GET" request to the "index.html" file', (done) => { + request(app) + .get('/index.html') + .expect('Content-Type', 'text/html; charset=utf-8') + .expect(200, done); }); }); - describe('should logging on unsuccessful build', () => { - let compiler; - let getLogsPlugin; - + describe('should work with "true" value', () => { beforeAll((done) => { - compiler = getCompiler(webpackErrorConfig); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const compiler = getCompiler(webpackConfig); - instance = middleware(compiler); + instance = middleware(compiler, { index: true, publicPath: '/' }); app = framework(); app.use(instance); @@ -3486,260 +2734,232 @@ describe.each([ afterAll(close); - it('should logging', (done) => { + it('should return the "200" code for the "GET" request to the public path', (done) => { request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - instance.invalidate(); - - return instance.waitUntilValid(() => { - expect(getLogsPlugin.logs).toMatchSnapshot(); + .get('/') + .expect('Content-Type', 'text/html; charset=utf-8') + .expect(200, done); + }); - done(); - }); - }); + it('should return the "200" code for the "GET" request to the public path', (done) => { + request(app) + .get('/index.html') + .expect('Content-Type', 'text/html; charset=utf-8') + .expect(200, done); }); }); - describe('should logging on unsuccessful build in multi-compiler ', () => { - let compiler; - let getLogsPlugin; - + describe('should work with "string" value', () => { beforeAll((done) => { - compiler = getCompiler(webpackMultiErrorConfig); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: outputPath, + }, + }); - instance = middleware(compiler); + instance = middleware(compiler, { + index: 'default.html', + publicPath: '/', + }); app = framework(); app.use(instance); listen = listenShorthand(done); + + instance.context.outputFileSystem.mkdirSync(outputPath, { + recursive: true, + }); + instance.context.outputFileSystem.writeFileSync( + path.resolve(outputPath, 'default.html'), + 'hello' + ); }); afterAll(close); - it('should logging', (done) => { + it('should return the "200" code for the "GET" request to the public path', (done) => { request(app) - .get('/static-one/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - instance.invalidate(); - - return instance.waitUntilValid(() => { - expect(getLogsPlugin.logs).toMatchSnapshot(); - - done(); - }); - }); + .get('/') + .expect('Content-Type', 'text/html; charset=utf-8') + .expect(200, done); }); }); - describe('should logging an warning', () => { - let compiler; - let getLogsPlugin; - + describe('should work with "string" value with a custom extension', () => { beforeAll((done) => { - compiler = getCompiler(webpackWarningConfig); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: outputPath, + }, + }); - instance = middleware(compiler); + instance = middleware(compiler, { + index: 'index.custom', + publicPath: '/', + }); app = framework(); app.use(instance); listen = listenShorthand(done); + + instance.context.outputFileSystem.mkdirSync(outputPath, { + recursive: true, + }); + instance.context.outputFileSystem.writeFileSync( + path.resolve(outputPath, 'index.custom'), + 'hello' + ); }); afterAll(close); - it('should logging', (done) => { - request(app) - .get('/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - instance.invalidate(); - - return instance.waitUntilValid(() => { - expect(getLogsPlugin.logs).toMatchSnapshot(); - - done(); - }); - }); + it('should return the "200" code for the "GET" request to the public path', (done) => { + request(app).get('/').expect(200, done); }); }); - describe('should logging warnings in multi-compiler mode', () => { - let compiler; - let getLogsPlugin; - + describe('should work with "string" value with a custom extension and defined a custom MIME type', () => { beforeAll((done) => { - compiler = getCompiler(webpackMultiWarningConfig); - - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: outputPath, + }, + }); - instance = middleware(compiler); + instance = middleware(compiler, { + index: 'index.mycustom', + mimeTypes: { + mycustom: 'text/html', + }, + publicPath: '/', + }); app = framework(); app.use(instance); listen = listenShorthand(done); + + instance.context.outputFileSystem.mkdirSync(outputPath, { + recursive: true, + }); + instance.context.outputFileSystem.writeFileSync( + path.resolve(outputPath, 'index.mycustom'), + 'hello' + ); }); afterAll(close); - it('should logging', (done) => { + it('should return the "200" code for the "GET" request to the public path', (done) => { request(app) - .get('/static-one/bundle.js') - .expect(200, (error) => { - if (error) { - return done(error); - } - - instance.invalidate(); - - return instance.waitUntilValid(() => { - expect(getLogsPlugin.logs).toMatchSnapshot(); - - done(); - }); - }); + .get('/') + .expect('Content-Type', 'text/html; charset=utf-8') + .expect(200, done); }); }); - describe('should logging an error in "watch" method', () => { - let getLogsPlugin; - - it('should logging on startup', () => { - const compiler = getCompiler(webpackConfig); - - const watchSpy = jest - .spyOn(compiler, 'watch') - .mockImplementation((watchOptions, callback) => { - const error = new Error('Error in Watch method'); - - error.stack = ''; - - callback(error); + describe('should work with "string" value without an extension', () => { + beforeAll((done) => { + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, + output: { + filename: 'bundle.js', + path: outputPath, + }, + }); - return { - close: () => {}, - }; - }); + instance = middleware(compiler, { index: 'noextension' }); - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); + app = framework(); + app.use(instance); - instance = middleware(compiler); + listen = listenShorthand(done); - expect(getLogsPlugin.logs).toMatchSnapshot(); + instance.context.outputFileSystem.mkdirSync(outputPath, { + recursive: true, + }); + instance.context.outputFileSystem.writeFileSync( + path.resolve(outputPath, 'noextension'), + 'hello' + ); + }); - instance.close(); + afterAll(close); - watchSpy.mockRestore(); + it('should return the "200" code for the "GET" request to the public path', (done) => { + request(app).get('/').expect(200, done); }); }); - describe('should logging an error from the "fs.mkdir" method when the "writeToDisk" option is "true" ', () => { - let compiler; - let getLogsPlugin; - let mkdirSpy; - + describe('should work with "string" value but the "index" option is a directory', () => { beforeAll((done) => { - compiler = getCompiler({ - ...webpackSimpleConfig, + const outputPath = path.resolve(__dirname, './outputs/basic'); + const compiler = getCompiler({ + ...webpackConfig, output: { filename: 'bundle.js', - path: path.resolve( - __dirname, - './outputs/write-to-disk-mkdir-error' - ), + path: outputPath, }, }); - mkdirSpy = jest.spyOn(fs, 'mkdir').mockImplementation((...args) => { - const callback = args[args.length - 1]; - - return callback(new Error('Error in the "fs.mkdir" method.')); + instance = middleware(compiler, { + index: 'custom.html', + publicPath: '/', }); - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); - - instance = middleware(compiler, { writeToDisk: true }); - app = framework(); app.use(instance); listen = listenShorthand(done); - }); - afterAll((done) => { - del.sync( - path.posix.resolve(__dirname, './outputs/write-to-disk-mkdir-error') + instance.context.outputFileSystem.mkdirSync(outputPath, { + recursive: true, + }); + instance.context.outputFileSystem.mkdirSync( + path.resolve(outputPath, 'custom.html') ); - - mkdirSpy.mockRestore(); - - close(done); }); - it('should logging', (done) => { - compiler.hooks.failed.tap('FailedCatcher', () => { - instance.close(() => { - expect(getLogsPlugin.logs).toMatchSnapshot(); + afterAll(close); - done(); - }); - }); + it('should return the "404" code for the "GET" request to the public path', (done) => { + request(app).get('/').expect(404, done); }); }); - describe('should logging an error from the "fs.writeFile" method when the "writeToDisk" option is "true" ', () => { + describe('should not handle request when index is neither a file nor a directory', () => { let compiler; - let getLogsPlugin; - let writeFileSpy; + let isDirectory; beforeAll((done) => { - compiler = getCompiler({ - ...webpackSimpleConfig, - output: { - filename: 'bundle.js', - path: path.resolve( - __dirname, - './outputs/write-to-disk-writeFile-error' - ), - }, - }); + compiler = getCompiler(webpackConfig); - writeFileSpy = jest - .spyOn(fs, 'writeFile') - .mockImplementation((...args) => { - const callback = args[args.length - 1]; + instance = middleware(compiler, { + index: 'default.html', + publicPath: '/', + }); - return callback(new Error('Error in the "fs.writeFile" method.')); + isDirectory = jest + .spyOn(instance.context.outputFileSystem, 'statSync') + .mockImplementation(() => { + return { + isFile: () => false, + isDirectory: () => false, + }; }); - getLogsPlugin = new GetLogsPlugin(); - getLogsPlugin.apply(compiler); - - instance = middleware(compiler, { writeToDisk: true }); - app = framework(); app.use(instance); @@ -3747,26 +2967,13 @@ describe.each([ }); afterAll((done) => { - writeFileSpy.mockRestore(); - - del.sync( - path.posix.resolve( - __dirname, - './outputs/write-to-disk-writeFile-error' - ) - ); + isDirectory.mockRestore(); close(done); }); - it('should logging', (done) => { - compiler.hooks.failed.tap('FailedCatcher', () => { - instance.close(() => { - expect(getLogsPlugin.logs).toMatchSnapshot(); - - done(); - }); - }); + it('should return the "404" code for the "GET" request to the public path', (done) => { + request(app).get('/').expect(404, done); }); }); }); diff --git a/test/utils/__snapshots__/handleRangeHeaders.test.js.snap b/test/utils/__snapshots__/handleRangeHeaders.test.js.snap.webpack4 similarity index 100% rename from test/utils/__snapshots__/handleRangeHeaders.test.js.snap rename to test/utils/__snapshots__/handleRangeHeaders.test.js.snap.webpack4 diff --git a/test/utils/__snapshots__/handleRangeHeaders.test.js.snap.webpack5 b/test/utils/__snapshots__/handleRangeHeaders.test.js.snap.webpack5 new file mode 100644 index 000000000..c92ff14b0 --- /dev/null +++ b/test/utils/__snapshots__/handleRangeHeaders.test.js.snap.webpack5 @@ -0,0 +1,61 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`handleRangeHeaders should handle malformed range header 1`] = ` +Array [ + Array [ + "A malformed Range header was provided. A regular response will be sent for this request.", + ], +] +`; + +exports[`handleRangeHeaders should handle malformed range header 2`] = ` +Array [ + Array [ + "Accept-Ranges", + "bytes", + ], +] +`; + +exports[`handleRangeHeaders should handle multiple ranges 1`] = ` +Array [ + Array [ + "A Range header with multiple ranges was provided. Multiple ranges are not supported, so a regular response will be sent for this request.", + ], +] +`; + +exports[`handleRangeHeaders should handle multiple ranges 2`] = ` +Array [ + Array [ + "Accept-Ranges", + "bytes", + ], +] +`; + +exports[`handleRangeHeaders should handle unsatisfiable range 1`] = ` +Array [ + Array [ + "Accept-Ranges", + "bytes", + ], + Array [ + "Content-Range", + "bytes */6", + ], +] +`; + +exports[`handleRangeHeaders should return content in range with valid range header 1`] = ` +Array [ + Array [ + "Accept-Ranges", + "bytes", + ], + Array [ + "Content-Range", + "bytes 1-4/6", + ], +] +`; diff --git a/test/utils/__snapshots__/setupHooks.test.js.snap b/test/utils/__snapshots__/setupHooks.test.js.snap deleted file mode 100644 index 26aca6e78..000000000 --- a/test/utils/__snapshots__/setupHooks.test.js.snap +++ /dev/null @@ -1,39 +0,0 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP - -exports[`setupHooks handles multi compiler 1`] = ` -Array [ - Array [ - "Child \\"comp1\\": Failed to compile.", - ], - Array [ - "Child \\"comp2\\": Compiled with warnings.", - ], -] -`; - -exports[`setupHooks handles multi compiler 2`] = ` -Array [ - Array [ - "Child \\"comp1\\": statsString1", - ], -] -`; - -exports[`setupHooks handles multi compiler 3`] = ` -Array [ - Array [ - "Child \\"comp2\\": statsString2", - ], -] -`; - -exports[`setupHooks sets state, then logs stats and handles callbacks on nextTick from done hook 1`] = ` -Array [ - Array [ - "statsString", - ], - Array [ - "Compiled successfully.", - ], -] -`; diff --git a/test/utils/__snapshots__/setupHooks.test.js.snap.webpack4 b/test/utils/__snapshots__/setupHooks.test.js.snap.webpack4 new file mode 100644 index 000000000..a07edcdf3 --- /dev/null +++ b/test/utils/__snapshots__/setupHooks.test.js.snap.webpack4 @@ -0,0 +1,9 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`setupHooks handles multi compiler 1`] = `Array []`; + +exports[`setupHooks handles multi compiler 2`] = `Array []`; + +exports[`setupHooks handles multi compiler 3`] = `Array []`; + +exports[`setupHooks sets state, then logs stats and handles callbacks on nextTick from done hook 1`] = `Array []`; diff --git a/test/utils/__snapshots__/setupHooks.test.js.snap.webpack5 b/test/utils/__snapshots__/setupHooks.test.js.snap.webpack5 new file mode 100644 index 000000000..a07edcdf3 --- /dev/null +++ b/test/utils/__snapshots__/setupHooks.test.js.snap.webpack5 @@ -0,0 +1,9 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`setupHooks handles multi compiler 1`] = `Array []`; + +exports[`setupHooks handles multi compiler 2`] = `Array []`; + +exports[`setupHooks handles multi compiler 3`] = `Array []`; + +exports[`setupHooks sets state, then logs stats and handles callbacks on nextTick from done hook 1`] = `Array []`; diff --git a/test/utils/__snapshots__/setupWriteToDisk.test.js.snap b/test/utils/__snapshots__/setupWriteToDisk.test.js.snap.webpack4 similarity index 100% rename from test/utils/__snapshots__/setupWriteToDisk.test.js.snap rename to test/utils/__snapshots__/setupWriteToDisk.test.js.snap.webpack4 diff --git a/test/utils/__snapshots__/setupWriteToDisk.test.js.snap.webpack5 b/test/utils/__snapshots__/setupWriteToDisk.test.js.snap.webpack5 new file mode 100644 index 000000000..66e809ba9 --- /dev/null +++ b/test/utils/__snapshots__/setupWriteToDisk.test.js.snap.webpack5 @@ -0,0 +1,55 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with mkdir error 1`] = ` +Array [ + Array [ + "Child \\"name\\": Unable to write \\"/target/path\\" directory to disk: +error1", + ], +] +`; + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with mkdir error 2`] = `Array []`; + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with mkdir error 3`] = ` +Array [ + Array [ + "error1", + ], +] +`; + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with no write errors 1`] = `Array []`; + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with no write errors 2`] = ` +Array [ + Array [ + "Child \\"name\\": Asset written to disk: \\"/target/path/file\\"", + ], +] +`; + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with no write errors 3`] = ` +Array [ + Array [], +] +`; + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with writeFile error 1`] = ` +Array [ + Array [ + "Child \\"name\\": Unable to write \\"/target/path/file\\" asset to disk: +error2", + ], +] +`; + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with writeFile error 2`] = `Array []`; + +exports[`setupWriteToDisk tries to create directories and write file if not filtered out with writeFile error 3`] = ` +Array [ + Array [ + "error2", + ], +] +`; diff --git a/test/utils/getFilenameFromUrl.test.js b/test/utils/getFilenameFromUrl.test.js index 3ac0e0790..7d8c7c4bf 100644 --- a/test/utils/getFilenameFromUrl.test.js +++ b/test/utils/getFilenameFromUrl.test.js @@ -4,13 +4,15 @@ import express from 'express'; import middleware from '../../src'; import getFilenameFromUrl from '../../src/utils/getFilenameFromUrl'; - import getCompiler from '../helpers/getCompiler'; import listenAndCompile from '../helpers/listenAndCompile'; import webpackSimpleConfig from '../fixtures/webpack.simple.config'; import webpackPublicPathConfig from '../fixtures/webpack.public-path.config'; import webpackMultiConfig from '../fixtures/webpack.array.config'; +// Suppress unnecessary stats output +global.console.log = jest.fn(); + describe('getFilenameFromUrl', () => { const configs = [ { diff --git a/test/utils/getPaths.test.js b/test/utils/getPaths.test.js index 21059100b..55d317dd1 100644 --- a/test/utils/getPaths.test.js +++ b/test/utils/getPaths.test.js @@ -12,6 +12,9 @@ import webpackPublicPathConfig from '../fixtures/webpack.public-path.config'; import webpackMultiConfig from '../fixtures/webpack.array.config'; import isWebpack5 from '../helpers/isWebpack5'; +// Suppress unnecessary stats output +global.console.log = jest.fn(); + describe('getPaths', () => { const configs = [ { diff --git a/test/utils/setupHooks.test.js b/test/utils/setupHooks.test.js index 2e11cbd56..dca7001fb 100644 --- a/test/utils/setupHooks.test.js +++ b/test/utils/setupHooks.test.js @@ -1,10 +1,14 @@ import setupHooks from '../../src/utils/setupHooks'; +// Suppress unnecessary stats output +global.console.log = jest.fn(); + describe('setupHooks', () => { let context; const watchRunHook = jest.fn(); const invalidHook = jest.fn(); const doneHook = jest.fn(); + const loggerLog = jest.fn(); const loggerInfo = jest.fn(); const loggerWarn = jest.fn(); const loggerError = jest.fn(); @@ -28,14 +32,14 @@ describe('setupHooks', () => { tap: doneHook, }, }, - options: {}, + options: { stats: {} }, }, logger: { + log: loggerLog, info: loggerInfo, warn: loggerWarn, error: loggerError, }, - stats: {}, callbacks: [cb1, cb2], }; }); @@ -84,7 +88,7 @@ describe('setupHooks', () => { invalidHook.mock.calls[0][1](); expect(context.state).toEqual(false); expect(context.stats).toBeUndefined(); - expect(loggerInfo.mock.calls[0][0]).toEqual('Compiling...'); + expect(loggerLog.mock.calls[0][0]).toEqual('Compilation starting...'); }); it('sets state, then logs stats and handles callbacks on nextTick from done hook', () => { @@ -123,11 +127,13 @@ describe('setupHooks', () => { { options: { name: 'comp1', + stats: {}, }, }, { options: { name: 'comp2', + stats: {}, }, }, ]; diff --git a/test/utils/setupOutputFileSystem.test.js b/test/utils/setupOutputFileSystem.test.js index b1dce0ab0..0e6df1904 100644 --- a/test/utils/setupOutputFileSystem.test.js +++ b/test/utils/setupOutputFileSystem.test.js @@ -3,6 +3,7 @@ import memfs from 'memfs'; import setupOutputFileSystem from '../../src/utils/setupOutputFileSystem'; const createFsFromVolume = jest.spyOn(memfs, 'createFsFromVolume'); + createFsFromVolume.mockImplementation(() => { return { testFs: true, diff --git a/test/validation-options.test.js b/test/validation-options.test.js index 5067902f1..719e5c895 100644 --- a/test/validation-options.test.js +++ b/test/validation-options.test.js @@ -2,6 +2,9 @@ import middleware from '../src'; import getCompiler from './helpers/getCompiler'; +// Suppress unnecessary stats output +global.console.log = jest.fn(); + describe('validation', () => { const cases = { mimeTypes: { @@ -21,7 +24,7 @@ describe('validation', () => { failure: [true], }, publicPath: { - success: ['/foo'], + success: ['/foo', '', 'auto', () => '/public/path'], failure: [false], }, serverSideRender: {