devtools-utils.js — react Source File
Architecture documentation for devtools-utils.js, a javascript file in the react codebase.
Entity Profile
Relationship Graph
Source Code
'use strict';
/** @flow */
async function clickButton(page, buttonTestName) {
await page.evaluate(testName => {
const {createTestNameSelector, findAllNodes} = window.REACT_DOM_DEVTOOLS;
const container = document.getElementById('devtools');
const button = findAllNodes(container, [
createTestNameSelector(testName),
])[0];
button.click();
}, buttonTestName);
}
async function getElementCount(page, displayName) {
return await page.evaluate(listItemText => {
const {createTestNameSelector, createTextSelector, findAllNodes} =
window.REACT_DOM_DEVTOOLS;
const container = document.getElementById('devtools');
const rows = findAllNodes(container, [
createTestNameSelector('ComponentTreeListItem'),
createTextSelector(listItemText),
]);
return rows.length;
}, displayName);
}
async function selectElement(
page,
displayName,
waitForOwnersText,
waitForSourceLoaded = false
) {
await page.evaluate(listItemText => {
const {createTestNameSelector, createTextSelector, findAllNodes} =
window.REACT_DOM_DEVTOOLS;
const container = document.getElementById('devtools');
const listItem = findAllNodes(container, [
createTestNameSelector('ComponentTreeListItem'),
createTextSelector(listItemText),
])[0];
listItem.dispatchEvent(
new MouseEvent('mousedown', {bubbles: true, cancelable: true})
);
}, displayName);
if (waitForOwnersText) {
// Wait for selected element's props to load.
await page.waitForFunction(
({titleText, ownersListText}) => {
const {createTestNameSelector, findAllNodes} =
window.REACT_DOM_DEVTOOLS;
const container = document.getElementById('devtools');
const title = findAllNodes(container, [
createTestNameSelector('InspectedElement-Title'),
])[0];
const ownersList = findAllNodes(container, [
createTestNameSelector('InspectedElementView-Owners'),
])[0];
if (!ownersList) {
return false;
}
const owners = findAllNodes(ownersList, [
createTestNameSelector('OwnerView'),
]);
return (
title &&
title.innerText.includes(titleText) &&
owners &&
owners
.map(node => node.innerText)
.join('\n')
.includes(ownersListText)
);
},
{titleText: displayName, ownersListText: waitForOwnersText}
);
}
if (waitForSourceLoaded) {
await page.waitForFunction(() => {
const {createTestNameSelector, findAllNodes} = window.REACT_DOM_DEVTOOLS;
const container = document.getElementById('devtools');
const sourceStringBlock = findAllNodes(container, [
createTestNameSelector('InspectedElementView-FormattedSourceString'),
])[0];
// Wait for a new source line to be fetched
return sourceStringBlock != null && sourceStringBlock.innerText != null;
});
}
}
module.exports = {
clickButton,
getElementCount,
selectElement,
};
Domain
Subdomains
Source
Frequently Asked Questions
What does devtools-utils.js do?
devtools-utils.js is a source file in the react codebase, written in javascript. It belongs to the BabelCompiler domain, Validation subdomain.
What functions are defined in devtools-utils.js?
devtools-utils.js defines 3 function(s): clickButton, getElementCount, selectElement.
Where is devtools-utils.js in the architecture?
devtools-utils.js is located at packages/react-devtools-inline/__tests__/__e2e__/devtools-utils.js (domain: BabelCompiler, subdomain: Validation, directory: packages/react-devtools-inline/__tests__/__e2e__).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free