diff --git a/.babelrc b/.babelrc new file mode 100644 index 0000000..a63facd --- /dev/null +++ b/.babelrc @@ -0,0 +1,35 @@ +{ + "presets": [ + [ + "env", + { + "useBuiltIns": true, + "targets": { + "node": "6.9.0" + }, + "exclude": [ + "transform-async-to-generator", + "transform-regenerator" + ] + } + ] + ], + "plugins": [ + [ + "transform-object-rest-spread", + { + "useBuiltIns": true + } + ] + ], + "env": { + "test": { + "presets": [ + "env" + ], + "plugins": [ + "transform-object-rest-spread" + ] + } + } +} diff --git a/.circleci/config.yml b/.circleci/config.yml new file mode 100644 index 0000000..3b49517 --- /dev/null +++ b/.circleci/config.yml @@ -0,0 +1,162 @@ +unit_tests: &unit_tests + steps: + - checkout + - setup_remote_docker + - restore_cache: + key: dependency-cache-{{ checksum "package.json" }} + - run: + name: NPM Rebuild + command: npm rebuild + - run: + name: Run unit tests. + command: npm run ci:test +canary_tests: &canary_tests + steps: + - checkout + - setup_remote_docker + - restore_cache: + key: dependency-cache-{{ checksum "package.json" }} + - run: + name: NPM Rebuild + command: npm rebuild + - run: + name: Install Webpack Canary + command: npm i --no-save webpack@next + - run: + name: Run unit tests. + command: npm run ci:test + +version: 2 +jobs: + dependency_cache: + docker: + - image: webpackcontrib/circleci-node-base:latest + steps: + - checkout + - setup_remote_docker + - restore_cache: + key: dependency-cache-{{ checksum "package.json" }} + - run: + name: Install Dependencies + command: npm install + - save_cache: + key: dependency-cache-{{ checksum "package.json" }} + paths: + - ./node_modules + + node8_webpack_latest: + docker: + - image: webpackcontrib/circleci-node8:latest + steps: + - checkout + - setup_remote_docker + - restore_cache: + key: dependency-cache-{{ checksum "package.json" }} + - run: + name: NPM Rebuild + command: npm rebuild + - run: + name: Run unit tests. + command: npm run ci:coverage + - run: + name: Submit coverage data to codecov. + command: bash <(curl -s https://codecov.io/bash) + when: on_success + node6_webpack_latest: + docker: + - image: webpackcontrib/circleci-node6:latest + <<: *unit_tests + node9_webpack_latest: + docker: + - image: webpackcontrib/circleci-node9:latest + <<: *unit_tests + node8_webpack_canary: + docker: + - image: webpackcontrib/circleci-node8:latest + <<: *canary_tests + analysis: + docker: + - image: webpackcontrib/circleci-node-base:latest + steps: + - checkout + - setup_remote_docker + - restore_cache: + key: dependency-cache-{{ checksum "package.json" }} + - run: + name: NPM Rebuild + command: npm rebuild + - run: + name: Run linting. + command: npm run lint + - run: + name: Run NSP Security Check. + command: npm run security + - run: + name: Validate Commit Messages + command: npm run ci:lint:commits + publish: + docker: + - image: webpackcontrib/circleci-node-base:latest + steps: + - checkout + - setup_remote_docker + - restore_cache: + key: dependency-cache-{{ checksum "package.json" }} + - run: + name: NPM Rebuild + command: npm rebuild + - run: + name: Validate Commit Messages + command: npm run release:validate + - run: + name: Publish to NPM + command: printf "noop running conventional-github-releaser" + +version: 2.0 +workflows: + version: 2 + validate-publish: + jobs: + - dependency_cache + - node6_webpack_latest: + requires: + - dependency_cache + filters: + tags: + only: /.*/ + - node8_webpack_latest: + requires: + - dependency_cache + filters: + tags: + only: /.*/ + - node9_webpack_latest: + requires: + - dependency_cache + filters: + tags: + only: /.*/ + - node8_webpack_canary: + requires: + - dependency_cache + filters: + tags: + only: /.*/ + - analysis: + requires: + - node6_webpack_latest + - node8_webpack_latest + - node9_webpack_latest + filters: + tags: + only: /.*/ + - publish: + requires: + - node6_webpack_latest + - node8_webpack_latest + - node9_webpack_latest + - analysis + filters: + branches: + only: + - master diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..28e1806 --- /dev/null +++ b/.editorconfig @@ -0,0 +1,13 @@ +# editorconfig.org + +[*] +charset = utf-8 +indent_style = space +indent_size = 2 +end_of_line = lf +insert_final_newline = true +trim_trailing_whitespace = true + +[.md] +insert_final_newline = false +trim_trailing_whitespace = false diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 0000000..8225baa --- /dev/null +++ b/.eslintignore @@ -0,0 +1,2 @@ +/node_modules +/dist diff --git a/.eslintrc.js b/.eslintrc.js new file mode 100644 index 0000000..f5064a3 --- /dev/null +++ b/.eslintrc.js @@ -0,0 +1,11 @@ +module.exports = { + root: true, + plugins: ['prettier'], + extends: ['@webpack-contrib/eslint-config-webpack'], + rules: { + 'prettier/prettier': [ + 'error', + { singleQuote: true, trailingComma: 'es5', arrowParens: 'always' }, + ], + }, +}; diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 0000000..70df4c9 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,3 @@ +package-lock.json -diff +* text=auto +bin/* eol=lf diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS new file mode 100644 index 0000000..f320648 --- /dev/null +++ b/.github/CODEOWNERS @@ -0,0 +1,6 @@ +# These are the default owners for everything in +# webpack-contrib +@webpack-contrib/org-maintainers + +# Add repository specific users / groups +# below here for libs that are not maintained by the org. diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md index f274013..4601e18 100644 --- a/.github/ISSUE_TEMPLATE.md +++ b/.github/ISSUE_TEMPLATE.md @@ -1,15 +1,7 @@ - + - -**What is the current behavior?** - -**If the current behavior is a bug, please provide the steps to reproduce.** - - -**What is the expected behavior?** - -**If this is a feature request, what is motivation or use case for changing the behavior?** - -**Please mention other relevant information such as your webpack version, Node.js version and Operating System.** +**IMPORTANT! You should use [Stack Overflow](https://stackoverflow.com/) for support related questions.** +--> diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md index 77e6835..cadb1bf 100644 --- a/.github/PULL_REQUEST_TEMPLATE.md +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -1,18 +1,5 @@ - - -**What kind of change does this PR introduce?** - - -**Did you add tests for your changes?** - -**If relevant, did you update the README?** - -**Summary** - - - - -**Does this PR introduce a breaking change?** - - -**Other information** + diff --git a/.gitignore b/.gitignore index b512c09..19e9e2d 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,16 @@ -node_modules \ No newline at end of file +node_modules +logs +*.log +npm-debug.log* +.eslintcache +/coverage +/dist +/local +/reports +/node_modules +.DS_Store +Thumbs.db +.idea +.vscode +*.sublime-project +*.sublime-workspace \ No newline at end of file diff --git a/.npmrc b/.npmrc new file mode 100644 index 0000000..43c97e7 --- /dev/null +++ b/.npmrc @@ -0,0 +1 @@ +package-lock=false diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000..e537c8a --- /dev/null +++ b/.prettierrc @@ -0,0 +1,5 @@ +{ + "singleQuote": true, + "trailingComma": "es5", + "arrowParens": "always" +} diff --git a/README.md b/README.md index 498390a..f8cc533 100644 --- a/README.md +++ b/README.md @@ -54,9 +54,9 @@ module.exports = { |Name|Type|Default|Description| |:--:|:--:|:-----:|:----------| -|**`limit`**|`{Number}`|`undefined`|Byte limit to inline files as Data URL| -|**`mimetype`**|`{String}`|`extname`|Specify MIME type for the file (Otherwise it's inferred from the file extension)| -|**`fallback`**|`{String}`|`file-loader`|Specify `loader` for the file when file is greater than the limit (in bytes)| +|**[`limit`](#limit)**|`{Number}`|`undefined`|Byte limit to inline files as Data URL| +|**[`mimetype`](#mimetype)**|`{String}`|`extname`|Specify MIME type for the file (Otherwise it's inferred from the file extension)| +|**[`fallback`](#fallback)**|`{String}`|`file-loader`|Specify `loader` for the file when file is greater than the limit (in bytes)| ### `limit` diff --git a/appveyor.yml b/appveyor.yml new file mode 100644 index 0000000..6f7f941 --- /dev/null +++ b/appveyor.yml @@ -0,0 +1,30 @@ +branches: + only: + - master + - next +init: + - git config --global core.autocrlf input +environment: + matrix: + - nodejs_version: '8' + webpack_version: latest + job_part: test + - nodejs_version: '6' + webpack_version: latest + job_part: test + - nodejs_version: '8' + webpack_version: next + job_part: test +build: 'off' +matrix: + fast_finish: true +install: + - ps: Install-Product node $env:nodejs_version x64 + - npm i -g npm@latest + - npm install +before_test: + - cmd: npm install webpack@%webpack_version% +test_script: + - node --version + - npm --version + - cmd: npm run ci:%job_part% diff --git a/codecov.yml b/codecov.yml new file mode 100644 index 0000000..9ff9166 --- /dev/null +++ b/codecov.yml @@ -0,0 +1,10 @@ +coverage: + precision: 2 + round: down + range: 70...100 + + status: + project: no + patch: yes + +comment: 'off' diff --git a/commitlint.config.js b/commitlint.config.js new file mode 100644 index 0000000..ede6e23 --- /dev/null +++ b/commitlint.config.js @@ -0,0 +1,31 @@ +/* eslint-disable */ +const Configuration = { + extends: ['@commitlint/config-angular'], + + rules: { + 'body-leading-blank': [1, 'always'], + 'footer-leading-blank': [1, 'always'], + 'header-max-length': [2, 'always', 72], + 'scope-case': [2, 'always', 'lower-case'], + 'subject-case': [2, 'never', ['start-case', 'pascal-case', 'upper-case']], + 'subject-empty': [2, 'never'], + 'subject-full-stop': [2, 'never', '.'], + 'type-case': [2, 'always', 'lower-case'], + 'type-empty': [2, 'never'], + 'type-enum': [ + 'build', + 'chore', + 'ci', + 'docs', + 'feat', + 'fix', + 'perf', + 'refactor', + 'revert', + 'style', + 'test', + ], + }, +}; + +module.exports = Configuration; diff --git a/index.js b/index.js deleted file mode 100644 index 8aa4666..0000000 --- a/index.js +++ /dev/null @@ -1,40 +0,0 @@ -/* - MIT License http://www.opensource.org/licenses/mit-license.php - Author Tobias Koppers @sokra - */ -var loaderUtils = require("loader-utils"); -var validateOptions = require("schema-utils"); - -var mime = require("mime"); - -module.exports = function(content) { - this.cacheable && this.cacheable(); - - var options = loaderUtils.getOptions(this) || {}; - - validateOptions(require("./options"), options, "URL Loader") - // Options `dataUrlLimit` is backward compatibility with first loader versions - var limit = options.limit || (this.options && this.options.url && this.options.url.dataUrlLimit); - - if(limit) { - limit = parseInt(limit, 10); - } - - var mimetype = options.mimetype || options.minetype || mime.lookup(this.resourcePath); - - // No limits or limit more than content length - if(!limit || content.length < limit) { - if(typeof content === "string") { - content = new Buffer(content); - } - - return "module.exports = " + JSON.stringify("data:" + (mimetype ? mimetype + ";" : "") + "base64," + content.toString("base64")); - } - - var fallback = options.fallback || "file-loader"; - var fallbackLoader = require(fallback); - - return fallbackLoader.call(this, content); -} - -module.exports.raw = true; diff --git a/package.json b/package.json index 582e932..8490079 100644 --- a/package.json +++ b/package.json @@ -2,28 +2,83 @@ "name": "url-loader", "version": "0.6.2", "author": "Tobias Koppers @sokra", - "description": "url loader module for webpack", + "description": "URL Loader for webpack", "license": "MIT", - "scripts": { - "release": "standard-version" + "engines": { + "node": ">= 6.9.0 || >= 8.9.0" }, + "main": "dist/cjs.js", + "files": [ + "dist" + ], "dependencies": { - "loader-utils": "^1.0.2", - "mime": "^1.4.1", - "schema-utils": "^0.3.0" + "loader-utils": "^1.1.0", + "mime": "^2.0.3", + "schema-utils": "^0.4.2" }, "devDependencies": { - "standard-version": "^4.0.0" + "@commitlint/cli": "^5.0.0", + "@commitlint/config-angular": "^5.0.0", + "@webpack-contrib/eslint-config-webpack": "^2.0.0", + "babel-cli": "^6.0.0", + "babel-jest": "^21.0.0", + "babel-plugin-transform-object-rest-spread": "^6.0.0", + "babel-polyfill": "^6.0.0", + "babel-preset-env": "^1.0.0", + "conventional-github-releaser": "^2.0.0", + "cross-env": "^5.0.0", + "del": "^3.0.0", + "del-cli": "^1.0.0", + "eslint": "^4.0.0", + "eslint-plugin-import": "^2.0.0", + "eslint-plugin-prettier": "^2.0.0", + "file-loader": "^1.0.0", + "husky": "^0.14.0", + "jest": "^21.0.0", + "lint-staged": "^6.0.0", + "memory-fs": "^0.4.1", + "nsp": "^3.1.0", + "pre-commit": "^1.0.0", + "prettier": "^1.0.0", + "standard-version": "^4.0.0", + "webpack": "^3.0.0", + "webpack-defaults": "^2.0.0-beta.1" }, "peerDependencies": { - "file-loader": "*" - }, - "repository": { - "type": "git", - "url": "git+https://github.com/webpack-contrib/url-loader.git" + "file-loader": "*", + "webpack": "^3.0.0 || ^4.0.0" }, - "bugs": { - "url": "https://github.com/webpack-contrib/url-loader/issues" + "scripts": { + "start": "npm run build -- -w", + "build": "cross-env NODE_ENV=production babel src -d dist --ignore 'src/**/*.test.js' --copy-files", + "clean": "del-cli dist", + "commitlint": "commitlint", + "commitmsg": "commitlint -e $GIT_PARAMS", + "lint": "eslint --cache src test", + "lint-staged": "lint-staged", + "prebuild": "npm run clean", + "prepublish": "npm run build", + "release:ci": "conventional-github-releaser -p angular", + "release:validate": "commitlint --from=$(git describe --tags --abbrev=0) --to=$(git rev-parse HEAD)", + "security": "nsp check", + "test": "jest", + "test:watch": "jest --watch", + "test:coverage": "jest --collectCoverageFrom='src/**/*.js' --coverage", + "ci:lint": "npm run lint && npm run security", + "ci:lint:commits": "commitlint --from=${CIRCLE_BRANCH} --to=${CIRCLE_SHA1}", + "ci:test": "npm run test -- --runInBand", + "ci:coverage": "npm run test:coverage -- --runInBand", + "webpack-defaults": "webpack-defaults", + "release": "standard-version" }, - "homepage": "https://github.com/webpack-contrib/url-loader" + "repository": "https://github.com/webpack-contrib/url-loader.git", + "bugs": "https://github.com/webpack-contrib/url-loader/issues", + "homepage": "https://github.com/webpack-contrib/url-loader", + "pre-commit": "lint-staged", + "lint-staged": { + "*.js": [ + "eslint --fix", + "git add" + ] + } } diff --git a/src/cjs.js b/src/cjs.js new file mode 100644 index 0000000..c1c8d9a --- /dev/null +++ b/src/cjs.js @@ -0,0 +1,4 @@ +const loader = require('./index'); + +module.exports = loader.default; +module.exports.raw = loader.raw; diff --git a/src/index.js b/src/index.js new file mode 100644 index 0000000..585328d --- /dev/null +++ b/src/index.js @@ -0,0 +1,45 @@ +/* eslint-disable + global-require, + no-param-reassign, + prefer-destructuring, + import/no-dynamic-require, +*/ +import { getOptions } from 'loader-utils'; +import validateOptions from 'schema-utils'; +import mime from 'mime'; +import schema from './options.json'; + +// Loader Mode +export const raw = true; + +export default function loader(src) { + // Loader Options + const options = getOptions(this) || {}; + + validateOptions(schema, options, 'URL Loader'); + + const file = this.resourcePath; + // Set limit for resource inlining (file size) + let limit = options.limit; + + if (limit) { + limit = parseInt(limit, 10); + } + // Get MIME type + const mimetype = options.mimetype || mime.getType(file); + + // No limit or within the specified limit + if (!limit || src.length < limit) { + if (typeof src === 'string') { + src = new Buffer(src); + } + + return `export default ${JSON.stringify( + `data:${mimetype || ''};base64,${src.toString('base64')}` + )}`; + } + + const fallback = require(options.fallback ? options.fallback : 'file-loader'); + + return fallback.call(this, src); +} diff --git a/options.json b/src/options.json similarity index 64% rename from options.json rename to src/options.json index 5a0c6c3..9e47900 100644 --- a/options.json +++ b/src/options.json @@ -2,15 +2,12 @@ "type": "object", "properties": { "limit": { - "type": ["number", "string"] - }, - "prefix": { - "type": "string" + "type": ["string", "number"] }, "mimetype": { "type": "string" }, - "encoding": { + "fallback": { "type": "string" } }, diff --git a/test/Errors.test.js b/test/Errors.test.js new file mode 100644 index 0000000..5d29bf6 --- /dev/null +++ b/test/Errors.test.js @@ -0,0 +1,13 @@ +/* eslint-disable + prefer-destructuring, +*/ +import loader from '../src'; + +describe('Errors', () => { + test('Validation Error', () => { + const err = () => loader.call({ query: { limit: {} } }); + + expect(err).toThrow(); + expect(err).toThrowErrorMatchingSnapshot(); + }); +}); diff --git a/test/__snapshots__/Errors.test.js.snap b/test/__snapshots__/Errors.test.js.snap new file mode 100644 index 0000000..0cf2c6d --- /dev/null +++ b/test/__snapshots__/Errors.test.js.snap @@ -0,0 +1,8 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Errors Validation Error 1`] = ` +"URL Loader Invalid Options + +options.limit should be string,number +" +`; diff --git a/test/__snapshots__/loader.test.js.snap b/test/__snapshots__/loader.test.js.snap new file mode 100644 index 0000000..469ea06 --- /dev/null +++ b/test/__snapshots__/loader.test.js.snap @@ -0,0 +1,3 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Loader Defaults 1`] = `"export default \\"\\""`; diff --git a/test/fixtures/file.gif b/test/fixtures/file.gif new file mode 100644 index 0000000..2c192da Binary files /dev/null and b/test/fixtures/file.gif differ diff --git a/test/fixtures/file.jpg b/test/fixtures/file.jpg new file mode 100644 index 0000000..8deb3d2 Binary files /dev/null and b/test/fixtures/file.jpg differ diff --git a/test/fixtures/file.png b/test/fixtures/file.png new file mode 100644 index 0000000..02d7a6b Binary files /dev/null and b/test/fixtures/file.png differ diff --git a/test/fixtures/file.svg b/test/fixtures/file.svg new file mode 100644 index 0000000..f083f3f --- /dev/null +++ b/test/fixtures/file.svg @@ -0,0 +1,48 @@ + + + + mochi + Created with Sketch. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/test/fixtures/fixture.js b/test/fixtures/fixture.js new file mode 100644 index 0000000..493c9e4 --- /dev/null +++ b/test/fixtures/fixture.js @@ -0,0 +1,2 @@ +/* eslint-disable */ +import png from './file.png'; diff --git a/test/helpers/compiler.js b/test/helpers/compiler.js new file mode 100644 index 0000000..87ba9ca --- /dev/null +++ b/test/helpers/compiler.js @@ -0,0 +1,73 @@ +/* eslint-disable + import/order, + no-param-reassign, + no-nested-ternary, +*/ +import del from 'del'; +import path from 'path'; +import webpack from 'webpack'; +import MemoryFS from 'memory-fs'; + +const modules = (config) => { + return { + rules: config.rules + ? config.rules + : config.loader + ? [ + { + test: config.loader.test || /\.txt$/, + use: { + loader: path.resolve(__dirname, '../../src'), + options: config.loader.options || {}, + }, + }, + ] + : [], + }; +}; + +const plugins = (config) => + [ + new webpack.optimize.CommonsChunkPlugin({ + names: ['runtime'], + minChunks: Infinity, + }), + ].concat(config.plugins || []); + +const output = (config) => { + return { + path: path.resolve( + __dirname, + `../outputs/${config.output ? config.output : ''}` + ), + filename: '[name].js', + chunkFilename: '[name].chunk.js', + }; +}; + +export default function(fixture, config, options) { + config = { + devtool: config.devtool || 'sourcemap', + context: path.resolve(__dirname, '..', 'fixtures'), + entry: `./${fixture}`, + output: output(config), + module: modules(config), + plugins: plugins(config), + }; + + options = Object.assign({ output: false }, options); + + if (options.output) del.sync(config.output.path); + + const compiler = webpack(config); + + if (!options.output) compiler.outputFileSystem = new MemoryFS(); + + return new Promise((resolve, reject) => + compiler.run((err, stats) => { + if (err) reject(err); + + resolve(stats); + }) + ); +} diff --git a/test/loader.test.js b/test/loader.test.js new file mode 100644 index 0000000..dc0599c --- /dev/null +++ b/test/loader.test.js @@ -0,0 +1,20 @@ +/* eslint-disable + prefer-destructuring, +*/ +import webpack from './helpers/compiler'; + +describe('Loader', () => { + test('Defaults', async () => { + const config = { + loader: { + test: /\.png$/, + options: {}, + }, + }; + + const stats = await webpack('fixture.js', config); + const { source } = stats.toJson().modules[1]; + + expect(source).toMatchSnapshot(); + }); +}); diff --git a/test/options/__snapshots__/fallback.test.js.snap b/test/options/__snapshots__/fallback.test.js.snap new file mode 100644 index 0000000..51a0c6b --- /dev/null +++ b/test/options/__snapshots__/fallback.test.js.snap @@ -0,0 +1,3 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Options fallback {String} 1`] = `"module.exports = __webpack_public_path__ + \\"9c87cbf3ba33126ffd25ae7f2f6bbafb.png\\";"`; diff --git a/test/options/__snapshots__/limit.test.js.snap b/test/options/__snapshots__/limit.test.js.snap new file mode 100644 index 0000000..1892913 --- /dev/null +++ b/test/options/__snapshots__/limit.test.js.snap @@ -0,0 +1,5 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Options limit {Number} 1`] = `"export default \\"\\""`; + +exports[`Options limit {String} 1`] = `"export default \\"\\""`; diff --git a/test/options/__snapshots__/mimetype.test.js.snap b/test/options/__snapshots__/mimetype.test.js.snap new file mode 100644 index 0000000..4dde0af --- /dev/null +++ b/test/options/__snapshots__/mimetype.test.js.snap @@ -0,0 +1,3 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Options mimetype {String} 1`] = `"export default \\"\\""`; diff --git a/test/options/fallback.test.js b/test/options/fallback.test.js new file mode 100644 index 0000000..175af8e --- /dev/null +++ b/test/options/fallback.test.js @@ -0,0 +1,25 @@ +/* eslint-disable + prefer-destructuring, +*/ +import webpack from '../helpers/compiler'; + +describe('Options', () => { + describe('fallback', () => { + test('{String}', async () => { + const config = { + loader: { + test: /\.png$/, + options: { + limit: 100, + fallback: 'file-loader', + }, + }, + }; + + const stats = await webpack('fixture.js', config); + const { source } = stats.toJson().modules[1]; + + expect(source).toMatchSnapshot(); + }); + }); +}); diff --git a/test/options/limit.test.js b/test/options/limit.test.js new file mode 100644 index 0000000..6b0c483 --- /dev/null +++ b/test/options/limit.test.js @@ -0,0 +1,40 @@ +/* eslint-disable + prefer-destructuring, +*/ +import webpack from '../helpers/compiler'; + +describe('Options', () => { + describe('limit', () => { + test('{Number}', async () => { + const config = { + loader: { + test: /\.png$/, + options: { + limit: 100000, + }, + }, + }; + + const stats = await webpack('fixture.js', config); + const { source } = stats.toJson().modules[1]; + + expect(source).toMatchSnapshot(); + }); + + test('{String}', async () => { + const config = { + loader: { + test: /\.png$/, + options: { + limit: '100000', + }, + }, + }; + + const stats = await webpack('fixture.js', config); + const { source } = stats.toJson().modules[1]; + + expect(source).toMatchSnapshot(); + }); + }); +}); diff --git a/test/options/mimetype.test.js b/test/options/mimetype.test.js new file mode 100644 index 0000000..baf4896 --- /dev/null +++ b/test/options/mimetype.test.js @@ -0,0 +1,24 @@ +/* eslint-disable + prefer-destructuring, +*/ +import webpack from '../helpers/compiler'; + +describe('Options', () => { + describe('mimetype', () => { + test('{String}', async () => { + const config = { + loader: { + test: /\.png$/, + options: { + mimetype: 'image/png', + }, + }, + }; + + const stats = await webpack('fixture.js', config); + const { source } = stats.toJson().modules[1]; + + expect(source).toMatchSnapshot(); + }); + }); +});