17c3c98f07
* Begin debugging * Initial tests set up This adds tests using uvu (we can switch if people want) and restructures things a bit so that it's easier to test. Like in snowpack you set up a little project. In our tests you can say: ```js const result = await runtime.load('/blog/hello-world') ``` And analyze the result. I included a `test-helpers.js` which has a function that will turn HTML into a cheerio instance, for inspecting the result HTML. * Add CI * Remove extra console logs * Formatting
38 lines
No EOL
844 B
JavaScript
38 lines
No EOL
844 B
JavaScript
import { suite } from 'uvu';
|
|
import * as assert from 'uvu/assert';
|
|
import { createRuntime } from '../lib/runtime.js';
|
|
import { doc } from './test-utils.js';
|
|
|
|
const Basics = suite('HMX Basics');
|
|
|
|
let runtime;
|
|
|
|
Basics.before(async () => {
|
|
const astroConfig = {
|
|
projectRoot: new URL('./fixtures/hmx-basic/', import.meta.url),
|
|
hmxRoot: new URL('./fixtures/hmx-basic/astro/', import.meta.url),
|
|
dist: './_site'
|
|
};
|
|
|
|
const logging = {
|
|
level: 'error',
|
|
dest: process.stderr
|
|
};
|
|
|
|
runtime = await createRuntime(astroConfig, logging);
|
|
});
|
|
|
|
Basics.after(async () => {
|
|
await runtime.shutdown();
|
|
});
|
|
|
|
Basics('Can load hmx page', async () => {
|
|
const result = await runtime.load('/');
|
|
|
|
assert.equal(result.statusCode, 200);
|
|
const $ = doc(result.contents);
|
|
|
|
assert.equal($('h1').text(), 'Hello world!');
|
|
});
|
|
|
|
Basics.run(); |