Skip to content
This repository was archived by the owner on Mar 17, 2021. It is now read-only.

Commit a2f5faf

Browse files
refactor: code (#344)
1 parent 9b9cd8d commit a2f5faf

File tree

9 files changed

+2169
-1737
lines changed

9 files changed

+2169
-1737
lines changed

package-lock.json

Lines changed: 2003 additions & 1708 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

package.json

Lines changed: 22 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -38,34 +38,34 @@
3838
},
3939
"dependencies": {
4040
"loader-utils": "^1.2.3",
41-
"schema-utils": "^2.0.0"
41+
"schema-utils": "^2.5.0"
4242
},
4343
"devDependencies": {
44-
"@babel/cli": "^7.5.5",
45-
"@babel/core": "^7.5.5",
46-
"@babel/preset-env": "^7.5.5",
47-
"@commitlint/cli": "^8.1.0",
48-
"@commitlint/config-conventional": "^8.1.0",
44+
"@babel/cli": "^7.7.0",
45+
"@babel/core": "^7.7.2",
46+
"@babel/preset-env": "^7.7.1",
47+
"@commitlint/cli": "^8.2.0",
48+
"@commitlint/config-conventional": "^8.2.0",
4949
"@webpack-contrib/defaults": "^5.0.2",
5050
"@webpack-contrib/eslint-config-webpack": "^3.0.0",
51-
"babel-jest": "^24.8.0",
51+
"babel-jest": "^24.9.0",
5252
"commitlint-azure-pipelines-cli": "^1.0.2",
53-
"cross-env": "^5.2.0",
54-
"del": "^5.0.0",
55-
"del-cli": "^2.0.0",
56-
"eslint": "^6.0.1",
57-
"eslint-config-prettier": "^6.0.0",
58-
"eslint-plugin-import": "^2.18.0",
59-
"husky": "^3.0.0",
60-
"jest": "^24.8.0",
61-
"jest-junit": "^6.4.0",
62-
"lint-staged": "^9.2.0",
63-
"memory-fs": "^0.4.1",
53+
"cross-env": "^6.0.3",
54+
"del": "^5.1.0",
55+
"del-cli": "^3.0.0",
56+
"eslint": "^6.6.0",
57+
"eslint-config-prettier": "^6.7.0",
58+
"eslint-plugin-import": "^2.18.2",
59+
"husky": "^3.1.0",
60+
"jest": "^24.9.0",
61+
"jest-junit": "^9.0.0",
62+
"lint-staged": "^9.4.3",
63+
"memory-fs": "^0.5.0",
6464
"npm-run-all": "^4.1.5",
65-
"prettier": "^1.18.2",
66-
"standard-version": "^6.0.1",
67-
"url-loader": "^2.0.1",
68-
"webpack": "^4.36.1"
65+
"prettier": "^1.19.1",
66+
"standard-version": "^7.0.1",
67+
"url-loader": "^2.2.0",
68+
"webpack": "^4.41.2"
6969
},
7070
"keywords": [
7171
"webpack"

src/index.js

Lines changed: 3 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -59,11 +59,9 @@ export default function loader(content) {
5959
this.emitFile(outputPath, content);
6060
}
6161

62-
const esModules =
63-
typeof options.esModules === 'boolean' && options.esModules === true;
64-
65-
// TODO revert to ES2015 Module export, when new CSS Pipeline is in place
66-
return `${esModules ? 'export default' : 'module.exports ='} ${publicPath};`;
62+
return `${
63+
options.esModules ? 'export default' : 'module.exports ='
64+
} ${publicPath};`;
6765
}
6866

6967
export const raw = true;

src/options.json

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -56,6 +56,9 @@
5656
"instanceof": "RegExp"
5757
}
5858
]
59+
},
60+
"esModules": {
61+
"type": "boolean"
5962
}
6063
},
6164
"type": "object"

test/__snapshots__/loader.test.js.snap

Lines changed: 108 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,113 @@
11
// Jest Snapshot v1, https://goo.gl/fbAQLP
22

