summaryrefslogtreecommitdiff
path: root/packages/integrations/netlify/test/edge-functions/prerender.test.ts
diff options
context:
space:
mode:
authorGravatar Happydev <81974850+MoustaphaDev@users.noreply.github.com> 2023-05-17 13:23:20 +0000
committerGravatar GitHub <noreply@github.com> 2023-05-17 09:23:20 -0400
commit719002ca5b128744fb4316d4a52c5dcd46a42759 (patch)
treef43782264925e7d7cb3675f1c859f39c898e2458 /packages/integrations/netlify/test/edge-functions/prerender.test.ts
parent2b9230ed22dd379633ece3fcd9d485dfc3064441 (diff)
downloadastro-719002ca5b128744fb4316d4a52c5dcd46a42759.tar.gz
astro-719002ca5b128744fb4316d4a52c5dcd46a42759.tar.zst
astro-719002ca5b128744fb4316d4a52c5dcd46a42759.zip
feat: hybrid output (#6991)
* 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>
Diffstat (limited to 'packages/integrations/netlify/test/edge-functions/prerender.test.ts')
-rw-r--r--packages/integrations/netlify/test/edge-functions/prerender.test.ts81
1 files changed, 71 insertions, 10 deletions
diff --git a/packages/integrations/netlify/test/edge-functions/prerender.test.ts b/packages/integrations/netlify/test/edge-functions/prerender.test.ts
index 5d858ef73..4d4dfc9c6 100644
--- a/packages/integrations/netlify/test/edge-functions/prerender.test.ts
+++ b/packages/integrations/netlify/test/edge-functions/prerender.test.ts
@@ -1,15 +1,76 @@
-import { runBuild } from './test-utils.ts';
-import { assertEquals } from './deps.ts';
+import { loadFixture } from './test-utils.ts';
+import { assertEquals, assertExists, cheerio, fs } from './deps.ts';
Deno.test({
name: 'Prerender',
- async fn() {
- let close = await runBuild('./fixtures/prerender/');
- const { default: handler } = await import(
- './fixtures/prerender/.netlify/edge-functions/entry.js'
- );
- const response = await handler(new Request('http://example.com/index.html'));
- assertEquals(response, undefined, 'No response because this is an asset');
- await close();
+ async fn(t) {
+ const environmentVariables = {
+ PRERENDER: 'true',
+ };
+ const fixture = loadFixture('./fixtures/prerender/', environmentVariables);
+ await fixture.runBuild();
+
+ await t.step('Handler can process requests to non-existing routes', async () => {
+ const { default: handler } = await import(
+ './fixtures/prerender/.netlify/edge-functions/entry.js'
+ );
+ assertExists(handler);
+ const response = await handler(new Request('http://example.com/index.html'));
+ assertEquals(response, undefined, "No response because this route doesn't exist");
+ });
+
+ await t.step('Prerendered route exists', async () => {
+ let content: string | null = null;
+ try {
+ const path = new URL('./fixtures/prerender/dist/index.html', import.meta.url);
+ content = Deno.readTextFileSync(path);
+ } catch (e) {}
+ assertExists(content);
+ const $ = cheerio.load(content);
+ assertEquals($('h1').text(), 'testing');
+ });
+
+ Deno.env.delete('PRERENDER');
+ await fixture.cleanup();
+ },
+});
+
+Deno.test({
+ name: 'Hybrid rendering',
+ async fn(t) {
+ const environmentVariables = {
+ PRERENDER: 'false',
+ };
+ const fixture = loadFixture('./fixtures/prerender/', environmentVariables);
+ await fixture.runBuild();
+
+ const stop = await fixture.runApp('./fixtures/prerender/prod.js');
+ await t.step('Can fetch server route', async () => {
+ const response = await fetch('http://127.0.0.1:8085/');
+ assertEquals(response.status, 200);
+
+ const html = await response.text();
+ const $ = cheerio.load(html);
+ assertEquals($('h1').text(), 'testing');
+ });
+ stop();
+
+ await t.step('Handler can process requests to non-existing routes', async () => {
+ const { default: handler } = await import(
+ './fixtures/prerender/.netlify/edge-functions/entry.js'
+ );
+ const response = await handler(new Request('http://example.com/index.html'));
+ assertEquals(response, undefined, "No response because this route doesn't exist");
+ });
+
+ await t.step('Has no prerendered route', async () => {
+ let prerenderedRouteExists = false;
+ try {
+ const path = new URL('./fixtures/prerender/dist/index.html', import.meta.url);
+ prerenderedRouteExists = fs.existsSync(path);
+ } catch (e) {}
+ assertEquals(prerenderedRouteExists, false);
+ });
+ await fixture.cleanup();
},
});