Home / File/ rendering.test.js — astro Source File

rendering.test.js — astro Source File

Architecture documentation for rendering.test.js, a javascript file in the astro codebase. 5 imports, 0 dependents.

File javascript IntegrationAdapters SsrAdapters 5 imports 2 functions 1 classes

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)

Subdomains

Dependencies

  • ../../../dist/runtime/server/index.js
  • cheerio
  • node:test
  • strict
  • types

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