mirror of
https://github.com/withastro/astro.git
synced 2025-03-10 23:01:26 -05:00
* chore: move `nodetest.js` to `test.js` * chore: move `nodetest.js` to `test.js` * remove script
39 lines
1.2 KiB
JavaScript
39 lines
1.2 KiB
JavaScript
import assert from 'node:assert/strict';
|
|
import { before, describe, it } from 'node:test';
|
|
import * as cheerio from 'cheerio';
|
|
import { loadFixture } from './test-utils.js';
|
|
|
|
describe('Component parallelization', () => {
|
|
let fixture;
|
|
|
|
before(async () => {
|
|
fixture = await loadFixture({
|
|
root: './fixtures/parallel/',
|
|
});
|
|
await fixture.build();
|
|
});
|
|
|
|
it('renders fast', async () => {
|
|
let html = await fixture.readFile('/index.html');
|
|
let $ = cheerio.load(html);
|
|
|
|
const startTimes = Array.from($('.start')).map((element) => Number(element.children[0].data));
|
|
const finishTimes = Array.from($('.finished')).map((element) =>
|
|
Number(element.children[0].data)
|
|
);
|
|
|
|
const renderStartWithin = Math.max(...startTimes) - Math.min(...startTimes);
|
|
assert.equal(
|
|
renderStartWithin < 40,
|
|
true, // in theory, this should be 0, but add 40ms tolerance for CI
|
|
"The components didn't start rendering in parallel"
|
|
);
|
|
|
|
const totalRenderTime = Math.max(...finishTimes) - Math.min(...startTimes);
|
|
assert.equal(
|
|
totalRenderTime < 80,
|
|
true, // max component delay is 40ms, add 40ms tolerance for CI
|
|
'The total render time was significantly longer than the max component delay'
|
|
);
|
|
});
|
|
});
|