rendering.test.js — astro Source File
Architecture documentation for rendering.test.js, a javascript file in the astro codebase. 5 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR e3fe003a_df56_8dae_828e_d1fb163c9c09["rendering.test.js"] 36446797_9ff6_e36e_ac08_4b016b6eefad["../../../dist/runtime/server/index.js"] e3fe003a_df56_8dae_828e_d1fb163c9c09 --> 36446797_9ff6_e36e_ac08_4b016b6eefad e1e2fac7_5a95_7a88_cb1e_0a3b91c4e607["strict"] e3fe003a_df56_8dae_828e_d1fb163c9c09 --> e1e2fac7_5a95_7a88_cb1e_0a3b91c4e607 6b0635f9_51ea_77aa_767b_7857878e98a6["node:test"] e3fe003a_df56_8dae_828e_d1fb163c9c09 --> 6b0635f9_51ea_77aa_767b_7857878e98a6 3d2a7ed8_891d_0ee1_3ee3_4af62832f876["types"] e3fe003a_df56_8dae_828e_d1fb163c9c09 --> 3d2a7ed8_891d_0ee1_3ee3_4af62832f876 deb87372_5629_35f8_9a54_e755a08f776a["cheerio"] e3fe003a_df56_8dae_828e_d1fb163c9c09 --> deb87372_5629_35f8_9a54_e755a08f776a style e3fe003a_df56_8dae_828e_d1fb163c9c09 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
import * as assert from 'node:assert/strict';
import { beforeEach, describe, it } from 'node:test';
import { isPromise } from 'node:util/types';
import * as cheerio from 'cheerio';
import {
createComponent,
HTMLString,
renderComponent,
renderTemplate,
} from '../../../dist/runtime/server/index.js';
const DEFAULT_RESULT = {
clientDirectives: new Map(),
};
describe('rendering', () => {
const evaluated = [];
const Scalar = createComponent((_result, props) => {
evaluated.push(props.id);
return renderTemplate`<scalar id="${props.id}"></scalar>`;
});
beforeEach(() => {
evaluated.length = 0;
});
it('components are evaluated and rendered depth-first', async () => {
const Root = createComponent((result, props) => {
evaluated.push(props.id);
return renderTemplate`<root id="${props.id}">
${renderComponent(result, '', Scalar, { id: `${props.id}/scalar_1` })}
${renderComponent(result, '', Nested, { id: `${props.id}/nested` })}
${renderComponent(result, '', Scalar, { id: `${props.id}/scalar_2` })}
</root>`;
});
const Nested = createComponent((result, props) => {
evaluated.push(props.id);
return renderTemplate`<nested id="${props.id}">
${renderComponent(result, '', Scalar, { id: `${props.id}/scalar` })}
</nested>`;
});
const result = await renderToString(Root(DEFAULT_RESULT, { id: 'root' }, {}));
const rendered = getRenderedIds(result);
assert.deepEqual(evaluated, [
'root',
'root/scalar_1',
'root/nested',
'root/nested/scalar',
'root/scalar_2',
]);
assert.deepEqual(rendered, [
'root',
'root/scalar_1',
'root/nested',
'root/nested/scalar',
// ... (257 more lines)
Domain
Subdomains
Functions
Classes
Dependencies
- ../../../dist/runtime/server/index.js
- cheerio
- node:test
- strict
- types
Source
Frequently Asked Questions
What does rendering.test.js do?
rendering.test.js is a source file in the astro codebase, written in javascript. It belongs to the IntegrationAdapters domain, SsrAdapters subdomain.
What functions are defined in rendering.test.js?
rendering.test.js defines 2 function(s): getRenderedIds, renderToString.
What does rendering.test.js depend on?
rendering.test.js imports 5 module(s): ../../../dist/runtime/server/index.js, cheerio, node:test, strict, types.
Where is rendering.test.js in the architecture?
rendering.test.js is located at packages/astro/test/units/render/rendering.test.js (domain: IntegrationAdapters, subdomain: SsrAdapters, directory: packages/astro/test/units/render).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free