mirror of
https://github.com/facebook/react.git
synced 2026-02-23 12:13:04 +00:00
Stacked on https://github.com/facebook/react/pull/31892, see commit on top. For some reason, there were 2 fields different fields for essentially same thing: `selectedElementID` and `inspectedElementID`. Basically, the change is: ``` selectedElementID -> inspectedElementID selectedElementIndex -> inspectedElementIndex ``` I have a theory that it was due to previously used async approach around element inspection, and the whole `InspectedElementView` was wrapped in `Suspense`.
98 lines
2.8 KiB
JavaScript
98 lines
2.8 KiB
JavaScript
'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];
|
|
|
|
return (
|
|
title &&
|
|
title.innerText.includes(titleText) &&
|
|
ownersList &&
|
|
ownersList.innerText.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,
|
|
};
|