3+
exports[`loader should work with ModuleConcatenationPlugin 1`] = `
4+
"/******/ (function(modules) { // webpackBootstrap
5+
/******/ // The module cache
6+
/******/ var installedModules = {};
7+
/******/
8+
/******/ // The require function
9+
/******/ function __webpack_require__(moduleId) {
10+
/******/
11+
/******/ // Check if module is in cache
12+
/******/ if(installedModules[moduleId]) {
13+
/******/ return installedModules[moduleId].exports;
14+
/******/ }
15+
/******/ // Create a new module (and put it into the cache)
16+
/******/ var module = installedModules[moduleId] = {
17+
/******/ i: moduleId,
18+
/******/ l: false,
19+
/******/ exports: {}
20+
/******/ };
21+
/******/
22+
/******/ // Execute the module function
23+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
24+
/******/
25+
/******/ // Flag the module as loaded
26+
/******/ module.l = true;
27+
/******/
28+
/******/ // Return the exports of the module
29+
/******/ return module.exports;
30+
/******/ }
31+
/******/
32+
/******/
33+
/******/ // expose the modules object (__webpack_modules__)
34+
/******/ __webpack_require__.m = modules;
35+
/******/
36+
/******/ // expose the module cache
37+
/******/ __webpack_require__.c = installedModules;
38+
/******/
39+
/******/ // define getter function for harmony exports
40+
/******/ __webpack_require__.d = function(exports, name, getter) {
41+
/******/ if(!__webpack_require__.o(exports, name)) {
42+
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
43+
/******/ }
44+
/******/ };
45+
/******/
46+
/******/ // define __esModule on exports
47+
/******/ __webpack_require__.r = function(exports) {
48+
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
49+
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
50+
/******/ }
51+
/******/ Object.defineProperty(exports, '__esModule', { value: true });
52+
/******/ };
53+
/******/
54+
/******/ // create a fake namespace object
55+
/******/ // mode & 1: value is a module id, require it
56+
/******/ // mode & 2: merge all properties of value into the ns
57+
/******/ // mode & 4: return value when already ns object
58+
/******/ // mode & 8|1: behave like require
59+
/******/ __webpack_require__.t = function(value, mode) {
60+
/******/ if(mode & 1) value = __webpack_require__(value);
61+
/******/ if(mode & 8) return value;
62+
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
63+
/******/ var ns = Object.create(null);
64+
/******/ __webpack_require__.r(ns);
65+
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
66+
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
67+
/******/ return ns;
68+
/******/ };
69+
/******/
70+
/******/ // getDefaultExport function for compatibility with non-harmony modules
71+
/******/ __webpack_require__.n = function(module) {
72+
/******/ var getter = module && module.__esModule ?
73+
/******/ function getDefault() { return module['default']; } :
74+
/******/ function getModuleExports() { return module; };
75+
/******/ __webpack_require__.d(getter, 'a', getter);
76+
/******/ return getter;
77+
/******/ };
78+
/******/
79+
/******/ // Object.prototype.hasOwnProperty.call
80+
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
81+
/******/
82+
/******/ // __webpack_public_path__
83+
/******/ __webpack_require__.p = \\"\\";
84+
/******/
85+
/******/
86+
/******/ // Load entry module and return exports
87+
/******/ return __webpack_require__(__webpack_require__.s = 0);
88+
/******/ })
89+
/************************************************************************/
90+
/******/ ([
91+
/* 0 */
92+
/***/ (function(module, __webpack_exports__, __webpack_require__) {
93+
94+
\\"use strict\\";
95+
__webpack_require__.r(__webpack_exports__);
96+
97+
// CONCATENATED MODULE: ./file.png
98+
/* harmony default export */ var file = (__webpack_require__.p + \\"9c87cbf3ba33126ffd25ae7f2f6bbafb.png\\");
99+
// CONCATENATED MODULE: ./fixture.js
100+
/* eslint-disable */
101+
102+
103+
/* harmony default export */ var fixture = __webpack_exports__[\\"default\\"] = (file);
104+
105+
106+
/***/ })
107+
/******/ ]);
108+
//# sourceMappingURL=main.bundle.js.map"
109+
`;
110+
3111
exports[`loader should works with \`url-loader\` when limit is less 1`] = `"module.exports = __webpack_public_path__ + \\"9c87cbf3ba33126ffd25ae7f2f6bbafb.png\\";"`;
4112

5113
exports[`loader should works with \`url-loader\` when limit is more 1`] = `"module.exports = \\"\\""`;

test/__snapshots__/validate-options.test.js.snap renamed to test/__snapshots__/validation-options.test.js.snap

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -51,3 +51,8 @@ exports[`validate options 6`] = `
5151
* options.regExp should be a string.
5252
* options.regExp should be an instance of RegExp."
5353
`;
54+
55+
exports[`validate options 7`] = `
56+
"Invalid options object. File Loader has been initialised using an options object that does not match the API schema.
57+
- options.esModules should be a boolean."
58+
`;

test/helpers/compiler.js

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -41,15 +41,16 @@ const output = (config) => {
4141
export default function(fixture, config, options) {
4242
// webpack Config
4343
config = {
44-
mode: 'development',
44+
mode: config.mode || 'development',
4545
devtool: config.devtool || 'sourcemap',
4646
context: path.resolve(__dirname, '..', 'fixtures'),
4747
entry: `./${fixture}`,
4848
output: output(config),
4949
module: module(config),
5050
plugins: plugins(config),
5151
optimization: {
52-
runtimeChunk: true,
52+
minimize: false,
53+
runtimeChunk: false,
5354
},
5455
};
5556
// Compiler Options

test/loader.test.js

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -78,4 +78,22 @@ describe('loader', () => {
7878

7979
expect(source).toMatchSnapshot();
8080
});
81+
82+
it('should work with ModuleConcatenationPlugin', async () => {
83+
const config = {
84+
mode: 'production',
85+
loader: {
86+
test: /(png|jpg|svg)/,
87+
options: {
88+
esModules: true,
89+
},
90+
},
91+
};
92+
93+
const stats = await webpack('fixture.js', config);
94+
95+
expect(
96+
stats.compilation.assets['main.bundle.js'].source()
97+
).toMatchSnapshot();
98+
});
8199
});

test/validate-options.test.js renamed to test/validation-options.test.js

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -55,5 +55,9 @@ it('validate options', () => {
5555
expect(() => validate({ regExp: 'image\\.png' })).not.toThrow();
5656
expect(() => validate({ regExp: true })).toThrowErrorMatchingSnapshot();
5757

58+
expect(() => validate({ esModules: true })).not.toThrow();
59+
expect(() => validate({ esModules: false })).not.toThrow();
60+
expect(() => validate({ esModules: 'true' })).toThrowErrorMatchingSnapshot();
61+
5862
expect(() => validate({ unknown: 'unknown' })).not.toThrow();
5963
});

0 commit comments

Comments
 (0)