webpack/test
Tobias Koppers 5fc7008c3e update webpack-sources to 3.1.1 2021-07-29 15:11:51 +02:00
..
__snapshots__ update webpack-sources to 3.1.1 2021-07-29 15:11:51 +02:00
benchmarkCases improve typings and test them in CI 2020-04-21 09:25:43 +02:00
cases update webpack-sources for performance problem in hashing 2021-07-20 13:29:25 +02:00
configCases Fix generator publicPath behavior when empty string 2021-07-24 17:02:09 +02:00
fixtures remove bundle.js file 2021-05-31 18:17:48 +02:00
helpers filter experimental warnings 2021-07-15 16:37:54 +02:00
hotCases Dispose and apply must run atomically. 2021-06-21 17:21:23 -07:00
hotPlayground improve typings and test them in CI 2020-04-21 09:25:43 +02:00
statsCases pretty files 2021-05-11 09:31:46 +02:00
watchCases fixes #13691 2021-07-05 11:22:13 +02:00
AbstractMethodError.unittest.js #9391 resolve super call discussion 2019-07-15 17:27:59 +03:00
BenchmarkTestCases.benchmark.js pretty files 2021-05-11 09:31:46 +02:00
BinaryMiddleware.unittest.js improve BinaryMiddleware test cases 2021-02-03 11:53:03 +01:00
BuildDependencies.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
ChangesAndRemovals.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
Chunk.unittest.js update eslint and lint-staged 2019-08-06 10:57:37 +02:00
Cli.test.js replace output.ecmaVersion with output.environment and more detailed flags 2020-09-10 11:12:28 +02:00
Compiler-caching.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
Compiler.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
ConfigCacheTestCases.longtest.js split up integration tests for windows 2021-07-15 16:37:54 +02:00
ConfigTestCases.basictest.js split up integration tests for windows 2021-07-15 16:37:54 +02:00
ConfigTestCases.template.js fix problems with compiling twice 2021-07-22 11:11:18 +02:00
ContextModuleFactory.unittest.js fix bug for maxCallStack in ContextModuleFactory 2020-09-13 18:13:52 +05:30
Defaults.unittest.js update test snapshots 2021-07-16 13:18:48 +02:00
Errors.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
Examples.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
HotModuleReplacementPlugin.test.js fix test case 2020-11-28 18:27:44 +01:00
HotTestCases.template.js Merge pull request #13576 from StateFarmIns/async-hmr-handlers 2021-07-18 19:02:25 +02:00
HotTestCasesAsyncNode.test.js Refactor HMR for runtime modules 2018-11-29 16:22:29 +01:00
HotTestCasesNode.test.js Refactor HMR for runtime modules 2018-11-29 16:22:29 +01:00
HotTestCasesWeb.test.js Refactor HMR for runtime modules 2018-11-29 16:22:29 +01:00
HotTestCasesWebWorker.test.js Refactor HMR for runtime modules 2018-11-29 16:22:29 +01:00
JavascriptParser.unittest.js run prettier 2020-09-01 11:30:46 +02:00
LazySet.unittest.js Fix perf issues with lazy sets 2021-06-17 18:42:39 +00:00
LocalModulesHelpers.unittest.js update eslint and lint-staged 2019-08-06 10:57:37 +02:00
ModuleDependencyError.unittest.js Cleanup error location and origin information 2018-06-04 10:35:46 +02:00
MultiCompiler.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
MultiStats.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
MultiWatching.unittest.js Merge tag 'v4.35.0' into next 2019-06-21 09:15:49 +02:00
NodeTemplatePlugin.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
NormalModule.unittest.js add useSimpleSourceMap flag to enable/disable OriginalSource for generated code 2020-10-26 16:33:38 +01:00
NullDependency.unittest.js
PersistentCaching.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
ProfilingPlugin.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
ProfilingPlugin.unittest.js refactor: the `outputPath` option of `ProfilingPlugin` plugin now accepts only absolute path 2019-08-07 20:36:27 +03:00
ProgressPlugin.test.js improvements 2021-04-06 15:20:27 +02:00
README.md split up integration tests for windows 2021-07-15 16:37:54 +02:00
RawModule.unittest.js refactor Module.source() and Module.getRuntimeRequirements() into Module.codeGeneration 2019-10-08 23:59:48 +02:00
RequestShortener.unittest.js make RequestShortener simpler, only use relative path 2020-01-15 18:48:37 +01:00
SemVer.unittest.js run prettier 2020-09-01 11:30:46 +02:00
SideEffectsFlagPlugin.unittest.js replace micromatch with glob-to-regexp for sideEffects flag 2019-05-16 21:54:03 +02:00
SizeFormatHelpers.unittest.js update eslint and lint-staged 2019-08-06 10:57:37 +02:00
SortableSet.unittest.js update eslint and lint-staged 2019-08-06 10:57:37 +02:00
Stats.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
StatsTestCases.basictest.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
Template.unittest.js correct spelling mistake, update identifer to identifier 2019-04-12 10:29:41 -06:00
TestCases.template.js update webpack-sources for performance problem in hashing 2021-07-20 13:29:25 +02:00
TestCasesAllCombined.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
TestCasesCachePack.longtest.js split up integration tests for windows 2021-07-15 16:37:54 +02:00
TestCasesDevelopment.test.js refactor: `devtool` option 2019-10-18 14:43:21 +02:00
TestCasesDevtoolCheapSourceMap.test.js
TestCasesDevtoolEval.test.js
TestCasesDevtoolEvalCheapModuleSourceMap.test.js fix source map devtools in test cases 2019-10-18 15:06:58 +02:00
TestCasesDevtoolEvalCheapSourceMap.test.js fix source map devtools in test cases 2019-10-18 15:06:58 +02:00
TestCasesDevtoolEvalDeterministicModuleIds.test.js fix test case naming which causes weird CI failures 2019-12-20 13:54:12 +01:00
TestCasesDevtoolEvalNamedModules.test.js Refactor module id plugins to be independent 2018-09-03 20:45:44 +02:00
TestCasesDevtoolEvalSourceMap.test.js refactor: `devtool` option 2019-10-18 14:43:21 +02:00
TestCasesDevtoolInlineCheapSourceMap.test.js fix source map devtools in test cases 2019-10-18 15:06:58 +02:00
TestCasesDevtoolInlineSourceMap.test.js
TestCasesDevtoolSourceMap.test.js refactor: `devtool` option 2019-10-18 14:43:21 +02:00
TestCasesHot.test.js Refactor webpack main 2018-12-09 15:32:03 +01:00
TestCasesMinimizedSourceMap.test.js remove more expected deprecations 2020-08-04 14:54:06 +02:00
TestCasesModule.test.js partially fix test cases 2021-06-24 10:05:37 +02:00
TestCasesNormal.basictest.js split up integration tests for windows 2021-07-15 16:37:54 +02:00
TestCasesProdGlobalUsed.test.js assign class property keys to the correct top level symbol 2021-06-21 09:48:14 +02:00
TestCasesProduction.longtest.js split up integration tests for windows 2021-07-15 16:37:54 +02:00
URLAbsoluteSpecifier.unittest.js improve windows absolute path detection 2020-07-03 10:18:41 +02:00
Validation.test.js parse import assertions 2021-07-16 13:14:54 +02:00
WatchClose.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
WatchDetection.test.js add test cases 2021-05-19 15:48:00 +02:00
WatchSuspend.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
WatchTestCases.test.js add separate webpack warmup step with large timeout 2021-07-15 16:37:54 +02:00
WatcherEvents.test.js refactor: invoke createFsFromVolume as a function 2020-02-18 20:22:26 +05:30
WebpackError.unittest.js Update unit tests 2019-05-10 09:55:58 +02:00
checkArrayExpectation.js improve error reporting 2021-04-13 17:33:41 +02:00
cleverMerge.unittest.js improve handling of non-object values in clever merge 2021-01-06 10:51:44 +01:00
compareLocations.unittest.js replace Object.assign with object spread 2019-06-19 13:16:05 +02:00
compileBooleanMatcher.unittest.js fix #12255 2020-12-22 12:29:08 +01:00
deterministicGrouping.unittest.js fix some edge cases in deterministicGrouping and add more tests 2021-03-31 16:55:30 +02:00
extractUrlAndGlobal.unittest.js fix ExternalModule bug 2020-08-11 20:42:32 +08:00
formatLocation.unittest.js fix unit test, add handling for line only location 2018-07-15 09:57:36 +02:00
identifier.unittest.js allow to place runtime outside of the output path 2021-03-16 13:07:58 +01:00
numberHash.unittest.js correct spelling mistake, update identifer to identifier 2019-04-12 10:29:41 -06:00
objectToMap.unittest.js update eslint and lint-staged 2019-08-06 10:57:37 +02:00
setupTestFramework.js fix DEBUG_INFO env var 2021-07-13 10:20:21 +02:00
smartGrouping.unittest.js add grouping of assets 2020-09-01 18:16:43 +02:00
target-browserslist.unittest.js fix: more 2020-11-02 18:21:37 +03:00

