Skip to content

Commit

Permalink
fix: more consistent cache (#43)
Browse files Browse the repository at this point in the history
  • Loading branch information
evilebottnawi authored Dec 19, 2018
1 parent bd40cbc commit 36f5f3c
Show file tree
Hide file tree
Showing 11 changed files with 289 additions and 280 deletions.
36 changes: 18 additions & 18 deletions package-lock.json

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

2 changes: 0 additions & 2 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -228,14 +228,12 @@ class TerserPlugin {
};

if (this.options.cache) {
const { outputPath } = compiler;
const defaultCacheKeys = {
// eslint-disable-next-line global-require
terser: require('terser/package.json').version,
// eslint-disable-next-line global-require
'terser-webpack-plugin': require('../package.json').version,
'terser-webpack-plugin-options': this.options,
path: `${outputPath ? `${outputPath}/` : ''}${file}`,
hash: crypto
.createHash('md4')
.update(input)
Expand Down
305 changes: 163 additions & 142 deletions test/__snapshots__/cache-option.test.js.snap

Large diffs are not rendered by default.

96 changes: 48 additions & 48 deletions test/__snapshots__/extractComments-option.test.js.snap

Large diffs are not rendered by default.

70 changes: 34 additions & 36 deletions test/__snapshots__/test-option.test.js.snap

Large diffs are not rendered by default.

39 changes: 5 additions & 34 deletions test/cache-option.test.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
import path from 'path';

import cacache from 'cacache';
import findCacheDir from 'find-cache-dir';

Expand All @@ -16,10 +14,11 @@ describe('when applied with `cache` option', () => {
beforeEach(() => {
compiler = createCompiler({
entry: {
one: `${__dirname}/fixtures/entry.js`,
two: `${__dirname}/fixtures/entry.js`,
three: `${__dirname}/fixtures/entry.js`,
four: `${__dirname}/fixtures/entry.js`,
one: `${__dirname}/fixtures/cache.js`,
two: `${__dirname}/fixtures/cache-1.js`,
three: `${__dirname}/fixtures/cache-2.js`,
four: `${__dirname}/fixtures/cache-3.js`,
five: `${__dirname}/fixtures/cache-4.js`,
},
});

Expand Down Expand Up @@ -105,18 +104,6 @@ describe('when applied with `cache` option', () => {
// Make sure that we cached files
expect(cacheKeys.length).toBe(countAssets);

cacheKeys.forEach((cacheEntry) => {
// eslint-disable-next-line no-new-func
const cacheEntryOptions = new Function(
`'use strict'\nreturn ${cacheEntry}`
)();
const basename = path.basename(cacheEntryOptions.path);

expect([basename, cacheEntryOptions.hash]).toMatchSnapshot(
basename
);
});

cacache.get.mockClear();
cacache.put.mockClear();
})
Expand Down Expand Up @@ -192,18 +179,6 @@ describe('when applied with `cache` option', () => {
// Make sure that we cached files
expect(cacheKeys.length).toBe(countAssets);

cacheKeys.forEach((cacheEntry) => {
// eslint-disable-next-line no-new-func
const cacheEntryOptions = new Function(
`'use strict'\nreturn ${cacheEntry}`
)();
const basename = path.basename(cacheEntryOptions.path);

expect([basename, cacheEntryOptions.hash]).toMatchSnapshot(
basename
);
});

cacache.get.mockClear();
cacache.put.mockClear();
})
Expand Down Expand Up @@ -294,15 +269,11 @@ describe('when applied with `cache` option', () => {
const cacheEntryOptions = new Function(
`'use strict'\nreturn ${cacheEntry}`
)();
const basename = path.basename(cacheEntryOptions.path);

expect(cacheEntryOptions.myCacheKey).toBe(1);
expect(cacheEntryOptions.myCacheKeyBasedOnFile).toMatch(
/file-(.+)?\.js/
);
expect([basename, cacheEntryOptions.hash]).toMatchSnapshot(
basename
);
});

cacache.get.mockClear();
Expand Down
1 change: 1 addition & 0 deletions test/fixtures/cache-1.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
module.exports = 'string';
1 change: 1 addition & 0 deletions test/fixtures/cache-2.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
module.exports = () => { return /test/ };
1 change: 1 addition & 0 deletions test/fixtures/cache-3.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
module.exports = class A {};
9 changes: 9 additions & 0 deletions test/fixtures/cache-4.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
// foo
/* @preserve*/
// bar
const a = 2 + 2;

module.exports = function Foo() {
const b = 2 + 2;
console.log(b + 1 + 2);
};
9 changes: 9 additions & 0 deletions test/fixtures/cache.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
// foo
/* @preserve*/
// bar
const a = 2 + 2;

module.exports = function Foo() {
const b = 2 + 2;
console.log(b + 1 + 2);
};

0 comments on commit 36f5f3c

Please sign in to comment.