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

Commit

Permalink
fix: relax options validation for additional properties (#309)
Browse files Browse the repository at this point in the history
  • Loading branch information
evilebottnawi authored Dec 20, 2018
1 parent 40a206e commit c74d44e
Show file tree
Hide file tree
Showing 8 changed files with 132 additions and 60 deletions.
91 changes: 58 additions & 33 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@
"memory-fs": "^0.4.0",
"prettier": "^1.11.1",
"standard-version": "^4.0.0",
"url-loader": "^1.1.2",
"webpack": "^4.5.0"
},
"keywords": [
Expand Down
2 changes: 1 addition & 1 deletion src/options.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"additionalProperties": false,
"additionalProperties": true,
"properties": {
"name": {
"anyOf": [
Expand Down
17 changes: 5 additions & 12 deletions test/__snapshots__/errors.test.js.snap
Original file line number Diff line number Diff line change
Expand Up @@ -3,20 +3,13 @@
exports[`validation errors 1`] = `
"File Loader Invalid Options
options should NOT have additional properties
"
`;

exports[`validation errors 2`] = `
"File Loader Invalid Options
options.name should be string
options.name should pass \\"instanceof\\" keyword validation
options.name should match some schema in anyOf
"
`;

exports[`validation errors 3`] = `
exports[`validation errors 2`] = `
"File Loader Invalid Options
options.outputPath should be string
Expand All @@ -25,7 +18,7 @@ options.outputPath should match some schema in anyOf
"
`;

exports[`validation errors 4`] = `
exports[`validation errors 3`] = `
"File Loader Invalid Options
options.publicPath should be string
Expand All @@ -34,21 +27,21 @@ options.publicPath should match some schema in anyOf
"
`;

exports[`validation errors 5`] = `
exports[`validation errors 4`] = `
"File Loader Invalid Options
options.context should be string
"
`;

exports[`validation errors 6`] = `
exports[`validation errors 5`] = `
"File Loader Invalid Options
options.emitFile should be boolean
"
`;

exports[`validation errors 7`] = `
exports[`validation errors 6`] = `
"File Loader Invalid Options
options.regExp should be string
Expand Down
4 changes: 4 additions & 0 deletions test/__snapshots__/loader.test.js.snap
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`loader should works with \`url-loader\` when limit is less 1`] = `"module.exports = __webpack_public_path__ + \\"9c87cbf3ba33126ffd25ae7f2f6bbafb.png\\";"`;

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

exports[`loader should works without options 1`] = `"module.exports = __webpack_public_path__ + \\"9c87cbf3ba33126ffd25ae7f2f6bbafb.png\\";"`;
6 changes: 3 additions & 3 deletions test/errors.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,9 @@ describe('validation', () => {
'a { color: red; }'
);

expect(() =>
validate({ unknown: 'unknown' })
).toThrowErrorMatchingSnapshot();
// The `file-loader` loader can be used as `fallback` loader and options can contain not only `file-loader` options
// so we use `additionalProperties: false` to avoid problems.
expect(() => validate({ limit: 8192 })).not.toThrow();

expect(() => validate({ name: '[path][name].[ext]' })).not.toThrow();
expect(() =>
Expand Down
Loading

0 comments on commit c74d44e

Please sign in to comment.