README.md

Welcome to the webpack test suite!!!!

Every pull request that you submit to webpack (besides README and spelling corrections in comments) requires tests that are created.

But don't give up hope!!! Although our tests may appear complex and overwhelming, once you become familiar with the test suite and structure, adding and creating tests will be fun and beneficial as you work inside the codebase! ❤

tl;dr

Run all tests (this automatically runs the setup):

yarn test

Run an individual suite:

yarn jest ConfigTestCases

Watch mode:

yarn jest --watch ConfigTestCases

See also: Jest CLI docs

Test suite overview

We use Jest for our tests. For more information on Jest you can visit their homepage!

Class Tests

All test files can be found in *.test.js. There are many tests that simply test API's of a specific class/file (such as Compiler, Errors, Integration, Parser, RuleSet, Validation). If the feature you are contributing involves one of those classes, then best to start there to understand the structure.

xCases

In addition to Class specific tests, there are also directories that end in "Cases". The suites for these cases also have corresponding *.test.js files.

cases (TestCases.test.js) 1

Cases are a set of general purpose tests that will run against a variety of permutations of webpack configurations. When you are making a general purpose change that doesn't require you to have a special configuration, you would likely add your tests here. Inside of the ./test/cases directory you will find tests are broken into thematic sub directories. Take a moment to explore the different options.

