Skip to content

Commit

Permalink
fix(webpack): include hash in asset filenames so they do not conflict
Browse files Browse the repository at this point in the history
  • Loading branch information
jaysoo committed Jul 26, 2024
1 parent b7f2514 commit 72ea4a1
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 19 deletions.
22 changes: 12 additions & 10 deletions e2e/react/src/react.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,8 @@ describe('React Applications', () => {
const libName = uniq('lib');
const libWithNoComponents = uniq('lib');
const logoSvg = readFileSync(join(__dirname, 'logo.svg')).toString();
const blueSvg = `<?xml version="1.0"?><svg xmlns="http://www.w3.org/2000/svg" version="1.2" baseProfile="tiny" viewBox="0 0 30 30"><rect x="10" y="10" width="10" height="10" fill="blue"/></svg>`;
const redSvg = `<?xml version="1.0"?><svg xmlns="http://www.w3.org/2000/svg" version="1.2" baseProfile="tiny" viewBox="0 0 30 30"><rect x="10" y="10" width="10" height="10" fill="red"/></svg>`;

runCLI(
`generate @nx/react:app ${appName} --style=css --bundler=webpack --no-interactive --skipFormat`
Expand All @@ -92,11 +94,15 @@ describe('React Applications', () => {
`
);

updateFile(`apps/${appName}/src/app/blue/img.svg`, blueSvg); // ensure that same filenames do not conflict
updateFile(`apps/${appName}/src/app/red/img.svg`, redSvg); // ensure that same filenames do not conflict
updateFile(`apps/${appName}/src/app/logo.svg`, logoSvg);
updateFile(
`apps/${appName}/src/app/app.tsx`,
`
import { ReactComponent as Logo } from './logo.svg';
import blue from './blue/img.svg';
import red from './red/img.svg';
import logo from './logo.svg';
import NxWelcome from './nx-welcome';
Expand All @@ -105,6 +111,8 @@ describe('React Applications', () => {
<>
<Logo />
<img src={logo} alt="" />
<img src={blue} alt="" />
<img src={red} alt="" />
<NxWelcome title="${appName}" />
</>
);
Expand Down Expand Up @@ -134,10 +142,7 @@ describe('React Applications', () => {
checkSourceMap: true,
checkStyles: true,
checkLinter: true,
// TODO(caleb): Fix cypress tests
// /tmp/nx-e2e--1970-rQ4U0qBe6Nht/nx/proj1614306/dist/apps/app5172641/server/runtime.js:119
// if (typeof import.meta.url === "string") scriptUrl = import.meta.url
// SyntaxError: Cannot use 'import.meta' outside a module
// TODO(jack): check why Playwright tests are timing out in CI
checkE2E: false,
});

Expand All @@ -150,13 +155,10 @@ describe('React Applications', () => {
checkSourceMap: false,
checkStyles: false,
checkLinter: false,
// TODO(caleb): Fix cypress tests
// /tmp/nx-e2e--1970-rQ4U0qBe6Nht/nx/proj1614306/dist/apps/app5172641/server/runtime.js:119
// if (typeof import.meta.url === "string") scriptUrl = import.meta.url
// SyntaxError: Cannot use 'import.meta' outside a module
// TODO(jack): check why Playwright tests are timing out in CI
checkE2E: false,
});
}, 500000);
}, 500_000);

it('should generate app with routing', async () => {
const appName = uniq('app');
Expand Down Expand Up @@ -532,7 +534,7 @@ async function testGeneratedApp(

if (opts.checkE2E && runE2ETests()) {
const e2eResults = runCLI(`e2e ${appName}-e2e`);
expect(e2eResults).toContain('All specs passed!');
expect(e2eResults).toContain('Successfully ran target e2e');
expect(await killPorts()).toBeTruthy();
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -332,6 +332,11 @@ export function applyWebConfig(

config.output = {
...config.output,
assetModuleFilename:
// Turn on hashing if output hashing is used (default for web, or if in dev mode to avoid name conflicts).
options.outputHashing || process.env.NODE_ENV !== 'production'
? '[name].[contenthash:20][ext]'
: '[name][ext]',
crossOriginLoading: options.subresourceIntegrity
? ('anonymous' as const)
: (false as const),
Expand Down Expand Up @@ -404,9 +409,6 @@ export function applyWebConfig(
maxSize: 10_000, // 10 kB
},
},
generator: {
filename: `[name]${hashFormat.file}[ext]`,
},
},
// SVG: same as image but we need to separate it so it can be swapped for SVGR in the React plugin.
{
Expand All @@ -417,17 +419,11 @@ export function applyWebConfig(
maxSize: 10_000, // 10 kB
},
},
generator: {
filename: `[name]${hashFormat.file}[ext]`,
},
},
// Fonts: Emit separate file and export the URL.
{
test: /\.(eot|otf|ttf|woff|woff2)$/,
type: 'asset/resource',
generator: {
filename: `[name]${hashFormat.file}[ext]`,
},
},
...rules,
],
Expand Down

0 comments on commit 72ea4a1

Please sign in to comment.