mirror of https://github.com/webpack/webpack.git
				
				
				
			
		
			
				
	
	
		
			194 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			194 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
"use strict";
 | 
						|
 | 
						|
/*globals describe it */
 | 
						|
const path = require("path");
 | 
						|
 | 
						|
const webpack = require("../lib/webpack");
 | 
						|
 | 
						|
const base = path.join(__dirname, "fixtures", "errors");
 | 
						|
 | 
						|
describe("Errors", () => {
 | 
						|
	jest.setTimeout(20000);
 | 
						|
 | 
						|
	function customOutputFilesystem(c) {
 | 
						|
		const files = {};
 | 
						|
		c.outputFileSystem = {
 | 
						|
			join: path.join.bind(path),
 | 
						|
			mkdirp(path, callback) {
 | 
						|
				callback();
 | 
						|
			},
 | 
						|
			writeFile(name, content, callback) {
 | 
						|
				files[name] = content.toString("utf-8");
 | 
						|
				callback();
 | 
						|
			}
 | 
						|
		};
 | 
						|
		return files;
 | 
						|
	}
 | 
						|
 | 
						|
	function getErrors(options, callback) {
 | 
						|
		options.context = base;
 | 
						|
		const c = webpack(options);
 | 
						|
		customOutputFilesystem(c);
 | 
						|
		c.run((err, stats) => {
 | 
						|
			if (err) throw err;
 | 
						|
			expect(typeof stats).toBe("object");
 | 
						|
			stats = stats.toJson({
 | 
						|
				errorDetails: false
 | 
						|
			});
 | 
						|
			expect(typeof stats).toBe("object");
 | 
						|
			expect(stats).toHaveProperty("errors");
 | 
						|
			expect(stats).toHaveProperty("warnings");
 | 
						|
			expect(Array.isArray(stats.errors)).toBe(true);
 | 
						|
			expect(Array.isArray(stats.warnings)).toBe(true);
 | 
						|
			callback(stats.errors, stats.warnings);
 | 
						|
		});
 | 
						|
	}
 | 
						|
	it("should throw an error if file doesn't exist", done => {
 | 
						|
		getErrors(
 | 
						|
			{
 | 
						|
				mode: "development",
 | 
						|
				entry: "./missingFile"
 | 
						|
			},
 | 
						|
			(errors, warnings) => {
 | 
						|
				expect(errors).toHaveLength(2);
 | 
						|
				expect(warnings).toHaveLength(0);
 | 
						|
				errors.sort();
 | 
						|
				let lines = errors[0].split("\n");
 | 
						|
				expect(lines[0]).toMatch(/missingFile.js/);
 | 
						|
				expect(lines[1]).toMatch(/^Module not found/);
 | 
						|
				expect(lines[1]).toMatch(/\.\/dir\/missing2/);
 | 
						|
				expect(lines[2]).toMatch(/missingFile.js 12:9/);
 | 
						|
				lines = errors[1].split("\n");
 | 
						|
				expect(lines[0]).toMatch(/missingFile.js/);
 | 
						|
				expect(lines[1]).toMatch(/^Module not found/);
 | 
						|
				expect(lines[1]).toMatch(/\.\/missing/);
 | 
						|
				expect(lines[2]).toMatch(/missingFile.js 4:0/);
 | 
						|
				done();
 | 
						|
			}
 | 
						|
		);
 | 
						|
	});
 | 
						|
	it("should report require.extensions as unsupported", done => {
 | 
						|
		getErrors(
 | 
						|
			{
 | 
						|
				mode: "development",
 | 
						|
				entry: "./require.extensions"
 | 
						|
			},
 | 
						|
			(errors, warnings) => {
 | 
						|
				expect(errors).toHaveLength(0);
 | 
						|
				expect(warnings).toHaveLength(1);
 | 
						|
				const lines = warnings[0].split("\n");
 | 
						|
				expect(lines[0]).toMatch(/require.extensions\.js/);
 | 
						|
				expect(lines[1]).toMatch(
 | 
						|
					/require.extensions is not supported by webpack/
 | 
						|
				);
 | 
						|
				done();
 | 
						|
			}
 | 
						|
		);
 | 
						|
	});
 | 
						|
	it("should warn about case-sensitive module names", done => {
 | 
						|
		getErrors(
 | 
						|
			{
 | 
						|
				mode: "development",
 | 
						|
				entry: "./case-sensitive"
 | 
						|
			},
 | 
						|
			(errors, warnings) => {
 | 
						|
				if (errors.length === 0) {
 | 
						|
					expect(warnings).toHaveLength(1);
 | 
						|
					const lines = warnings[0].split("\n");
 | 
						|
					expect(lines[4]).toMatch(/FILE\.js/);
 | 
						|
					expect(lines[5]).toMatch(/Used by/);
 | 
						|
					expect(lines[6]).toMatch(/case-sensitive/);
 | 
						|
					expect(lines[7]).toMatch(/file\.js/);
 | 
						|
					expect(lines[8]).toMatch(/Used by/);
 | 
						|
					expect(lines[9]).toMatch(/case-sensitive/);
 | 
						|
				} else {
 | 
						|
					expect(errors).toHaveLength(1);
 | 
						|
					expect(warnings).toHaveLength(0);
 | 
						|
				}
 | 
						|
				done();
 | 
						|
			}
 | 
						|
		);
 | 
						|
	});
 | 
						|
	it("should warn when not using mode", done => {
 | 
						|
		getErrors(
 | 
						|
			{
 | 
						|
				entry: "./entry-point"
 | 
						|
			},
 | 
						|
			(errors, warnings) => {
 | 
						|
				expect(errors).toHaveLength(0);
 | 
						|
				expect(warnings).toHaveLength(1);
 | 
						|
				let lines = warnings[0].split("\n");
 | 
						|
				expect(lines[0]).toMatch(/configuration/);
 | 
						|
				expect(lines[1]).toMatch(/mode/);
 | 
						|
				expect(lines[1]).toMatch(/development/);
 | 
						|
				expect(lines[1]).toMatch(/production/);
 | 
						|
				done();
 | 
						|
			}
 | 
						|
		);
 | 
						|
	});
 | 
						|
	it("should not warn if the NoEmitOnErrorsPlugin is used over the NoErrorsPlugin", done => {
 | 
						|
		getErrors(
 | 
						|
			{
 | 
						|
				mode: "production",
 | 
						|
				entry: "./no-errors-deprecate"
 | 
						|
			},
 | 
						|
			(errors, warnings) => {
 | 
						|
				expect(errors).toHaveLength(0);
 | 
						|
				expect(warnings).toHaveLength(0);
 | 
						|
				done();
 | 
						|
			}
 | 
						|
		);
 | 
						|
	});
 | 
						|
	it("should not not emit if NoEmitOnErrorsPlugin is used and there is an error", done => {
 | 
						|
		getErrors(
 | 
						|
			{
 | 
						|
				mode: "production",
 | 
						|
				entry: "./missingFile"
 | 
						|
			},
 | 
						|
			(errors, warnings) => {
 | 
						|
				expect(errors).toHaveLength(2);
 | 
						|
				expect(warnings).toHaveLength(0);
 | 
						|
				errors.sort();
 | 
						|
				let lines = errors[0].split("\n");
 | 
						|
				expect(lines[0]).toMatch(/missingFile.js/);
 | 
						|
				expect(lines[1]).toMatch(/^Module not found/);
 | 
						|
				expect(lines[1]).toMatch(/\.\/dir\/missing2/);
 | 
						|
				expect(lines[2]).toMatch(/missingFile.js 12:9/);
 | 
						|
				lines = errors[1].split("\n");
 | 
						|
				expect(lines[0]).toMatch(/missingFile.js/);
 | 
						|
				expect(lines[1]).toMatch(/^Module not found/);
 | 
						|
				expect(lines[1]).toMatch(/\.\/missing/);
 | 
						|
				expect(lines[2]).toMatch(/missingFile.js 4:0/);
 | 
						|
				done();
 | 
						|
			}
 | 
						|
		);
 | 
						|
	});
 | 
						|
	it("should throw an error when trying to use [chunkhash] when it's invalid", done => {
 | 
						|
		getErrors(
 | 
						|
			{
 | 
						|
				mode: "development",
 | 
						|
				entry: {
 | 
						|
					a: "./entry-point",
 | 
						|
					b: "./entry-point",
 | 
						|
					c: "./entry-point"
 | 
						|
				},
 | 
						|
				output: {
 | 
						|
					filename: "[chunkhash].js"
 | 
						|
				},
 | 
						|
				plugins: [new webpack.HotModuleReplacementPlugin()]
 | 
						|
			},
 | 
						|
			(errors, warnings) => {
 | 
						|
				expect(errors).toHaveLength(3);
 | 
						|
				expect(warnings).toHaveLength(0);
 | 
						|
				errors.forEach(error => {
 | 
						|
					const lines = error.split("\n");
 | 
						|
					expect(lines[0]).toMatch(/chunk (a|b|c)/);
 | 
						|
					expect(lines[2]).toMatch(/\[chunkhash\].js/);
 | 
						|
					expect(lines[2]).toMatch(/use \[hash\] instead/);
 | 
						|
				});
 | 
						|
				done();
 | 
						|
			}
 | 
						|
		);
 | 
						|
	});
 | 
						|
});
 |