Home / File/ SyntheticFocusEvent-test.js — react Source File

SyntheticFocusEvent-test.js — react Source File

Architecture documentation for SyntheticFocusEvent-test.js, a javascript file in the react codebase.

Entity Profile

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.
 */

'use strict';

describe('SyntheticFocusEvent', () => {
  let React;
  let ReactDOMClient;
  let act;
  let container;

  beforeEach(() => {
    jest.resetModules();
    React = require('react');
    ReactDOMClient = require('react-dom/client');
    act = require('internal-test-utils').act;

    container = document.createElement('div');
    document.body.appendChild(container);
  });

  afterEach(() => {
    document.body.removeChild(container);
    container = null;
  });

  it('onFocus events have the focus type', async () => {
    const log = [];
    const root = ReactDOMClient.createRoot(container);
    await act(() => {
      root.render(
        <button
          onFocus={event => log.push(`onFocus: ${event.type}`)}
          onFocusCapture={event => log.push(`onFocusCapture: ${event.type}`)}
        />,
      );
    });

    const button = container.querySelector('button');

    await act(() => {
      button.dispatchEvent(
        new FocusEvent('focusin', {
          bubbles: true,
          cancelable: false,
        }),
      );
    });

    expect(log).toEqual(['onFocusCapture: focus', 'onFocus: focus']);
  });

  it('onBlur events have the blur type', async () => {
    const log = [];
    const root = ReactDOMClient.createRoot(container);
    await act(() => {
      root.render(
        <button
          onBlur={event => log.push(`onBlur: ${event.type}`)}
          onBlurCapture={event => log.push(`onBlurCapture: ${event.type}`)}
        />,
      );
    });

    const button = container.querySelector('button');

    await act(() => {
      button.dispatchEvent(
        new FocusEvent('focusout', {
          bubbles: true,
          cancelable: false,
        }),
      );
    });

    expect(log).toEqual(['onBlurCapture: blur', 'onBlur: blur']);
  });
});

Frequently Asked Questions

What does SyntheticFocusEvent-test.js do?
SyntheticFocusEvent-test.js is a source file in the react codebase, written in javascript.
Where is SyntheticFocusEvent-test.js in the architecture?
SyntheticFocusEvent-test.js is located at packages/react-dom/src/events/__tests__/SyntheticFocusEvent-test.js (directory: packages/react-dom/src/events/__tests__).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free