ReactDOMEventListener-test.js — react Source File
Architecture documentation for ReactDOMEventListener-test.js, a javascript file in the react codebase.
Entity Profile
Relationship Graph
Source Code
/**
* 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
*/
'use strict';
describe('ReactDOMEventListener', () => {
let React;
let ReactDOM;
let ReactDOMClient;
let ReactDOMServer;
let act;
let simulateEventDispatch;
beforeEach(() => {
jest.resetModules();
React = require('react');
ReactDOM = require('react-dom');
ReactDOMClient = require('react-dom/client');
ReactDOMServer = require('react-dom/server');
act = require('internal-test-utils').act;
simulateEventDispatch =
require('internal-test-utils').simulateEventDispatch;
});
describe('Propagation', () => {
it('should propagate events one level down', async () => {
const mouseOut = jest.fn();
const onMouseOut = event => mouseOut(event.currentTarget);
const childContainer = document.createElement('div');
const parentContainer = document.createElement('div');
const childRoot = ReactDOMClient.createRoot(childContainer);
const parentRoot = ReactDOMClient.createRoot(parentContainer);
await act(() => {
childRoot.render(<div onMouseOut={onMouseOut}>Child</div>);
parentRoot.render(<div onMouseOut={onMouseOut}>Parent</div>);
});
const parentNode = parentContainer.firstChild;
const childNode = childContainer.firstChild;
parentNode.appendChild(childContainer);
document.body.appendChild(parentContainer);
try {
const nativeEvent = document.createEvent('Event');
nativeEvent.initEvent('mouseout', true, true);
childNode.dispatchEvent(nativeEvent);
expect(mouseOut).toHaveBeenCalledTimes(2);
expect(mouseOut).toHaveBeenNthCalledWith(1, childNode);
expect(mouseOut).toHaveBeenNthCalledWith(2, parentNode);
} finally {
// ... (1245 more lines)
Domain
Subdomains
Classes
Source
Frequently Asked Questions
What does ReactDOMEventListener-test.js do?
ReactDOMEventListener-test.js is a source file in the react codebase, written in javascript. It belongs to the BabelCompiler domain, Validation subdomain.
Where is ReactDOMEventListener-test.js in the architecture?
ReactDOMEventListener-test.js is located at packages/react-dom/src/__tests__/ReactDOMEventListener-test.js (domain: BabelCompiler, subdomain: Validation, directory: packages/react-dom/src/__tests__).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free