| 
									
										
										
										
											2017-02-02 19:56:41 +08:00
										 |  |  | /* globals describe, it */ | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | "use strict"; | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | const path = require("path"); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-09 21:26:35 +08:00
										 |  |  | const webpack = require(".."); | 
					
						
							| 
									
										
										
										
											2018-11-04 16:40:02 +08:00
										 |  |  | const Stats = require("../lib/Stats"); | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | const WebpackOptionsDefaulter = require("../lib/WebpackOptionsDefaulter"); | 
					
						
							| 
									
										
										
										
											2017-12-31 02:34:14 +08:00
										 |  |  | const MemoryFs = require("memory-fs"); | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | describe("Compiler", () => { | 
					
						
							| 
									
										
										
										
											2018-10-24 21:56:50 +08:00
										 |  |  | 	jest.setTimeout(20000); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 	function compile(entry, options, callback) { | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 		const noOutputPath = !options.output || !options.output.path; | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 		if (!options.mode) options.mode = "production"; | 
					
						
							| 
									
										
										
										
											2017-09-22 21:03:30 +08:00
										 |  |  | 		options = new WebpackOptionsDefaulter().process(options); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 		options.entry = entry; | 
					
						
							|  |  |  | 		options.context = path.join(__dirname, "fixtures"); | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 		if (noOutputPath) options.output.path = "/"; | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 		options.output.pathinfo = true; | 
					
						
							| 
									
										
										
										
											2017-12-13 23:05:21 +08:00
										 |  |  | 		options.optimization = { | 
					
						
							|  |  |  | 			minimize: false | 
					
						
							|  |  |  | 		}; | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 		const logs = { | 
					
						
							| 
									
										
										
										
											2019-06-11 19:09:42 +08:00
										 |  |  | 			mkdir: [], | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			writeFile: [] | 
					
						
							| 
									
										
										
										
											2015-01-05 21:13:11 +08:00
										 |  |  | 		}; | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 		const c = webpack(options); | 
					
						
							|  |  |  | 		const files = {}; | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 		c.outputFileSystem = { | 
					
						
							| 
									
										
										
										
											2019-06-11 19:09:42 +08:00
										 |  |  | 			mkdir(path, callback) { | 
					
						
							|  |  |  | 				logs.mkdir.push(path); | 
					
						
							|  |  |  | 				const err = new Error(); | 
					
						
							|  |  |  | 				err.code = "EEXIST"; | 
					
						
							|  |  |  | 				callback(err); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 			}, | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			writeFile(name, content, callback) { | 
					
						
							| 
									
										
										
										
											2015-01-05 21:13:11 +08:00
										 |  |  | 				logs.writeFile.push(name, content); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 				files[name] = content.toString("utf-8"); | 
					
						
							|  |  |  | 				callback(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}; | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 		c.hooks.compilation.tap( | 
					
						
							|  |  |  | 			"CompilerTest", | 
					
						
							|  |  |  | 			compilation => (compilation.bail = true) | 
					
						
							|  |  |  | 		); | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 		c.run((err, stats) => { | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			if (err) throw err; | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(typeof stats).toBe("object"); | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 			const compilation = stats.compilation; | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 			stats = stats.toJson({ | 
					
						
							|  |  |  | 				modules: true, | 
					
						
							|  |  |  | 				reasons: true | 
					
						
							|  |  |  | 			}); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(typeof stats).toBe("object"); | 
					
						
							|  |  |  | 			expect(stats).toHaveProperty("errors"); | 
					
						
							|  |  |  | 			expect(Array.isArray(stats.errors)).toBe(true); | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			if (stats.errors.length > 0) { | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(stats.errors[0]).toBeInstanceOf(Error); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 				throw stats.errors[0]; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2015-01-05 21:13:11 +08:00
										 |  |  | 			stats.logs = logs; | 
					
						
							| 
									
										
										
										
											2016-12-14 19:03:24 +08:00
										 |  |  | 			callback(stats, files, compilation); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-01-05 21:13:11 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 	it("should compile a single file to deep output", done => { | 
					
						
							|  |  |  | 		compile( | 
					
						
							|  |  |  | 			"./c", | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/what", | 
					
						
							|  |  |  | 					filename: "the/hell.js" | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			(stats, files) => { | 
					
						
							| 
									
										
										
										
											2019-06-11 19:09:42 +08:00
										 |  |  | 				expect(stats.logs.mkdir).toEqual(["/what", "/what/the"]); | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 				done(); | 
					
						
							| 
									
										
										
										
											2015-01-05 21:13:11 +08:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 		); | 
					
						
							| 
									
										
										
										
											2015-01-05 21:13:11 +08:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2017-02-02 19:36:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 	it("should compile a single file", done => { | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 		compile("./c", {}, (stats, files) => { | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(Object.keys(files)).toEqual(["/main.js"]); | 
					
						
							| 
									
										
										
										
											2017-03-01 01:23:24 +08:00
										 |  |  | 			const bundle = files["/main.js"]; | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(bundle).toMatch("function __webpack_require__("); | 
					
						
							| 
									
										
										
										
											2018-10-25 23:57:23 +08:00
										 |  |  | 			expect(bundle).toMatch(/__webpack_require__\(\/\*! \.\/a \*\/ \w+\);/); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(bundle).toMatch("./c.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./a.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("This is a"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("This is c"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("2: function("); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("window"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("jsonp"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("fixtures"); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2017-02-02 19:36:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 	it("should compile a complex file", done => { | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 		compile("./main1", {}, (stats, files) => { | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(Object.keys(files)).toEqual(["/main.js"]); | 
					
						
							| 
									
										
										
										
											2017-03-01 01:23:24 +08:00
										 |  |  | 			const bundle = files["/main.js"]; | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(bundle).toMatch("function __webpack_require__("); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("__webpack_require__(/*! ./a */"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./main1.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./a.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./b.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./node_modules/m1/a.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("This is a"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("This is b"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("This is m1/a"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("4: function("); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("window"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("jsonp"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("fixtures"); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2017-02-02 19:36:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 	it("should compile a file with transitive dependencies", done => { | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 		compile("./abc", {}, (stats, files) => { | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(Object.keys(files)).toEqual(["/main.js"]); | 
					
						
							| 
									
										
										
										
											2017-03-01 01:23:24 +08:00
										 |  |  | 			const bundle = files["/main.js"]; | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(bundle).toMatch("function __webpack_require__("); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("__webpack_require__(/*! ./a */"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("__webpack_require__(/*! ./b */"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("__webpack_require__(/*! ./c */"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./abc.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./a.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./b.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./c.js"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("This is a"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("This is b"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("This is c"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("4: function("); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("window"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("jsonp"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("fixtures"); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2017-02-02 19:36:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 	it("should compile a file with multiple chunks", done => { | 
					
						
							| 
									
										
										
										
											2017-01-18 16:03:37 +08:00
										 |  |  | 		compile("./chunks", {}, (stats, files) => { | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(stats.chunks).toHaveLength(2); | 
					
						
							| 
									
										
										
										
											2019-02-20 18:32:12 +08:00
										 |  |  | 			expect(Object.keys(files)).toEqual(["/main.js", "/394.js"]); | 
					
						
							| 
									
										
										
										
											2017-03-01 01:23:24 +08:00
										 |  |  | 			const bundle = files["/main.js"]; | 
					
						
							| 
									
										
										
										
											2019-02-20 18:32:12 +08:00
										 |  |  | 			const chunk = files["/394.js"]; | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 			expect(bundle).toMatch("function __webpack_require__("); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("__webpack_require__(/*! ./b */"); | 
					
						
							|  |  |  | 			expect(chunk).not.toMatch("__webpack_require__(/* ./b */"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("./chunks.js"); | 
					
						
							|  |  |  | 			expect(chunk).toMatch("./a.js"); | 
					
						
							|  |  |  | 			expect(chunk).toMatch("./b.js"); | 
					
						
							|  |  |  | 			expect(chunk).toMatch("This is a"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("This is a"); | 
					
						
							|  |  |  | 			expect(chunk).toMatch("This is b"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("This is b"); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("4: function("); | 
					
						
							|  |  |  | 			expect(bundle).not.toMatch("fixtures"); | 
					
						
							|  |  |  | 			expect(chunk).not.toMatch("fixtures"); | 
					
						
							|  |  |  | 			expect(bundle).toMatch("webpackJsonp"); | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			expect(chunk).toMatch('window["webpackJsonp"] || []).push'); | 
					
						
							| 
									
										
										
										
											2013-01-31 01:49:25 +08:00
										 |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 	describe("methods", () => { | 
					
						
							|  |  |  | 		let compiler; | 
					
						
							|  |  |  | 		beforeEach(() => { | 
					
						
							|  |  |  | 			compiler = webpack({ | 
					
						
							|  |  |  | 				entry: "./c", | 
					
						
							|  |  |  | 				context: path.join(__dirname, "fixtures"), | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/", | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 					pathinfo: true | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		describe("purgeInputFileSystem", () => { | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			it("invokes purge() if inputFileSystem.purge", done => { | 
					
						
							| 
									
										
										
										
											2018-05-07 21:26:04 +08:00
										 |  |  | 				const mockPurge = jest.fn(); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				compiler.inputFileSystem = { | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 					purge: mockPurge | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				}; | 
					
						
							|  |  |  | 				compiler.purgeInputFileSystem(); | 
					
						
							| 
									
										
										
										
											2018-05-07 21:26:04 +08:00
										 |  |  | 				expect(mockPurge.mock.calls.length).toBe(1); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			it("does NOT invoke purge() if !inputFileSystem.purge", done => { | 
					
						
							| 
									
										
										
										
											2018-05-07 21:26:04 +08:00
										 |  |  | 				const mockPurge = jest.fn(); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				compiler.inputFileSystem = null; | 
					
						
							|  |  |  | 				compiler.purgeInputFileSystem(); | 
					
						
							| 
									
										
										
										
											2018-05-07 21:26:04 +08:00
										 |  |  | 				expect(mockPurge.mock.calls.length).toBe(0); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		describe("isChild", () => { | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			it("returns booleanized this.parentCompilation", done => { | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				compiler.parentCompilation = "stringyStringString"; | 
					
						
							|  |  |  | 				const response1 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response1).toBe(true); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				compiler.parentCompilation = 123456789; | 
					
						
							|  |  |  | 				const response2 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response2).toBe(true); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-24 04:45:59 +08:00
										 |  |  | 				compiler.parentCompilation = { | 
					
						
							|  |  |  | 					what: "I belong to an object" | 
					
						
							|  |  |  | 				}; | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				const response3 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response3).toBe(true); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				compiler.parentCompilation = ["Array", 123, true, null, [], () => {}]; | 
					
						
							|  |  |  | 				const response4 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response4).toBe(true); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				compiler.parentCompilation = false; | 
					
						
							|  |  |  | 				const response5 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response5).toBe(false); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				compiler.parentCompilation = 0; | 
					
						
							|  |  |  | 				const response6 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response6).toBe(false); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				compiler.parentCompilation = null; | 
					
						
							|  |  |  | 				const response7 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response7).toBe(false); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				compiler.parentCompilation = ""; | 
					
						
							|  |  |  | 				const response8 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response8).toBe(false); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				compiler.parentCompilation = NaN; | 
					
						
							|  |  |  | 				const response9 = compiler.isChild(); | 
					
						
							| 
									
										
										
										
											2018-01-24 23:00:43 +08:00
										 |  |  | 				expect(response9).toBe(false); | 
					
						
							| 
									
										
										
										
											2017-06-24 04:30:30 +08:00
										 |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 	it("should not emit on errors", done => { | 
					
						
							| 
									
										
										
										
											2017-12-31 02:34:14 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./missing", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		compiler.run((err, stats) => { | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 			if (compiler.outputFileSystem.existsSync("/bundle.js")) | 
					
						
							| 
									
										
										
										
											2017-12-31 02:34:14 +08:00
										 |  |  | 				return done(new Error("Bundle should not be created on error")); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-11-04 16:40:02 +08:00
										 |  |  | 	it("should bubble up errors when wrapped in a promise and bail is true", async done => { | 
					
						
							|  |  |  | 		try { | 
					
						
							|  |  |  | 			const createCompiler = options => { | 
					
						
							|  |  |  | 				return new Promise((resolve, reject) => { | 
					
						
							|  |  |  | 					const c = webpack(options); | 
					
						
							|  |  |  | 					c.run((err, stats) => { | 
					
						
							|  |  |  | 						if (err) { | 
					
						
							|  |  |  | 							reject(err); | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 						if (stats !== undefined && "errors" in stats) { | 
					
						
							|  |  |  | 							reject(err); | 
					
						
							|  |  |  | 						} else { | 
					
						
							|  |  |  | 							resolve(stats); | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					}); | 
					
						
							|  |  |  | 				}); | 
					
						
							|  |  |  | 			}; | 
					
						
							|  |  |  | 			const compiler = await createCompiler({ | 
					
						
							|  |  |  | 				context: __dirname, | 
					
						
							|  |  |  | 				mode: "production", | 
					
						
							|  |  |  | 				entry: "./missing-file", | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/", | 
					
						
							|  |  |  | 					filename: "bundle.js" | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				bail: true | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 			return compiler; | 
					
						
							|  |  |  | 		} catch (err) { | 
					
						
							|  |  |  | 			expect(err.toString()).toMatch( | 
					
						
							|  |  |  | 				"ModuleNotFoundError: Module not found: Error: Can't resolve './missing-file'" | 
					
						
							|  |  |  | 			); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | 	it("should not emit compilation errors in async (watch)", async done => { | 
					
						
							|  |  |  | 		try { | 
					
						
							|  |  |  | 			const createCompiler = options => { | 
					
						
							|  |  |  | 				return new Promise((resolve, reject) => { | 
					
						
							|  |  |  | 					const c = webpack(options); | 
					
						
							|  |  |  | 					c.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 					const watching = c.watch({}, (err, stats) => { | 
					
						
							|  |  |  | 						watching.close(() => { | 
					
						
							|  |  |  | 							if (err) return reject(err); | 
					
						
							|  |  |  | 							resolve(stats); | 
					
						
							|  |  |  | 						}); | 
					
						
							|  |  |  | 					}); | 
					
						
							|  |  |  | 				}); | 
					
						
							|  |  |  | 			}; | 
					
						
							|  |  |  | 			const compiler = await createCompiler({ | 
					
						
							|  |  |  | 				context: __dirname, | 
					
						
							|  |  |  | 				mode: "production", | 
					
						
							|  |  |  | 				entry: "./missing-file", | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/", | 
					
						
							|  |  |  | 					filename: "bundle.js" | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				watch: true | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 			expect(compiler).toBeInstanceOf(Stats); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		} catch (err) { | 
					
						
							|  |  |  | 			done(err); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 	it("should not emit on errors (watch)", done => { | 
					
						
							| 
									
										
										
										
											2017-12-31 16:53:35 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./missing", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		const watching = compiler.watch({}, (err, stats) => { | 
					
						
							|  |  |  | 			watching.close(); | 
					
						
							| 
									
										
										
										
											2018-02-25 18:46:17 +08:00
										 |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 			if (compiler.outputFileSystem.existsSync("/bundle.js")) | 
					
						
							| 
									
										
										
										
											2017-12-31 16:53:35 +08:00
										 |  |  | 				return done(new Error("Bundle should not be created on error")); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 	it("should not be run twice at a time (run)", function(done) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		compiler.run((err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.run((err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 	it("should not be run twice at a time (watch)", function(done) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		compiler.watch({}, (err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.watch({}, (err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 	}); | 
					
						
							|  |  |  | 	it("should not be run twice at a time (run - watch)", function(done) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		compiler.run((err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 		compiler.watch({}, (err, stats) => { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 			if (err) return done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 	it("should not be run twice at a time (watch - run)", function(done) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 		compiler.watch({}, (err, stats) => { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 		compiler.run((err, stats) => { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 			if (err) return done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 	it("should not be run twice at a time (instance cb)", function(done) { | 
					
						
							|  |  |  | 		const compiler = webpack( | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				context: __dirname, | 
					
						
							|  |  |  | 				mode: "production", | 
					
						
							|  |  |  | 				entry: "./c", | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/", | 
					
						
							|  |  |  | 					filename: "bundle.js" | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			() => {} | 
					
						
							|  |  |  | 		); | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 		compiler.run((err, stats) => { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 			if (err) return done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 	it("should run again correctly after first compilation", function(done) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 		compiler.run((err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(err); | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 			compiler.run((err, stats) => { | 
					
						
							|  |  |  | 				if (err) return done(err); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 	it("should watch again correctly after first compilation", function(done) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 		compiler.run((err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(err); | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 			compiler.watch({}, (err, stats) => { | 
					
						
							|  |  |  | 				if (err) return done(err); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 	it("should run again correctly after first closed watch", function(done) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:56:31 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							| 
									
										
										
										
											2018-03-07 06:31:14 +08:00
										 |  |  | 		const watching = compiler.watch({}, (err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		watching.close(() => { | 
					
						
							|  |  |  | 			compiler.run((err, stats) => { | 
					
						
							|  |  |  | 				if (err) return done(err); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2017-12-31 16:53:35 +08:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-03-07 17:16:40 +08:00
										 |  |  | 	it("should watch again correctly after first closed watch", function(done) { | 
					
						
							|  |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		const watching = compiler.watch({}, (err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		watching.close(() => { | 
					
						
							|  |  |  | 			compiler.watch({}, (err, stats) => { | 
					
						
							|  |  |  | 				if (err) return done(err); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2018-12-25 15:08:45 +08:00
										 |  |  | 	}); | 
					
						
							|  |  |  | 	it("should run again correctly inside afterDone hook", function(done) { | 
					
						
							|  |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							| 
									
										
										
										
											2019-07-10 21:01:13 +08:00
										 |  |  | 		let once = true; | 
					
						
							| 
									
										
										
										
											2018-12-25 15:08:45 +08:00
										 |  |  | 		compiler.hooks.afterDone.tap("RunAgainTest", () => { | 
					
						
							| 
									
										
										
										
											2019-07-10 21:01:13 +08:00
										 |  |  | 			if (!once) return; | 
					
						
							|  |  |  | 			once = false; | 
					
						
							| 
									
										
										
										
											2018-12-25 15:08:45 +08:00
										 |  |  | 			compiler.run((err, stats) => { | 
					
						
							|  |  |  | 				if (err) return done(err); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.run((err, stats) => { | 
					
						
							|  |  |  | 			if (err) return done(err); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 	it("should call afterDone hook after other callbacks (run)", function(done) { | 
					
						
							| 
									
										
										
										
											2018-12-25 15:08:45 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 		const runCb = jest.fn(); | 
					
						
							|  |  |  | 		const doneHookCb = jest.fn(); | 
					
						
							|  |  |  | 		compiler.hooks.done.tap("afterDoneRunTest", doneHookCb); | 
					
						
							|  |  |  | 		compiler.hooks.afterDone.tap("afterDoneRunTest", () => { | 
					
						
							|  |  |  | 			expect(runCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			expect(doneHookCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.run((err, stats) => { | 
					
						
							| 
									
										
										
										
											2019-07-10 20:58:31 +08:00
										 |  |  | 			if (err) return done(err); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 			runCb(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | 	it("should call afterDone hook after other callbacks (instance cb)", function(done) { | 
					
						
							|  |  |  | 		const instanceCb = jest.fn(); | 
					
						
							| 
									
										
										
										
											2019-07-10 20:58:31 +08:00
										 |  |  | 		const compiler = webpack( | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				context: __dirname, | 
					
						
							|  |  |  | 				mode: "production", | 
					
						
							|  |  |  | 				entry: "./c", | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/", | 
					
						
							|  |  |  | 					filename: "bundle.js" | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			(err, stats) => { | 
					
						
							|  |  |  | 				if (err) return done(err); | 
					
						
							|  |  |  | 				instanceCb(); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2019-07-10 20:58:31 +08:00
										 |  |  | 		); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		const doneHookCb = jest.fn(); | 
					
						
							|  |  |  | 		compiler.hooks.done.tap("afterDoneRunTest", doneHookCb); | 
					
						
							|  |  |  | 		compiler.hooks.afterDone.tap("afterDoneRunTest", () => { | 
					
						
							|  |  |  | 			expect(instanceCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			expect(doneHookCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | 	it("should call afterDone hook after other callbacks (watch)", function(done) { | 
					
						
							|  |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		const doneHookCb = jest.fn(); | 
					
						
							|  |  |  | 		const watchCb = jest.fn(); | 
					
						
							|  |  |  | 		const invalidateCb = jest.fn(); | 
					
						
							|  |  |  | 		compiler.hooks.done.tap("afterDoneWatchTest", doneHookCb); | 
					
						
							|  |  |  | 		compiler.hooks.afterDone.tap("afterDoneWatchTest", () => { | 
					
						
							|  |  |  | 			expect(doneHookCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			expect(watchCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			expect(invalidateCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		const watch = compiler.watch({}, (err, stats) => { | 
					
						
							| 
									
										
										
										
											2018-12-25 15:08:45 +08:00
										 |  |  | 			if (err) return done(err); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 			watchCb(); | 
					
						
							| 
									
										
										
										
											2018-12-25 15:08:45 +08:00
										 |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 		watch.invalidate(invalidateCb); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | 	it("should call afterDone hook after other callbacks (watch close)", function(done) { | 
					
						
							|  |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		const watchCloseCb = jest.fn(); | 
					
						
							|  |  |  | 		const watchCloseHookCb = jest.fn(); | 
					
						
							|  |  |  | 		const invalidateCb = jest.fn(); | 
					
						
							|  |  |  | 		compiler.hooks.watchClose.tap("afterDoneWatchTest", watchCloseHookCb); | 
					
						
							|  |  |  | 		compiler.hooks.afterDone.tap("afterDoneWatchTest", () => { | 
					
						
							|  |  |  | 			expect(watchCloseCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			expect(watchCloseHookCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			expect(invalidateCb).toHaveBeenCalled(); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		const watch = compiler.watch({}, (err, stats) => { | 
					
						
							| 
									
										
										
										
											2018-12-25 15:08:45 +08:00
										 |  |  | 			if (err) return done(err); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 			watch.close(watchCloseCb); | 
					
						
							| 
									
										
										
										
											2018-12-25 15:08:45 +08:00
										 |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2018-12-26 21:56:19 +08:00
										 |  |  | 		watch.invalidate(invalidateCb); | 
					
						
							| 
									
										
										
										
											2018-03-07 17:16:40 +08:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-10-23 07:12:42 +08:00
										 |  |  | 	it("should flag watchMode as true in watch", function(done) { | 
					
						
							| 
									
										
										
										
											2018-10-23 07:01:07 +08:00
										 |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./c", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							| 
									
										
										
										
											2018-10-24 02:12:36 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		const watch = compiler.watch({}, err => { | 
					
						
							| 
									
										
										
										
											2018-10-23 07:01:07 +08:00
										 |  |  | 			if (err) return done(err); | 
					
						
							| 
									
										
										
										
											2018-10-23 07:12:42 +08:00
										 |  |  | 			expect(compiler.watchMode).toBeTruthy(); | 
					
						
							| 
									
										
										
										
											2018-10-24 02:12:36 +08:00
										 |  |  | 			watch.close(() => { | 
					
						
							|  |  |  | 				expect(compiler.watchMode).toBeFalsy(); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							| 
									
										
										
										
											2018-10-23 07:01:07 +08:00
										 |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2018-10-23 07:12:42 +08:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-06-20 03:41:23 +08:00
										 |  |  | 	it("should use cache on second run call", function(done) { | 
					
						
							|  |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "development", | 
					
						
							|  |  |  | 			devtool: false, | 
					
						
							|  |  |  | 			entry: "./fixtures/count-loader!./fixtures/count-loader", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/" | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		compiler.run(() => { | 
					
						
							|  |  |  | 			compiler.run(() => { | 
					
						
							|  |  |  | 				const result = compiler.outputFileSystem.readFileSync( | 
					
						
							|  |  |  | 					"/main.js", | 
					
						
							|  |  |  | 					"utf-8" | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				expect(result).toContain("module.exports = 0;"); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2018-06-20 16:23:26 +08:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2018-11-22 00:03:18 +08:00
										 |  |  | 	it("should call the failed-hook on error", done => { | 
					
						
							|  |  |  | 		const failedSpy = jest.fn(); | 
					
						
							|  |  |  | 		const compiler = webpack({ | 
					
						
							|  |  |  | 			bail: true, | 
					
						
							|  |  |  | 			context: __dirname, | 
					
						
							|  |  |  | 			mode: "production", | 
					
						
							|  |  |  | 			entry: "./missing", | 
					
						
							|  |  |  | 			output: { | 
					
						
							|  |  |  | 				path: "/", | 
					
						
							|  |  |  | 				filename: "bundle.js" | 
					
						
							| 
									
										
										
										
											2019-02-18 16:09:46 +08:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2018-11-22 00:03:18 +08:00
										 |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2019-02-18 16:09:46 +08:00
										 |  |  | 		compiler.hooks.failed.tap("CompilerTest", failedSpy); | 
					
						
							| 
									
										
										
										
											2018-11-22 00:03:18 +08:00
										 |  |  | 		compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 		compiler.run((err, stats) => { | 
					
						
							|  |  |  | 			expect(err).toBeTruthy(); | 
					
						
							|  |  |  | 			expect(failedSpy).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 			expect(failedSpy).toHaveBeenCalledWith(err); | 
					
						
							|  |  |  | 			done(); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2019-07-22 15:18:00 +08:00
										 |  |  | 	describe("infrastructure logging", () => { | 
					
						
							|  |  |  | 		const CONSOLE_METHODS = [ | 
					
						
							|  |  |  | 			"error", | 
					
						
							|  |  |  | 			"warn", | 
					
						
							|  |  |  | 			"info", | 
					
						
							|  |  |  | 			"log", | 
					
						
							|  |  |  | 			"debug", | 
					
						
							|  |  |  | 			"trace", | 
					
						
							|  |  |  | 			"profile", | 
					
						
							|  |  |  | 			"profileEnd", | 
					
						
							|  |  |  | 			"group", | 
					
						
							|  |  |  | 			"groupEnd", | 
					
						
							|  |  |  | 			"groupCollapsed" | 
					
						
							|  |  |  | 		]; | 
					
						
							|  |  |  | 		const spies = {}; | 
					
						
							|  |  |  | 		beforeEach(() => { | 
					
						
							|  |  |  | 			for (const method of CONSOLE_METHODS) { | 
					
						
							|  |  |  | 				if (console[method]) { | 
					
						
							|  |  |  | 					spies[method] = jest.spyOn(console, method).mockImplementation(); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		afterEach(() => { | 
					
						
							|  |  |  | 			for (const method in spies) { | 
					
						
							|  |  |  | 				spies[method].mockRestore(); | 
					
						
							|  |  |  | 				delete spies[method]; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2019-07-22 16:35:26 +08:00
										 |  |  | 		class MyPlugin { | 
					
						
							|  |  |  | 			apply(compiler) { | 
					
						
							|  |  |  | 				const logger = compiler.getInfrastructureLogger("MyPlugin"); | 
					
						
							|  |  |  | 				logger.time("Time"); | 
					
						
							|  |  |  | 				logger.group("Group"); | 
					
						
							|  |  |  | 				logger.error("Error"); | 
					
						
							|  |  |  | 				logger.warn("Warning"); | 
					
						
							|  |  |  | 				logger.info("Info"); | 
					
						
							|  |  |  | 				logger.log("Log"); | 
					
						
							|  |  |  | 				logger.debug("Debug"); | 
					
						
							|  |  |  | 				logger.groupCollapsed("Collaped group"); | 
					
						
							|  |  |  | 				logger.log("Log inside collapsed group"); | 
					
						
							|  |  |  | 				logger.groupEnd(); | 
					
						
							|  |  |  | 				logger.groupEnd(); | 
					
						
							|  |  |  | 				logger.timeEnd("Time"); | 
					
						
							| 
									
										
										
										
											2019-07-22 15:18:00 +08:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2019-07-22 16:35:26 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		it("should log to the console (verbose)", done => { | 
					
						
							| 
									
										
										
										
											2019-07-22 15:18:00 +08:00
										 |  |  | 			const compiler = webpack({ | 
					
						
							|  |  |  | 				context: path.join(__dirname, "fixtures"), | 
					
						
							|  |  |  | 				entry: "./a", | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/", | 
					
						
							|  |  |  | 					filename: "bundle.js" | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				infrastructureLogging: { | 
					
						
							|  |  |  | 					level: "verbose" | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				plugins: [new MyPlugin()] | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 			compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 			compiler.run((err, stats) => { | 
					
						
							|  |  |  | 				expect(spies.group).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.group).toHaveBeenCalledWith("[MyPlugin] Group"); | 
					
						
							|  |  |  | 				expect(spies.groupCollapsed).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.groupCollapsed).toHaveBeenCalledWith( | 
					
						
							|  |  |  | 					"[MyPlugin] Collaped group" | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				expect(spies.error).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.error).toHaveBeenCalledWith("<e> [MyPlugin] Error"); | 
					
						
							|  |  |  | 				expect(spies.warn).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.warn).toHaveBeenCalledWith("<w> [MyPlugin] Warning"); | 
					
						
							|  |  |  | 				expect(spies.info).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.info).toHaveBeenCalledWith("<i> [MyPlugin] Info"); | 
					
						
							| 
									
										
										
										
											2019-07-22 16:35:26 +08:00
										 |  |  | 				expect(spies.log).toHaveBeenCalledTimes(3); | 
					
						
							| 
									
										
										
										
											2019-07-22 15:18:00 +08:00
										 |  |  | 				expect(spies.log).toHaveBeenCalledWith("[MyPlugin] Log"); | 
					
						
							|  |  |  | 				expect(spies.log).toHaveBeenCalledWith( | 
					
						
							|  |  |  | 					"[MyPlugin] Log inside collapsed group" | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				expect(spies.debug).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				expect(spies.groupEnd).toHaveBeenCalledTimes(2); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2019-07-22 16:35:26 +08:00
										 |  |  | 		it("should log to the console (debug mode)", done => { | 
					
						
							|  |  |  | 			const compiler = webpack({ | 
					
						
							|  |  |  | 				context: path.join(__dirname, "fixtures"), | 
					
						
							|  |  |  | 				entry: "./a", | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/", | 
					
						
							|  |  |  | 					filename: "bundle.js" | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				infrastructureLogging: { | 
					
						
							|  |  |  | 					level: "error", | 
					
						
							|  |  |  | 					debug: /MyPlugin/ | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				plugins: [new MyPlugin()] | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 			compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 			compiler.run((err, stats) => { | 
					
						
							|  |  |  | 				expect(spies.group).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.group).toHaveBeenCalledWith("[MyPlugin] Group"); | 
					
						
							|  |  |  | 				expect(spies.groupCollapsed).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.groupCollapsed).toHaveBeenCalledWith( | 
					
						
							|  |  |  | 					"[MyPlugin] Collaped group" | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				expect(spies.error).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.error).toHaveBeenCalledWith("<e> [MyPlugin] Error"); | 
					
						
							|  |  |  | 				expect(spies.warn).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.warn).toHaveBeenCalledWith("<w> [MyPlugin] Warning"); | 
					
						
							|  |  |  | 				expect(spies.info).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.info).toHaveBeenCalledWith("<i> [MyPlugin] Info"); | 
					
						
							|  |  |  | 				expect(spies.log).toHaveBeenCalledTimes(3); | 
					
						
							|  |  |  | 				expect(spies.log).toHaveBeenCalledWith("[MyPlugin] Log"); | 
					
						
							|  |  |  | 				expect(spies.log).toHaveBeenCalledWith( | 
					
						
							|  |  |  | 					"[MyPlugin] Log inside collapsed group" | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 				expect(spies.debug).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 				expect(spies.debug).toHaveBeenCalledWith("[MyPlugin] Debug"); | 
					
						
							|  |  |  | 				expect(spies.groupEnd).toHaveBeenCalledTimes(2); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		it("should log to the console (none)", done => { | 
					
						
							|  |  |  | 			const compiler = webpack({ | 
					
						
							|  |  |  | 				context: path.join(__dirname, "fixtures"), | 
					
						
							|  |  |  | 				entry: "./a", | 
					
						
							|  |  |  | 				output: { | 
					
						
							|  |  |  | 					path: "/", | 
					
						
							|  |  |  | 					filename: "bundle.js" | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				infrastructureLogging: { | 
					
						
							|  |  |  | 					level: "none" | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				plugins: [new MyPlugin()] | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 			compiler.outputFileSystem = new MemoryFs(); | 
					
						
							|  |  |  | 			compiler.run((err, stats) => { | 
					
						
							|  |  |  | 				expect(spies.group).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				expect(spies.groupCollapsed).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				expect(spies.error).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				expect(spies.warn).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				expect(spies.info).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				expect(spies.log).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				expect(spies.debug).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				expect(spies.groupEnd).toHaveBeenCalledTimes(0); | 
					
						
							|  |  |  | 				done(); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2019-07-22 15:18:00 +08:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2015-01-05 21:13:11 +08:00
										 |  |  | }); |