Fix use of dynamic imports / Astro.glob with Deno Deploy (#3532)

* Fix use of dynamic imports / Astro.glob with Deno Deploy

* Adds a changeset

* Mark the markdown package as external
This commit is contained in:
Matthew Phillips 2022-06-06 12:02:13 -04:00 committed by GitHub
parent 9029c43549
commit c22a07db13
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
12 changed files with 157 additions and 9 deletions

View file

@ -0,0 +1,5 @@
---
'@astrojs/deno': patch
---
Fix for using Astro.glob when using the Deno Deploy adapter

View file

@ -22,7 +22,12 @@
"build": "astro-scripts build \"src/**/*.ts\" && tsc", "build": "astro-scripts build \"src/**/*.ts\" && tsc",
"build:ci": "astro-scripts build \"src/**/*.ts\"", "build:ci": "astro-scripts build \"src/**/*.ts\"",
"dev": "astro-scripts dev \"src/**/*.ts\"", "dev": "astro-scripts dev \"src/**/*.ts\"",
"test": "deno test --allow-run --allow-read --allow-env --allow-net ./test/" "test:import": "deno test --allow-run --allow-env --allow-read --allow-net --ignore=test/dynamic-import.test.js ./test/",
"test:subprocess": "deno test --allow-run --allow-env --allow-net ./test/dynamic-import.test.js",
"test": "npm run test:import && npm run test:subprocess"
},
"dependencies": {
"esbuild": "^0.14.42"
}, },
"devDependencies": { "devDependencies": {
"astro": "workspace:*", "astro": "workspace:*",

View file

@ -1,4 +1,8 @@
import type { AstroAdapter, AstroIntegration } from 'astro'; import type { AstroAdapter, AstroIntegration } from 'astro';
import { fileURLToPath } from 'url';
import esbuild from 'esbuild';
import * as npath from 'path';
import * as fs from 'fs';
interface Options { interface Options {
port?: number; port?: number;
@ -15,14 +19,20 @@ export function getAdapter(args?: Options): AstroAdapter {
} }
export default function createIntegration(args?: Options): AstroIntegration { export default function createIntegration(args?: Options): AstroIntegration {
let _buildConfig: any;
let _vite: any;
return { return {
name: '@astrojs/deno', name: '@astrojs/deno',
hooks: { hooks: {
'astro:config:done': ({ setAdapter }) => { 'astro:config:done': ({ setAdapter }) => {
setAdapter(getAdapter(args)); setAdapter(getAdapter(args));
}, },
'astro:build:start': ({ buildConfig }) => {
_buildConfig = buildConfig;
},
'astro:build:setup': ({ vite, target }) => { 'astro:build:setup': ({ vite, target }) => {
if (target === 'server') { if (target === 'server') {
_vite = vite;
vite.resolve = vite.resolve || {}; vite.resolve = vite.resolve || {};
vite.resolve.alias = vite.resolve.alias || {}; vite.resolve.alias = vite.resolve.alias || {};
@ -41,6 +51,28 @@ export default function createIntegration(args?: Options): AstroIntegration {
}; };
} }
}, },
'astro:build:done': async () => {
const entryUrl = new URL(_buildConfig.serverEntry, _buildConfig.server);
const pth = fileURLToPath(entryUrl);
await esbuild.build({
target: 'es2020',
platform: 'browser',
entryPoints: [pth],
outfile: pth,
allowOverwrite: true,
format: 'esm',
bundle: true,
external: [ "@astrojs/markdown-remark"]
});
// Remove chunks, if they exist. Since we have bundled via esbuild these chunks are trash.
try {
const chunkFileNames = _vite?.build?.rollupOptions?.output?.chunkFileNames ?? 'chunks/chunk.[hash].mjs';
const chunkPath = npath.dirname(chunkFileNames);
const chunksDirUrl = new URL(chunkPath + '/', _buildConfig.server);
await fs.promises.rm(chunksDirUrl, { recursive: true, force: true });
} catch {}
}
}, },
}; };
} }

View file

@ -32,13 +32,15 @@ export function start(manifest: SSRManifest, options: Options) {
return fetch(localPath.toString()); return fetch(localPath.toString());
}; };
const port = options.port ?? 8085;
_server = new Server({ _server = new Server({
port: options.port ?? 8085, port,
hostname: options.hostname ?? '0.0.0.0', hostname: options.hostname ?? '0.0.0.0',
handler, handler,
}); });
_startPromise = _server.listenAndServe(); _startPromise = Promise.resolve(_server.listenAndServe());
console.error(`Server running on port ${port}`);
} }
export function createExports(manifest: SSRManifest, options: Options) { export function createExports(manifest: SSRManifest, options: Options) {

View file

@ -1,3 +1,4 @@
export * from 'https://deno.land/std@0.110.0/path/mod.ts'; export * from 'https://deno.land/std@0.110.0/path/mod.ts';
export * from 'https://deno.land/std@0.132.0/testing/asserts.ts'; export * from 'https://deno.land/std@0.132.0/testing/asserts.ts';
export * from 'https://deno.land/x/deno_dom/deno-dom-wasm.ts'; export * from 'https://deno.land/x/deno_dom/deno-dom-wasm.ts';
export * from 'https://deno.land/std@0.142.0/streams/conversion.ts';

View file

@ -0,0 +1,21 @@
import { runBuildAndStartAppFromSubprocess } from './helpers.js';
import { assertEquals, assert, DOMParser } from './deps.js';
async function startApp(cb) {
await runBuildAndStartAppFromSubprocess('./fixtures/dynimport/', cb);
}
Deno.test({
name: 'Dynamic import',
async fn() {
await startApp(async () => {
const resp = await fetch('http://127.0.0.1:8085/');
assertEquals(resp.status, 200);
const html = await resp.text();
assert(html);
const doc = new DOMParser().parseFromString(html, `text/html`);
const div = doc.querySelector('#thing');
assert(div, 'div exists');
});
},
});

View file

@ -0,0 +1,9 @@
import { defineConfig } from 'astro/config';
import deno from '@astrojs/deno';
export default defineConfig({
adapter: deno(),
experimental: {
ssr: true
}
})

View file

@ -0,0 +1,9 @@
{
"name": "@test/deno-astro-dynimport",
"version": "0.0.0",
"private": true,
"dependencies": {
"astro": "workspace:*",
"@astrojs/deno": "workspace:*"
}
}

View file

@ -0,0 +1,4 @@
---
---
<div id="thing">testing</div>

View file

@ -0,0 +1,11 @@
---
const { default: Thing } = await import('../components/Thing.astro');
---
<html>
<head>
<title>testing</title>
</head>
<body>
<Thing />
</body>
</html>

View file

@ -1,4 +1,4 @@
import { fromFileUrl } from './deps.js'; import { readableStreamFromReader, fromFileUrl } from './deps.js';
const dir = new URL('./', import.meta.url); const dir = new URL('./', import.meta.url);
export async function runBuild(fixturePath) { export async function runBuild(fixturePath) {
@ -10,14 +10,52 @@ export async function runBuild(fixturePath) {
return async () => await proc.close(); return async () => await proc.close();
} }
export async function runBuildAndStartApp(fixturePath, cb) { export async function startModFromImport(baseUrl) {
const url = new URL(fixturePath, dir); const entryUrl = new URL('./dist/server/entry.mjs', baseUrl);
const close = await runBuild(fixturePath); const mod = await import(entryUrl);
const mod = await import(new URL('./dist/server/entry.mjs', url));
if (!mod.running()) { if (!mod.running()) {
mod.start(); mod.start();
} }
return () => mod.stop();
}
export async function startModFromSubprocess(baseUrl) {
const entryUrl = new URL('./dist/server/entry.mjs', baseUrl);
let proc = Deno.run({
cmd: ['deno', 'run', '--allow-env', '--allow-net', fromFileUrl(entryUrl)],
cwd: fromFileUrl(baseUrl),
stderr: 'piped'
});
const stderr = readableStreamFromReader(proc.stderr);
const dec = new TextDecoder();
for await(let bytes of stderr) {
let msg = dec.decode(bytes);
if(msg.includes(`Server running`)) {
break;
}
}
return () => proc.close();
}
export async function runBuildAndStartApp(fixturePath, cb) {
const url = new URL(fixturePath, dir);
const close = await runBuild(fixturePath);
const stop = await startModFromImport(url);
await cb(); await cb();
await mod.stop(); await stop();
await close();
}
export async function runBuildAndStartAppFromSubprocess(fixturePath, cb) {
const url = new URL(fixturePath, dir);
const close = await runBuild(fixturePath);
const stop = await startModFromSubprocess(url);
await cb();
await stop();
await close(); await close();
} }

View file

@ -1645,6 +1645,9 @@ importers:
specifiers: specifiers:
astro: workspace:* astro: workspace:*
astro-scripts: workspace:* astro-scripts: workspace:*
esbuild: ^0.14.42
dependencies:
esbuild: 0.14.42
devDependencies: devDependencies:
astro: link:../../astro astro: link:../../astro
astro-scripts: link:../../../scripts astro-scripts: link:../../../scripts
@ -1659,6 +1662,14 @@ importers:
'@astrojs/react': link:../../../../react '@astrojs/react': link:../../../../react
astro: link:../../../../../astro astro: link:../../../../../astro
packages/integrations/deno/test/fixtures/dynimport:
specifiers:
'@astrojs/deno': workspace:*
astro: workspace:*
dependencies:
'@astrojs/deno': link:../../..
astro: link:../../../../../astro
packages/integrations/lit: packages/integrations/lit:
specifiers: specifiers:
'@lit-labs/ssr': ^2.2.0 '@lit-labs/ssr': ^2.2.0