Home / File/ setupTests.js — react Source File

setupTests.js — react Source File

Architecture documentation for setupTests.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.
 */

'use strict';

const {
  patchConsoleMethods,
  resetAllUnexpectedConsoleCalls,
  assertConsoleLogsCleared,
} = require('internal-test-utils/consoleMock');
const spyOn = jest.spyOn;

// Spying on console methods in production builds can mask errors.
// This is why we added an explicit spyOnDev() helper.
// It's too easy to accidentally use the more familiar spyOn() helper though,
// So we disable it entirely.
// Spying on both dev and prod will require using both spyOnDev() and spyOnProd().
global.spyOn = function () {
  throw new Error(
    'Do not use spyOn(). ' +
      'It can accidentally hide unexpected errors in production builds. ' +
      'Use spyOnDev(), spyOnProd(), or spyOnDevAndProd() instead.'
  );
};

global.spyOnDev = function (...args) {
  if (__DEV__) {
    return spyOn(...args);
  }
};

global.spyOnDevAndProd = spyOn;

global.spyOnProd = function (...args) {
  if (!__DEV__) {
    return spyOn(...args);
  }
};

// Patch the console to assert that all console error/warn/log calls assert.
patchConsoleMethods({includeLog: !!process.env.CI});
beforeEach(resetAllUnexpectedConsoleCalls);
afterEach(assertConsoleLogsCleared);

// TODO: enable this check so we don't forget to reset spyOnX mocks.
// afterEach(() => {
//   if (
//       console[methodName] !== mockMethod &&
//       !jest.isMockFunction(console[methodName])
//   ) {
//     throw new Error(
//       `Test did not tear down console.${methodName} mock properly.`
//     );
//   }
// });

expect.extend({
  ...require('../matchers/reactTestMatchers'),
  ...require('../matchers/toThrow'),
});

Domain

Subdomains

Functions

Frequently Asked Questions

What does setupTests.js do?
setupTests.js is a source file in the react codebase, written in javascript. It belongs to the BabelCompiler domain, Entrypoint subdomain.
What functions are defined in setupTests.js?
setupTests.js defines 1 function(s): global.
Where is setupTests.js in the architecture?
setupTests.js is located at scripts/jest/spec-equivalence-reporter/setupTests.js (domain: BabelCompiler, subdomain: Entrypoint, directory: scripts/jest/spec-equivalence-reporter).

Analyze Your Own Codebase

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

Try Supermodel Free