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

docs: improve documentation about fallback #194

Merged
merged 1 commit into from Oct 4, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Jump to
Jump to file
Failed to load files.
Diff view
Diff view
4 changes: 2 additions & 2 deletions README.md
Expand Up @@ -79,7 +79,7 @@ module.exports = {
{
loader: 'url-loader',
options: {
fallback: 'responsive-loader',
fallback: require.resolve('responsive-loader'),
},
},
],
Expand All @@ -105,7 +105,7 @@ module.exports = {
{
loader: 'url-loader',
options: {
fallback: 'responsive-loader',
fallback: require.resolve('responsive-loader'),
quality: 85,
},
},
Expand Down
6 changes: 6 additions & 0 deletions test/__snapshots__/fallback-option.test.js.snap
Expand Up @@ -2,8 +2,14 @@

exports[`fallback option {Object} 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"fallback-[hash].[ext]\\",\\"unknown\\":\\"fallback-other-value\\"}"`;

exports[`fallback option {Object} require.resolve 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"fallback-[hash].[ext]\\",\\"unknown\\":\\"fallback-other-value\\"}"`;

exports[`fallback option {String} (with query) 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"fallback-[hash].[ext]\\",\\"unknown\\":\\"fallback-value\\"}"`;

exports[`fallback option {String} (with query) require.resolve 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"fallback-[hash].[ext]\\",\\"unknown\\":\\"fallback-value\\"}"`;

exports[`fallback option {String} 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"[name].[hash].[ext]\\",\\"unknown\\":\\"value\\"}"`;

exports[`fallback option {String} require.resolve 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"[name].[hash].[ext]\\",\\"unknown\\":\\"value\\"}"`;

exports[`fallback option {undefined} 1`] = `"module.exports = \\"\\""`;
80 changes: 80 additions & 0 deletions test/fallback-option.test.js
Expand Up @@ -46,6 +46,30 @@ describe('fallback option', () => {
expect(source).toMatchSnapshot();
});

it('{String} require.resolve', async () => {
const config = {
rules: [
{
test: /\.png$/,
use: {
loader: path.join(__dirname, '../src'),
options: {
limit: Number.MIN_SAFE_INTEGER,
name: '[name].[hash].[ext]',
unknown: 'value',
fallback: require.resolve('./fixtures/x-custom-loader'),
},
},
},
],
};

const stats = await webpack('fixture.js', config);
const [{ source }] = stats.toJson().modules;

expect(source).toMatchSnapshot();
});

it('{String} (with query)', async () => {
const config = {
rules: [
Expand Down Expand Up @@ -73,6 +97,32 @@ describe('fallback option', () => {
expect(source).toMatchSnapshot();
});

it('{String} (with query) require.resolve', async () => {
const config = {
rules: [
{
test: /\.png$/,
use: {
loader: path.join(__dirname, '../src'),
options: {
limit: Number.MIN_SAFE_INTEGER,
name: '[name].[hash].[ext]',
unknown: 'value',
fallback: `${require.resolve(
'./fixtures/x-custom-loader'
)}?name=fallback-[hash].[ext]&unknown=fallback-value`,
},
},
},
],
};

const stats = await webpack('fixture.js', config);
const [{ source }] = stats.toJson().modules;

expect(source).toMatchSnapshot();
});

it('{Object}', async () => {
const config = {
rules: [
Expand Down Expand Up @@ -102,4 +152,34 @@ describe('fallback option', () => {

expect(source).toMatchSnapshot();
});

it('{Object} require.resolve', async () => {
const config = {
rules: [
{
test: /\.png$/,
use: {
loader: path.join(__dirname, '../src'),
options: {
limit: Number.MIN_SAFE_INTEGER,
name: '[name].[hash].[ext]',
unknown: 'value',
fallback: {
loader: require.resolve('./fixtures/x-custom-loader'),
options: {
name: 'fallback-[hash].[ext]',
unknown: 'fallback-other-value',
},
},
},
},
},
],
};

const stats = await webpack('fixture.js', config);
const [{ source }] = stats.toJson().modules;

expect(source).toMatchSnapshot();
});
});