/** * Copyright (c) Meta Platforms, Inc. and affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @emails react-core * @jest-environment ./scripts/jest/ReactDOMServerIntegrationEnvironment */ 'use strict'; const ReactDOMServerIntegrationUtils = require('./utils/ReactDOMServerIntegrationTestUtils'); let React; let ReactDOM; let ReactDOMClient; let ReactDOMServer; let assertConsoleErrorDev; function initModules() { // Reset warning cache. jest.resetModules(); React = require('react'); ReactDOM = require('react-dom'); ReactDOMClient = require('react-dom/client'); ReactDOMServer = require('react-dom/server'); assertConsoleErrorDev = require('internal-test-utils').assertConsoleErrorDev; // Make them available to the helpers. return { ReactDOMClient, ReactDOMServer, }; } const {resetModules, itRenders, clientCleanRender} = ReactDOMServerIntegrationUtils(initModules); describe('ReactDOMServerIntegration', () => { beforeEach(() => { resetModules(); }); afterEach(() => { // TODO: This is a hack because expectErrors does not restore mock, // however fixing it requires a major refactor to all these tests. if (console.error.mockClear) { console.error.mockRestore(); } }); describe('property to attribute mapping', function () { describe('string properties', function () { itRenders('simple numbers', async render => { const e = await render(
); expect(e.getAttribute('width')).toBe('30'); }); itRenders('simple strings', async render => { const e = await render(); expect(e.getAttribute('width')).toBe('30'); }); itRenders('empty src on img', async render => { const e = await render(