Skip to content

Commit

Permalink
fix: different production base path does not work
Browse files Browse the repository at this point in the history
add test-case which uses a base-path
  • Loading branch information
rpetersen27 committed May 2, 2021
1 parent 2d42d0f commit b6fbb4a
Show file tree
Hide file tree
Showing 8 changed files with 70 additions and 6 deletions.
14 changes: 14 additions & 0 deletions packages/playground/base-path/__tests__/base-path.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
import { readFile, untilUpdated, isBuild } from '../../testUtils'

test('should work', async () => {
await page.click('.clickme')
await untilUpdated(() => page.textContent('.content'), '3', true)
})

if (isBuild) {
test('should have relative path', async () => {
expect(readFile('dist/foo/assets/index.js')).toMatch(
/.*\.\/assets\/preload\.js.*/
)
})
}
5 changes: 5 additions & 0 deletions packages/playground/base-path/dep.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import preload from './preload'

export function test() {
return 1 + preload()
}
4 changes: 4 additions & 0 deletions packages/playground/base-path/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
<script type="module" src="./main.js"></script>

<button class="clickme">Click me</button>
<div class="content"></div>
4 changes: 4 additions & 0 deletions packages/playground/base-path/main.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
document.querySelector('.clickme').addEventListener('click', async () => {
const { test } = await import('./dep.js')
document.querySelector('.content').textContent = test()
})
11 changes: 11 additions & 0 deletions packages/playground/base-path/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"name": "base-path",
"private": true,
"version": "0.0.0",
"scripts": {
"dev": "vite",
"build": "vite build",
"debug": "node --inspect-brk ../../vite/bin/vite",
"serve": "vite preview"
}
}
3 changes: 3 additions & 0 deletions packages/playground/base-path/preload.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export default function () {
return 2
}
24 changes: 24 additions & 0 deletions packages/playground/base-path/vite.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
const { resolve } = require('path')

/**
* @type {import('vite').UserConfig}
*/
module.exports = {
base: '/foo/',
build: {
// simulate production environment
outDir: 'dist/foo',
// prevent bundling of dep and preload to ensure that vite-preloading occurs
rollupOptions: {
input: [
resolve(__dirname, 'index.html'),
resolve(__dirname, 'preload.js'),
resolve(__dirname, 'dep.js')
],
// use simple entry names for easier reference inside the tests
output: {
entryFileNames: 'assets/[name].js'
}
}
}
}
11 changes: 5 additions & 6 deletions packages/vite/src/node/plugins/importAnalysisBuild.ts
Original file line number Diff line number Diff line change
Expand Up @@ -242,11 +242,13 @@ export function buildImportAnalysisPlugin(config: ResolvedConfig): Plugin {
analyzed.add(filename)
const chunk = bundle[filename] as OutputChunk | undefined
if (chunk) {
deps.add(config.base + chunk.fileName)
// use a relative path https://github.com/vitejs/vite/pull/3061
deps.add('./' + chunk.fileName)
const cssFiles = chunkToEmittedCssFileMap.get(chunk)
if (cssFiles) {
cssFiles.forEach((file) => {
deps.add(config.base + file)
// use a relative path https://github.com/vitejs/vite/pull/3061
deps.add('./' + file)
})
}
chunk.imports.forEach(addDeps)
Expand All @@ -267,10 +269,7 @@ export function buildImportAnalysisPlugin(config: ResolvedConfig): Plugin {
// the dep list includes the main chunk, so only need to
// preload when there are actual other deps.
deps.size > 1
? `[${[...deps]
// replace leading slashes to ensure a relative path. See https://github.com/vitejs/vite/pull/3061
.map((d) => JSON.stringify(d.replace(/^\//, './')))
.join(',')}]`
? `[${[...deps].map((d) => JSON.stringify(d)).join(',')}]`
: `void 0`
)
}
Expand Down

0 comments on commit b6fbb4a

Please sign in to comment.