Skip to content

Commit

Permalink
test: ssr builtin
Browse files Browse the repository at this point in the history
  • Loading branch information
hi-ogawa committed Apr 27, 2024
1 parent ffe4dd1 commit 37190af
Showing 1 changed file with 21 additions and 1 deletion.
22 changes: 21 additions & 1 deletion packages/vite/src/node/__tests__/build.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -638,7 +638,27 @@ describe('resolveBuildOutputs', () => {
})
})

test('custom environment ssr', async () => {
test('ssr builtin', async () => {
const builder = await createBuilder({
root: resolve(__dirname, 'fixtures/dynamic-import'),
environments: {
ssr: {
build: {
ssr: true,
rollupOptions: {
input: {
index: '/entry',
},
},
},
},
},
})
const result = await builder.build(builder.environments.ssr)
expect((result as RollupOutput).output[0].code).not.toContain('preload')

Check failure on line 658 in packages/vite/src/node/__tests__/build.spec.ts

View workflow job for this annotation

GitHub Actions / Build&Test: node-18, ubuntu-latest

packages/vite/src/node/__tests__/build.spec.ts > resolveBuildOutputs > ssr builtin

AssertionError: expected 'const scriptRel = "modulepreload";\nc…' not to contain 'preload' - Expected + Received - preload + const scriptRel = "modulepreload"; + const assetsURL = function(dep) { + return "/" + dep; + }; + const seen = {}; + const __vitePreload = function preload(baseModule, deps, importerUrl) { + let promise = Promise.resolve(); + if (deps && deps.length > 0) { + const links = document.getElementsByTagName("link"); + const cspNonceMeta = document.querySelector( + "meta[property=csp-nonce]" + ); + const cspNonce = (cspNonceMeta == null ? void 0 : cspNonceMeta.nonce) || (cspNonceMeta == null ? void 0 : cspNonceMeta.getAttribute("nonce")); + promise = Promise.all( + deps.map((dep) => { + dep = assetsURL(dep); + if (dep in seen) + return; + seen[dep] = true; + const isCss = dep.endsWith(".css"); + const cssSelector = isCss ? '[rel="stylesheet"]' : ""; + const isBaseRelative = !!importerUrl; + if (isBaseRelative) { + for (let i = links.length - 1; i >= 0; i--) { + const link2 = links[i]; + if (link2.href === dep && (!isCss || link2.rel === "stylesheet")) { + return; + } + } + } else if (document.querySelector(`link[href="${dep}"]${cssSelector}`)) { + return; + } + const link = document.createElement("link"); + link.rel = isCss ? "stylesheet" : scriptRel; + if (!isCss) { + link.as = "script"; + link.crossOrigin = ""; + } + link.href = dep; + if (cspNonce) { + link.setAttribute("nonce", cspNonce); + } + document.head.appendChild(link); + if (isCss) { + return new Promise((res, rej) => { + link.addEventListener("load", res); + link.addEventListener( + "error", + () => rej(new Error(`Unable to preload CSS for ${dep}`)) + ); + }); + } + }) + ); + } + return promise.then(() => baseModule()).catch((err) => { + const e = new Event("vite:preloadError", { cancelable: true }); + e.payload = err; + window.dispatchEvent(e); + if (!e.defaultPrevented) { + throw err; + } + }); + }; + async function main() { + const mod = await __vitePreload(() => import("./assets/dep-BSaPgEGk.mjs"), true ? [] : void 0); + console.log(mod); + } + export { + main + }; + ❯ packages/vite/src/node/__tests__/build.spec.ts:658:57

Check failure on line 658 in packages/vite/src/node/__tests__/build.spec.ts

View workflow job for this annotation

GitHub Actions / Build&Test: node-20, ubuntu-latest

packages/vite/src/node/__tests__/build.spec.ts > resolveBuildOutputs > ssr builtin

AssertionError: expected 'const scriptRel = "modulepreload";\nc…' not to contain 'preload' - Expected + Received - preload + const scriptRel = "modulepreload"; + const assetsURL = function(dep) { + return "/" + dep; + }; + const seen = {}; + const __vitePreload = function preload(baseModule, deps, importerUrl) { + let promise = Promise.resolve(); + if (deps && deps.length > 0) { + const links = document.getElementsByTagName("link"); + const cspNonceMeta = document.querySelector( + "meta[property=csp-nonce]" + ); + const cspNonce = (cspNonceMeta == null ? void 0 : cspNonceMeta.nonce) || (cspNonceMeta == null ? void 0 : cspNonceMeta.getAttribute("nonce")); + promise = Promise.all( + deps.map((dep) => { + dep = assetsURL(dep); + if (dep in seen) + return; + seen[dep] = true; + const isCss = dep.endsWith(".css"); + const cssSelector = isCss ? '[rel="stylesheet"]' : ""; + const isBaseRelative = !!importerUrl; + if (isBaseRelative) { + for (let i = links.length - 1; i >= 0; i--) { + const link2 = links[i]; + if (link2.href === dep && (!isCss || link2.rel === "stylesheet")) { + return; + } + } + } else if (document.querySelector(`link[href="${dep}"]${cssSelector}`)) { + return; + } + const link = document.createElement("link"); + link.rel = isCss ? "stylesheet" : scriptRel; + if (!isCss) { + link.as = "script"; + link.crossOrigin = ""; + } + link.href = dep; + if (cspNonce) { + link.setAttribute("nonce", cspNonce); + } + document.head.appendChild(link); + if (isCss) { + return new Promise((res, rej) => { + link.addEventListener("load", res); + link.addEventListener( + "error", + () => rej(new Error(`Unable to preload CSS for ${dep}`)) + ); + }); + } + }) + ); + } + return promise.then(() => baseModule()).catch((err) => { + const e = new Event("vite:preloadError", { cancelable: true }); + e.payload = err; + window.dispatchEvent(e); + if (!e.defaultPrevented) { + throw err; + } + }); + }; + async function main() { + const mod = await __vitePreload(() => import("./assets/dep-BSaPgEGk.mjs"), true ? [] : void 0); + console.log(mod); + } + export { + main + }; + ❯ packages/vite/src/node/__tests__/build.spec.ts:658:57

Check failure on line 658 in packages/vite/src/node/__tests__/build.spec.ts

View workflow job for this annotation

GitHub Actions / Build&Test: node-20, macos-latest

packages/vite/src/node/__tests__/build.spec.ts > resolveBuildOutputs > ssr builtin

AssertionError: expected 'const scriptRel = "modulepreload";\nc…' not to contain 'preload' - Expected + Received - preload + const scriptRel = "modulepreload"; + const assetsURL = function(dep) { + return "/" + dep; + }; + const seen = {}; + const __vitePreload = function preload(baseModule, deps, importerUrl) { + let promise = Promise.resolve(); + if (deps && deps.length > 0) { + const links = document.getElementsByTagName("link"); + const cspNonceMeta = document.querySelector( + "meta[property=csp-nonce]" + ); + const cspNonce = (cspNonceMeta == null ? void 0 : cspNonceMeta.nonce) || (cspNonceMeta == null ? void 0 : cspNonceMeta.getAttribute("nonce")); + promise = Promise.all( + deps.map((dep) => { + dep = assetsURL(dep); + if (dep in seen) + return; + seen[dep] = true; + const isCss = dep.endsWith(".css"); + const cssSelector = isCss ? '[rel="stylesheet"]' : ""; + const isBaseRelative = !!importerUrl; + if (isBaseRelative) { + for (let i = links.length - 1; i >= 0; i--) { + const link2 = links[i]; + if (link2.href === dep && (!isCss || link2.rel === "stylesheet")) { + return; + } + } + } else if (document.querySelector(`link[href="${dep}"]${cssSelector}`)) { + return; + } + const link = document.createElement("link"); + link.rel = isCss ? "stylesheet" : scriptRel; + if (!isCss) { + link.as = "script"; + link.crossOrigin = ""; + } + link.href = dep; + if (cspNonce) { + link.setAttribute("nonce", cspNonce); + } + document.head.appendChild(link); + if (isCss) { + return new Promise((res, rej) => { + link.addEventListener("load", res); + link.addEventListener( + "error", + () => rej(new Error(`Unable to preload CSS for ${dep}`)) + ); + }); + } + }) + ); + } + return promise.then(() => baseModule()).catch((err) => { + const e = new Event("vite:preloadError", { cancelable: true }); + e.payload = err; + window.dispatchEvent(e); + if (!e.defaultPrevented) { + throw err; + } + }); + }; + async function main() { + const mod = await __vitePreload(() => import("./assets/dep-BSaPgEGk.mjs"), true ? [] : void 0); + console.log(mod); + } + export { + main + }; + ❯ packages/vite/src/node/__tests__/build.spec.ts:658:57

Check failure on line 658 in packages/vite/src/node/__tests__/build.spec.ts

View workflow job for this annotation

GitHub Actions / Build&Test: node-20, windows-latest

packages/vite/src/node/__tests__/build.spec.ts > resolveBuildOutputs > ssr builtin

AssertionError: expected 'const scriptRel = "modulepreload";\nc…' not to contain 'preload' - Expected + Received - preload + const scriptRel = "modulepreload"; + const assetsURL = function(dep) { + return "/" + dep; + }; + const seen = {}; + const __vitePreload = function preload(baseModule, deps, importerUrl) { + let promise = Promise.resolve(); + if (deps && deps.length > 0) { + const links = document.getElementsByTagName("link"); + const cspNonceMeta = document.querySelector( + "meta[property=csp-nonce]" + ); + const cspNonce = (cspNonceMeta == null ? void 0 : cspNonceMeta.nonce) || (cspNonceMeta == null ? void 0 : cspNonceMeta.getAttribute("nonce")); + promise = Promise.all( + deps.map((dep) => { + dep = assetsURL(dep); + if (dep in seen) + return; + seen[dep] = true; + const isCss = dep.endsWith(".css"); + const cssSelector = isCss ? '[rel="stylesheet"]' : ""; + const isBaseRelative = !!importerUrl; + if (isBaseRelative) { + for (let i = links.length - 1; i >= 0; i--) { + const link2 = links[i]; + if (link2.href === dep && (!isCss || link2.rel === "stylesheet")) { + return; + } + } + } else if (document.querySelector(`link[href="${dep}"]${cssSelector}`)) { + return; + } + const link = document.createElement("link"); + link.rel = isCss ? "stylesheet" : scriptRel; + if (!isCss) { + link.as = "script"; + link.crossOrigin = ""; + } + link.href = dep; + if (cspNonce) { + link.setAttribute("nonce", cspNonce); + } + document.head.appendChild(link); + if (isCss) { + return new Promise((res, rej) => { + link.addEventListener("load", res); + link.addEventListener( + "error", + () => rej(new Error(`Unable to preload CSS for ${dep}`)) + ); + }); + } + }) + ); + } + return promise.then(() => baseModule()).catch((err) => { + const e = new Event("vite:preloadError", { cancelable: true }); + e.payload = err; + window.dispatchEvent(e); + if (!e.defaultPrevented) { + throw err; + } + }); + }; + async function main() { + const mod = await __vitePreload(() => import("./assets/dep-BSaPgEGk.mjs"), true ? [] : void 0); + console.log(mod); + } + export { + main + }; + ❯ packages/vite/src/node/__tests__/build.spec.ts:658:57
})

test('ssr custom', async () => {
const builder = await createBuilder({
root: resolve(__dirname, 'fixtures/dynamic-import'),
environments: {
Expand Down

0 comments on commit 37190af

Please sign in to comment.