diff --git a/src/fire-event.ts b/src/fire-event.ts index 5931ca9d..e2f32654 100644 --- a/src/fire-event.ts +++ b/src/fire-event.ts @@ -49,29 +49,43 @@ const textInputEventsIgnoringEditableProp = new Set([ 'onScroll', ]); -export function isEventEnabled( +type EventHandlerState = { + enabled: boolean; + reason?: string; +}; + +function getEventHandlerState( element: ReactTestInstance, eventName: string, nearestTouchResponder?: ReactTestInstance, -) { +): EventHandlerState { if (nearestTouchResponder != null && isHostTextInput(nearestTouchResponder)) { - return ( - isEditableTextInput(nearestTouchResponder) || - textInputEventsIgnoringEditableProp.has(eventName) - ); + if (isEditableTextInput(nearestTouchResponder)) { + return { enabled: true }; + } + + if (textInputEventsIgnoringEditableProp.has(eventName)) { + return { enabled: true }; + } + + return { enabled: false, reason: '"editable" prop' }; } if (eventsAffectedByPointerEventsProp.has(eventName) && !isPointerEventEnabled(element)) { - return false; + return { enabled: false, reason: '"pointerEvents" prop' }; } const touchStart = nearestTouchResponder?.props.onStartShouldSetResponder?.(); const touchMove = nearestTouchResponder?.props.onMoveShouldSetResponder?.(); if (touchStart || touchMove) { - return true; + return { enabled: true }; } - return touchStart === undefined && touchMove === undefined; + if (touchStart === undefined && touchMove === undefined) { + return { enabled: true }; + } + + return { enabled: false, reason: 'not a touch responder' }; } function findEventHandler( @@ -83,13 +97,15 @@ function findEventHandler( const handler = getEventHandler(element, eventName); if (handler) { - if (isEventEnabled(element, eventName, touchResponder)) { + const handlerState = getEventHandlerState(element, eventName, touchResponder); + + if (handlerState.enabled) { return handler; } else { logger.warn( - `FireEvent "${eventName}": event handler is disabled on ${formatElement(element, { + `FireEvent: "${eventName}" event handler is disabled on ${formatElement(element, { minimal: true, - })}`, + })} (${handlerState.reason}).`, ); } } @@ -142,9 +158,9 @@ function fireEvent(element: ReactTestInstance, eventName: EventName, ...data: un const handler = findEventHandler(element, eventName); if (!handler) { logger.warn( - `FireEvent "${eventName}": no event handler found on ${formatElement(element, { + `FireEvent: no enabled event handler for "${eventName}" found on ${formatElement(element, { minimal: true, - })} or its ancestors`, + })} or its ancestors.`, ); return; } diff --git a/src/helpers/format-default.ts b/src/helpers/format-default.ts index 7ee42b5b..72d2f566 100644 --- a/src/helpers/format-default.ts +++ b/src/helpers/format-default.ts @@ -24,9 +24,11 @@ const propsToDisplay = [ 'aria-valuenow', 'aria-valuetext', 'defaultValue', + 'editable', 'importantForAccessibility', 'nativeID', 'placeholder', + 'pointerEvents', 'role', 'testID', 'title', diff --git a/src/helpers/format-element.ts b/src/helpers/format-element.ts index fae33bbe..b9a00da3 100644 --- a/src/helpers/format-element.ts +++ b/src/helpers/format-element.ts @@ -1,7 +1,6 @@ import { ElementType } from 'react'; import { ReactTestInstance } from 'react-test-renderer'; import prettyFormat, { plugins } from 'pretty-format'; -import redent from 'redent'; import { defaultMapProps } from './format-default'; export type FormatElementOptions = { diff --git a/src/user-event/utils/dispatch-event.ts b/src/user-event/utils/dispatch-event.ts index d1202fd5..6249b1bc 100644 --- a/src/user-event/utils/dispatch-event.ts +++ b/src/user-event/utils/dispatch-event.ts @@ -1,6 +1,8 @@ import { ReactTestInstance } from 'react-test-renderer'; import act from '../../act'; import { isElementMounted } from '../../helpers/component-tree'; +import { formatElement } from '../../helpers/format-element'; +import { logger } from '../../helpers/logger'; /** * Basic dispatch event function used by User Event module. @@ -16,6 +18,11 @@ export function dispatchEvent(element: ReactTestInstance, eventName: string, ... const handler = getEventHandler(element, eventName); if (!handler) { + logger.debug( + `User Event: no event handler for "${eventName}" found on ${formatElement(element, { + minimal: true, + })}`, + ); return; }