To add a new case, create a new directory inside of the top level test groups, and then add an index.js file (and any other supporting files).

By default this file will be the entry point for the test suite and you can add your it()'s there. This will also become bundled so that node env support happens as well.

configCases (ConfigTestCases.basictest.js) 1

If you are trying to solve a bug which is reproducible when x and y properties are used together in a config, then configCases is the place to be!!!!

In addition to an index.js, these configCases require a webpack.config.js is located inside of your test suite. This will run this specific config through webpack just as you were building individually. They will use the same loading/bundling technique of your it() tests, however you now have a more specific config use cases that you can write even before you start coding.

statsCases (StatsTestCases.basictest.js)

Stats cases are similar to configCases except specifically focusing on the expected output of your stats. Instead of writing to the console, however the output of stats will be written to disk.

By default, the "expected" outcome is a pain to write by hand so instead when statsCases are run, runner is checking output using jest's awesome snapshot functionality.

Basically you don't need to write any expected behaviors yourself. The assumption is that the stats output from your test code is what you expect.

Please follow the approach described below:

  • write your test code in statsCases/ folder by creating a separate folder for it, for example statsCases/some-file-import-stats/index.js
import("./someModule");
  • don't forget the webpack.config.js
  • run the test
  • jest will automatically add the output from your test code to StatsTestCases.test.js.snap and you can always check your results there
  • Next time test will run -> runner will compare results against your output written to snapshot previously

You can read more about SnapShot testing right here

Questions? Comments?

If you are still nervous or don't quite understand, please submit an issue and tag us in it, and provide a relevant PR while working on!

Footnotes

1 webpack's parser supports the use of ES2015 features like arrow functions, harmony exports, etc. However as a library we follow NodeJS's timeline for dropping older versions of node. Because of this we expect your tests on Travis to pass all the way back to NodeJS v10; Therefore if you would like specific tests that use these features to be ignored if they are not supported, then you should add a test.filter.js file. This allows you to import the syntax needed for that test, meanwhile ignoring it on node versions (during CI) that don't support it. webpack has a variety of helpful examples you can refer to if you are just starting out. See the ./helpers folder to find a list of the versions.