2021-04-19 18:41:06 +00:00
|
|
|
import { suite } from 'uvu';
|
|
|
|
import * as assert from 'uvu/assert';
|
|
|
|
import { doc } from './test-utils.js';
|
2021-04-19 20:13:53 +00:00
|
|
|
import { setup, setupBuild } from './helpers.js';
|
2021-04-19 18:41:06 +00:00
|
|
|
|
|
|
|
const DynamicComponents = suite('Dynamic components tests');
|
|
|
|
|
|
|
|
setup(DynamicComponents, './fixtures/astro-dynamic');
|
2021-04-19 20:13:53 +00:00
|
|
|
setupBuild(DynamicComponents, './fixtures/astro-dynamic');
|
2021-04-19 18:41:06 +00:00
|
|
|
|
|
|
|
DynamicComponents('Loads client-only packages', async ({ runtime }) => {
|
|
|
|
let result = await runtime.load('/');
|
|
|
|
|
|
|
|
assert.equal(result.statusCode, 200);
|
|
|
|
|
|
|
|
// Grab the react-dom import
|
|
|
|
const exp = /import\("(.+?)"\)/g;
|
|
|
|
let match, reactDomURL;
|
2021-04-19 18:41:37 +00:00
|
|
|
while ((match = exp.exec(result.contents))) {
|
|
|
|
if (match[1].includes('react-dom')) {
|
2021-04-19 18:41:06 +00:00
|
|
|
reactDomURL = match[1];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.ok(reactDomURL, 'React dom is on the page');
|
2021-04-19 18:41:37 +00:00
|
|
|
|
2021-04-19 18:41:06 +00:00
|
|
|
result = await runtime.load(reactDomURL);
|
|
|
|
assert.equal(result.statusCode, 200, 'Can load react-dom');
|
|
|
|
});
|
|
|
|
|
2021-04-19 20:13:53 +00:00
|
|
|
DynamicComponents('Can be built', async ({ build }) => {
|
|
|
|
try {
|
|
|
|
await build();
|
|
|
|
assert.ok(true, 'Can build a project with svelte dynamic components');
|
2021-04-19 20:14:27 +00:00
|
|
|
} catch (err) {
|
2021-04-19 20:13:53 +00:00
|
|
|
console.log(err);
|
|
|
|
assert.ok(false, 'build threw');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-04-19 18:41:06 +00:00
|
|
|
DynamicComponents.run();
|