2022-03-30 08:42:19 -04:00
|
|
|
import { runBuildAndStartApp } from './helpers.js';
|
2022-04-15 17:01:33 -04:00
|
|
|
import { assertEquals, assert, DOMParser } from './deps.js';
|
|
|
|
|
|
|
|
async function startApp(cb) {
|
|
|
|
await runBuildAndStartApp('./fixtures/basics/', cb);
|
|
|
|
}
|
2022-03-30 08:42:19 -04:00
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
name: 'Basics',
|
|
|
|
async fn() {
|
2022-04-15 17:01:33 -04:00
|
|
|
await startApp(async () => {
|
2022-03-30 08:42:19 -04:00
|
|
|
const resp = await fetch('http://127.0.0.1:8085/');
|
|
|
|
assertEquals(resp.status, 200);
|
|
|
|
const html = await resp.text();
|
|
|
|
assert(html);
|
2022-04-21 12:10:06 -04:00
|
|
|
const doc = new DOMParser().parseFromString(html, `text/html`);
|
2022-04-21 16:11:09 +00:00
|
|
|
const div = doc.querySelector('#react');
|
2022-04-21 12:10:06 -04:00
|
|
|
assert(div, 'div exists');
|
2022-03-30 08:42:19 -04:00
|
|
|
});
|
2022-03-30 12:43:13 +00:00
|
|
|
},
|
2022-03-30 08:42:19 -04:00
|
|
|
});
|
2022-04-15 17:01:33 -04:00
|
|
|
|
|
|
|
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');
|
2022-04-15 21:02:19 +00:00
|
|
|
|
2022-04-15 17:01:33 -04:00
|
|
|
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');
|
2022-04-15 21:02:19 +00:00
|
|
|
await resp.body.cancel();
|
2022-04-15 17:01:33 -04:00
|
|
|
});
|
2022-04-15 21:02:19 +00:00
|
|
|
},
|
|
|
|
});
|