719002ca5b
* update config schema * adapt default route `prerender` value * adapt error message for hybrid output * core hybrid output support * add JSDocs for hybrid output * dev server hybrid output support * defer hybrid output check * update endpoint request warning * support `output=hybrid` in integrations * put constant variable out of for loop * revert: reapply back ssr plugin in ssr mode * change `prerender` option default * apply `prerender` by default in hybrid mode * simplfy conditional * update config schema * add `isHybridOutput` helper * more readable prerender condition * set default prerender value if no export is found * only add `pagesVirtualModuleId` ro rollup input in `output=static` * don't export vite plugin * remove unneeded check * don't prerender when it shouldn't * extract fallback `prerender` meta Extract the fallback `prerender` module meta out of the `scan` function. It shouldn't be its responsibility to handle that * pass missing argument to function * test: update cloudflare integration tests * test: update tests of vercel integration * test: update tests of node integration * test: update tests of netlify func integration * test: update tests of netlify edge integration * throw when `hybrid` mode is malconfigured * update node integraiton `output` warning * test(WIP): skip node prerendering tests for now * remove non-existant import * test: bring back prerendering tests * remove outdated comments * test: refactor test to support windows paths * remove outdated comments * apply sarah review Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> * docs: `experiment.hybridOutput` jsodcs * test: prevent import from being cached * refactor: extract hybrid output check to function * add `hybrid` to output warning in adapter hooks * chore: changeset * add `.js` extension to import * chore: use spaces instead of tabs for gh formating * resolve merge conflict * chore: move test to another file for consitency --------- Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> Co-authored-by: Matthew Phillips <matthew@skypack.dev>
66 lines
1.4 KiB
JavaScript
66 lines
1.4 KiB
JavaScript
import { loadFixture as baseLoadFixture } from '../../../astro/test/test-utils.js';
|
|
import { spawn } from 'child_process';
|
|
import { fileURLToPath } from 'url';
|
|
|
|
export { fixLineEndings } from '../../../astro/test/test-utils.js';
|
|
|
|
/**
|
|
* @typedef {import('../../../astro/test/test-utils').Fixture} Fixture
|
|
*/
|
|
|
|
export function loadFixture(config) {
|
|
if (config?.root) {
|
|
config.root = new URL(config.root, import.meta.url);
|
|
}
|
|
return baseLoadFixture(config);
|
|
}
|
|
|
|
const wranglerPath = fileURLToPath(
|
|
new URL('../node_modules/wrangler/bin/wrangler.js', import.meta.url)
|
|
);
|
|
|
|
export function runCLI(basePath, { silent }) {
|
|
const script = fileURLToPath(new URL(`${basePath}/dist/_worker.js`, import.meta.url));
|
|
const p = spawn('node', [wranglerPath, 'dev', '-l', script]);
|
|
|
|
p.stderr.setEncoding('utf-8');
|
|
p.stdout.setEncoding('utf-8');
|
|
|
|
const timeout = 10000;
|
|
|
|
const ready = new Promise(async (resolve, reject) => {
|
|
const failed = setTimeout(
|
|
() => reject(new Error(`Timed out starting the wrangler CLI`)),
|
|
timeout
|
|
);
|
|
|
|
(async function () {
|
|
for (const msg of p.stderr) {
|
|
if (!silent) {
|
|
// eslint-disable-next-line
|
|
console.error(msg);
|
|
}
|
|
}
|
|
})();
|
|
|
|
for await (const msg of p.stdout) {
|
|
if (!silent) {
|
|
// eslint-disable-next-line
|
|
console.log(msg);
|
|
}
|
|
if (msg.includes(`Listening on`)) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
clearTimeout(failed);
|
|
resolve();
|
|
});
|
|
|
|
return {
|
|
ready,
|
|
stop() {
|
|
p.kill();
|
|
},
|
|
};
|
|
}
|