Skip to content

Commit

Permalink
Handle static file serving in Deno adapter's start command (#3121)
Browse files Browse the repository at this point in the history
* Handle static file serving in Deno adapter's start command

* Adds a changeset

* Ignore a .ts imort
  • Loading branch information
matthewp authored Apr 15, 2022
1 parent b0ba22c commit e5383cd
Show file tree
Hide file tree
Showing 7 changed files with 55 additions and 8 deletions.
5 changes: 5 additions & 0 deletions .changeset/brave-planes-punch.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@astrojs/deno': patch
---

Handles file serving in the main export
2 changes: 1 addition & 1 deletion packages/integrations/deno/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ export function getAdapter(args?: Options): AstroAdapter {
name: '@astrojs/deno',
serverEntrypoint: '@astrojs/deno/server.js',
args: args ?? {},
exports: ['stop', 'handle'],
exports: ['stop', 'handle', 'start', 'running'],
};
}

Expand Down
23 changes: 18 additions & 5 deletions packages/integrations/deno/src/server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ import type { SSRManifest } from 'astro';
import { App } from 'astro/app';
// @ts-ignore
import { Server } from 'https://deno.land/std@0.132.0/http/server.ts';
// @ts-ignore
import { fetch } from 'https://deno.land/x/file_fetch/mod.ts';

interface Options {
port?: number;
Expand All @@ -18,32 +20,43 @@ export function start(manifest: SSRManifest, options: Options) {
return;
}

const clientRoot = new URL('../client/', import.meta.url);
const app = new App(manifest);

const handler = async (request: Request) => {
const response = await app.render(request);
return response;
if(app.match(request)) {
return await app.render(request);
}

const url = new URL(request.url);
const localPath = new URL('.' + url.pathname, clientRoot);
return fetch(localPath.toString());
};

_server = new Server({
port: options.port ?? 8085,
hostname: options.hostname ?? '0.0.0.0',
handler,
//onError: options.onError,
});

_startPromise = _server.listenAndServe();
}

export function createExports(manifest: SSRManifest) {
export function createExports(manifest: SSRManifest, options: Options) {
const app = new App(manifest);
return {
async stop() {
if (_server) {
_server.close();
_server = undefined;
}
await Promise.resolve(_startPromise);
},
running() {
return _server !== undefined;
},
async start() {
return start(manifest, options);
},
async handle(request: Request) {
return app.render(request);
},
Expand Down
28 changes: 26 additions & 2 deletions packages/integrations/deno/test/basics.test.js
Original file line number Diff line number Diff line change
@@ -1,14 +1,38 @@
import { runBuildAndStartApp } from './helpers.js';
import { assertEquals, assert } from './deps.js';
import { assertEquals, assert, DOMParser } from './deps.js';

async function startApp(cb) {
await runBuildAndStartApp('./fixtures/basics/', cb);
}

Deno.test({
name: 'Basics',
async fn() {
await runBuildAndStartApp('./fixtures/basics/', async () => {
await startApp(async () => {
const resp = await fetch('http://127.0.0.1:8085/');
assertEquals(resp.status, 200);
const html = await resp.text();
assert(html);
});
},
});

Deno.test({
name: 'Loads style assets',
async fn() {
await startApp(async () => {
let resp = await fetch('http://127.0.0.1:8085/');
const html = await resp.text();

const doc = new DOMParser().parseFromString(html, `text/html`);
const link = doc.querySelector('link');
const href = link.getAttribute('href');

resp = await fetch(new URL(href, 'http://127.0.0.1:8085/'));
assertEquals(resp.status, 200);
const ct = resp.headers.get('content-type');
assertEquals(ct, 'text/css');
await resp.body.cancel()
});
}
})
1 change: 1 addition & 0 deletions packages/integrations/deno/test/deps.js
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
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/x/deno_dom/deno-dom-wasm.ts';
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
<html>
<head>
<title>Basic App on Deno</title>
<style>body { font-family: 'Courier New', Courier, monospace; }</style>
</head>
<body>
<h1>Basic App on Deno</h1>
Expand Down
3 changes: 3 additions & 0 deletions packages/integrations/deno/test/helpers.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@ export async function runBuildAndStartApp(fixturePath, cb) {
const url = new URL(fixturePath, dir);
const close = await runBuild(fixturePath);
const mod = await import(new URL('./dist/server/entry.mjs', url));
if(!mod.running()) {
mod.start();
}
await cb();
await mod.stop();
await close();
Expand Down

0 comments on commit e5383cd

Please sign in to comment.