@testing-library/react-native 14.0.0-beta.0 → 14.0.0-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (191) hide show
  1. package/README.md +22 -33
  2. package/build/event-builder/base.js.map +1 -0
  3. package/build/event-builder/common.d.ts +152 -0
  4. package/build/event-builder/common.js +80 -0
  5. package/build/event-builder/common.js.map +1 -0
  6. package/build/event-builder/index.d.ts +3 -0
  7. package/build/event-builder/index.js +39 -0
  8. package/build/event-builder/index.js.map +1 -0
  9. package/build/event-builder/scroll.d.ts +56 -0
  10. package/build/event-builder/scroll.js +51 -0
  11. package/build/event-builder/scroll.js.map +1 -0
  12. package/build/event-builder/text.d.ts +162 -0
  13. package/build/event-builder/text.js +113 -0
  14. package/build/event-builder/text.js.map +1 -0
  15. package/build/fire-event.d.ts +6 -5
  16. package/build/fire-event.js +47 -23
  17. package/build/fire-event.js.map +1 -1
  18. package/build/helpers/accessibility.d.ts +18 -15
  19. package/build/helpers/accessibility.js +64 -47
  20. package/build/helpers/accessibility.js.map +1 -1
  21. package/build/helpers/component-tree.d.ts +9 -9
  22. package/build/helpers/component-tree.js +17 -17
  23. package/build/helpers/component-tree.js.map +1 -1
  24. package/build/helpers/find-all.d.ts +2 -2
  25. package/build/helpers/find-all.js +1 -1
  26. package/build/helpers/find-all.js.map +1 -1
  27. package/build/helpers/format-element.d.ts +5 -5
  28. package/build/helpers/format-element.js +9 -9
  29. package/build/helpers/format-element.js.map +1 -1
  30. package/build/helpers/host-component-names.d.ts +13 -13
  31. package/build/helpers/host-component-names.js +18 -18
  32. package/build/helpers/host-component-names.js.map +1 -1
  33. package/build/helpers/matchers/match-accessibility-state.d.ts +2 -2
  34. package/build/helpers/matchers/match-accessibility-state.js +6 -6
  35. package/build/helpers/matchers/match-accessibility-state.js.map +1 -1
  36. package/build/helpers/matchers/match-accessibility-value.d.ts +2 -2
  37. package/build/helpers/matchers/match-accessibility-value.js +2 -2
  38. package/build/helpers/matchers/match-accessibility-value.js.map +1 -1
  39. package/build/helpers/matchers/match-label-text.d.ts +2 -2
  40. package/build/helpers/matchers/match-label-text.js +2 -2
  41. package/build/helpers/matchers/match-label-text.js.map +1 -1
  42. package/build/helpers/matchers/match-text-content.d.ts +5 -5
  43. package/build/helpers/matchers/match-text-content.js +5 -5
  44. package/build/helpers/matchers/match-text-content.js.map +1 -1
  45. package/build/helpers/pointer-events.d.ts +2 -2
  46. package/build/helpers/pointer-events.js +4 -4
  47. package/build/helpers/pointer-events.js.map +1 -1
  48. package/build/helpers/text-content.d.ts +2 -2
  49. package/build/helpers/text-content.js +5 -5
  50. package/build/helpers/text-content.js.map +1 -1
  51. package/build/helpers/text-input.d.ts +3 -3
  52. package/build/helpers/text-input.js +6 -6
  53. package/build/helpers/text-input.js.map +1 -1
  54. package/build/matchers/to-be-busy.d.ts +2 -2
  55. package/build/matchers/to-be-busy.js +5 -5
  56. package/build/matchers/to-be-busy.js.map +1 -1
  57. package/build/matchers/to-be-checked.d.ts +2 -2
  58. package/build/matchers/to-be-checked.js +9 -9
  59. package/build/matchers/to-be-checked.js.map +1 -1
  60. package/build/matchers/to-be-disabled.d.ts +3 -3
  61. package/build/matchers/to-be-disabled.js +10 -10
  62. package/build/matchers/to-be-disabled.js.map +1 -1
  63. package/build/matchers/to-be-empty-element.d.ts +2 -2
  64. package/build/matchers/to-be-empty-element.js +4 -4
  65. package/build/matchers/to-be-empty-element.js.map +1 -1
  66. package/build/matchers/to-be-expanded.d.ts +3 -3
  67. package/build/matchers/to-be-expanded.js +10 -10
  68. package/build/matchers/to-be-expanded.js.map +1 -1
  69. package/build/matchers/to-be-on-the-screen.d.ts +2 -2
  70. package/build/matchers/to-be-on-the-screen.js +7 -7
  71. package/build/matchers/to-be-on-the-screen.js.map +1 -1
  72. package/build/matchers/to-be-partially-checked.d.ts +2 -2
  73. package/build/matchers/to-be-partially-checked.js +8 -8
  74. package/build/matchers/to-be-partially-checked.js.map +1 -1
  75. package/build/matchers/to-be-selected.d.ts +2 -2
  76. package/build/matchers/to-be-selected.js +4 -4
  77. package/build/matchers/to-be-selected.js.map +1 -1
  78. package/build/matchers/to-be-visible.d.ts +2 -2
  79. package/build/matchers/to-be-visible.js +12 -12
  80. package/build/matchers/to-be-visible.js.map +1 -1
  81. package/build/matchers/to-contain-element.d.ts +2 -2
  82. package/build/matchers/to-contain-element.js +6 -6
  83. package/build/matchers/to-contain-element.js.map +1 -1
  84. package/build/matchers/to-have-accessibility-value.d.ts +2 -2
  85. package/build/matchers/to-have-accessibility-value.js +6 -6
  86. package/build/matchers/to-have-accessibility-value.js.map +1 -1
  87. package/build/matchers/to-have-accessible-name.d.ts +2 -2
  88. package/build/matchers/to-have-accessible-name.js +5 -10
  89. package/build/matchers/to-have-accessible-name.js.map +1 -1
  90. package/build/matchers/to-have-display-value.d.ts +2 -2
  91. package/build/matchers/to-have-display-value.js +6 -6
  92. package/build/matchers/to-have-display-value.js.map +1 -1
  93. package/build/matchers/to-have-prop.d.ts +2 -2
  94. package/build/matchers/to-have-prop.js +6 -6
  95. package/build/matchers/to-have-prop.js.map +1 -1
  96. package/build/matchers/to-have-style.d.ts +2 -2
  97. package/build/matchers/to-have-style.js +5 -5
  98. package/build/matchers/to-have-style.js.map +1 -1
  99. package/build/matchers/to-have-text-content.d.ts +2 -2
  100. package/build/matchers/to-have-text-content.js +4 -4
  101. package/build/matchers/to-have-text-content.js.map +1 -1
  102. package/build/matchers/types.d.ts +20 -20
  103. package/build/matchers/types.js.map +1 -1
  104. package/build/matchers/utils.d.ts +4 -4
  105. package/build/matchers/utils.js +6 -6
  106. package/build/matchers/utils.js.map +1 -1
  107. package/build/native-state.d.ts +3 -3
  108. package/build/native-state.js +2 -2
  109. package/build/native-state.js.map +1 -1
  110. package/build/queries/display-value.d.ts +2 -2
  111. package/build/queries/display-value.js +12 -12
  112. package/build/queries/display-value.js.map +1 -1
  113. package/build/queries/hint-text.d.ts +2 -2
  114. package/build/queries/hint-text.js +11 -11
  115. package/build/queries/hint-text.js.map +1 -1
  116. package/build/queries/label-text.d.ts +2 -2
  117. package/build/queries/label-text.js +9 -9
  118. package/build/queries/label-text.js.map +1 -1
  119. package/build/queries/make-queries.d.ts +8 -8
  120. package/build/queries/make-queries.js +11 -11
  121. package/build/queries/make-queries.js.map +1 -1
  122. package/build/queries/placeholder-text.d.ts +2 -2
  123. package/build/queries/placeholder-text.js +11 -11
  124. package/build/queries/placeholder-text.js.map +1 -1
  125. package/build/queries/role.d.ts +2 -2
  126. package/build/queries/role.js +17 -27
  127. package/build/queries/role.js.map +1 -1
  128. package/build/queries/test-id.d.ts +2 -2
  129. package/build/queries/test-id.js +11 -11
  130. package/build/queries/test-id.js.map +1 -1
  131. package/build/queries/text.d.ts +2 -2
  132. package/build/queries/text.js +9 -9
  133. package/build/queries/text.js.map +1 -1
  134. package/build/render.d.ts +3 -4
  135. package/build/render.js +17 -3
  136. package/build/render.js.map +1 -1
  137. package/build/screen.js.map +1 -1
  138. package/build/test-utils/react-version-gates.d.ts +1 -0
  139. package/build/test-utils/react-version-gates.js +28 -0
  140. package/build/test-utils/react-version-gates.js.map +1 -0
  141. package/build/types.d.ts +7 -0
  142. package/build/types.js.map +1 -1
  143. package/build/user-event/clear.d.ts +2 -2
  144. package/build/user-event/clear.js +13 -13
  145. package/build/user-event/clear.js.map +1 -1
  146. package/build/user-event/index.d.ts +7 -7
  147. package/build/user-event/index.js +6 -6
  148. package/build/user-event/index.js.map +1 -1
  149. package/build/user-event/paste.d.ts +2 -2
  150. package/build/user-event/paste.js +18 -18
  151. package/build/user-event/paste.js.map +1 -1
  152. package/build/user-event/press/press.d.ts +3 -3
  153. package/build/user-event/press/press.js +35 -35
  154. package/build/user-event/press/press.js.map +1 -1
  155. package/build/user-event/scroll/scroll-to.d.ts +2 -2
  156. package/build/user-event/scroll/scroll-to.js +20 -20
  157. package/build/user-event/scroll/scroll-to.js.map +1 -1
  158. package/build/user-event/setup/setup.d.ts +11 -11
  159. package/build/user-event/setup/setup.js.map +1 -1
  160. package/build/user-event/type/type.d.ts +3 -3
  161. package/build/user-event/type/type.js +27 -28
  162. package/build/user-event/type/type.js.map +1 -1
  163. package/build/user-event/utils/dispatch-event.d.ts +3 -3
  164. package/build/user-event/utils/dispatch-event.js +4 -4
  165. package/build/user-event/utils/dispatch-event.js.map +1 -1
  166. package/build/user-event/utils/index.d.ts +0 -1
  167. package/build/user-event/utils/index.js +0 -11
  168. package/build/user-event/utils/index.js.map +1 -1
  169. package/build/within.d.ts +3 -3
  170. package/build/within.js +10 -10
  171. package/build/within.js.map +1 -1
  172. package/package.json +37 -27
  173. package/build/tsconfig.release.tsbuildinfo +0 -1
  174. package/build/user-event/event-builder/base.js.map +0 -1
  175. package/build/user-event/event-builder/common.d.ts +0 -155
  176. package/build/user-event/event-builder/common.js +0 -77
  177. package/build/user-event/event-builder/common.js.map +0 -1
  178. package/build/user-event/event-builder/index.d.ts +0 -318
  179. package/build/user-event/event-builder/index.js +0 -15
  180. package/build/user-event/event-builder/index.js.map +0 -1
  181. package/build/user-event/event-builder/scroll-view.d.ts +0 -58
  182. package/build/user-event/event-builder/scroll-view.js +0 -53
  183. package/build/user-event/event-builder/scroll-view.js.map +0 -1
  184. package/build/user-event/event-builder/text-input.d.ts +0 -165
  185. package/build/user-event/event-builder/text-input.js +0 -105
  186. package/build/user-event/event-builder/text-input.js.map +0 -1
  187. package/build/user-event/utils/text-range.d.ts +0 -4
  188. package/build/user-event/utils/text-range.js +0 -6
  189. package/build/user-event/utils/text-range.js.map +0 -1
  190. /package/build/{user-event/event-builder → event-builder}/base.d.ts +0 -0
  191. /package/build/{user-event/event-builder → event-builder}/base.js +0 -0
@@ -5,64 +5,63 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.emitTypingEvents = emitTypingEvents;
7
7
  exports.type = type;
8
+ var _eventBuilder = require("../../event-builder");
8
9
  var _errors = require("../../helpers/errors");
9
10
  var _hostComponentNames = require("../../helpers/host-component-names");
10
11
  var _pointerEvents = require("../../helpers/pointer-events");
11
12
  var _textInput = require("../../helpers/text-input");
12
13
  var _nativeState = require("../../native-state");
13
- var _eventBuilder = require("../event-builder");
14
14
  var _utils = require("../utils");
15
15
  var _parseKeys = require("./parse-keys");
16
- async function type(element, text, options) {
17
- if (!(0, _hostComponentNames.isHostTextInput)(element)) {
18
- throw new _errors.ErrorWithStack(`type() works only with host "TextInput" elements. Passed element has type "${element.type}".`, type);
16
+ async function type(instance, text, options) {
17
+ if (!(0, _hostComponentNames.isHostTextInput)(instance)) {
18
+ throw new _errors.ErrorWithStack(`type() works only with host "TextInput" instances. Passed instance has type "${instance.type}".`, type);
19
19
  }
20
20
 
21
- // Skip events if the element is disabled
22
- if (!(0, _textInput.isEditableTextInput)(element) || !(0, _pointerEvents.isPointerEventEnabled)(element)) {
21
+ // Skip events if the instance is disabled
22
+ if (!(0, _textInput.isEditableTextInput)(instance) || !(0, _pointerEvents.isPointerEventEnabled)(instance)) {
23
23
  return;
24
24
  }
25
25
  const keys = (0, _parseKeys.parseKeys)(text);
26
26
  if (!options?.skipPress) {
27
- await (0, _utils.dispatchEvent)(element, 'pressIn', _eventBuilder.EventBuilder.Common.touch());
27
+ await (0, _utils.dispatchEvent)(instance, 'pressIn', (0, _eventBuilder.buildTouchEvent)());
28
28
  }
29
- await (0, _utils.dispatchEvent)(element, 'focus', _eventBuilder.EventBuilder.Common.focus());
29
+ await (0, _utils.dispatchEvent)(instance, 'focus', (0, _eventBuilder.buildFocusEvent)());
30
30
  if (!options?.skipPress) {
31
31
  await (0, _utils.wait)(this.config);
32
- await (0, _utils.dispatchEvent)(element, 'pressOut', _eventBuilder.EventBuilder.Common.touch());
32
+ await (0, _utils.dispatchEvent)(instance, 'pressOut', (0, _eventBuilder.buildTouchEvent)());
33
33
  }
34
- let currentText = (0, _textInput.getTextInputValue)(element);
35
34
  for (const key of keys) {
36
- const previousText = (0, _textInput.getTextInputValue)(element);
35
+ const previousText = (0, _textInput.getTextInputValue)(instance);
37
36
  const proposedText = applyKey(previousText, key);
38
- const isAccepted = isTextChangeAccepted(element, proposedText);
39
- currentText = isAccepted ? proposedText : previousText;
40
- await emitTypingEvents(element, {
37
+ const isAccepted = isTextChangeAccepted(instance, proposedText);
38
+ const currentText = isAccepted ? proposedText : previousText;
39
+ await emitTypingEvents(instance, {
41
40
  config: this.config,
42
41
  key,
43
42
  text: currentText,
44
43
  isAccepted
45
44
  });
46
45
  }
47
- const finalText = (0, _textInput.getTextInputValue)(element);
46
+ const finalText = (0, _textInput.getTextInputValue)(instance);
48
47
  await (0, _utils.wait)(this.config);
49
48
  if (options?.submitEditing) {
50
- await (0, _utils.dispatchEvent)(element, 'submitEditing', _eventBuilder.EventBuilder.TextInput.submitEditing(finalText));
49
+ await (0, _utils.dispatchEvent)(instance, 'submitEditing', (0, _eventBuilder.buildSubmitEditingEvent)(finalText));
51
50
  }
52
51
  if (!options?.skipBlur) {
53
- await (0, _utils.dispatchEvent)(element, 'endEditing', _eventBuilder.EventBuilder.TextInput.endEditing(finalText));
54
- await (0, _utils.dispatchEvent)(element, 'blur', _eventBuilder.EventBuilder.Common.blur());
52
+ await (0, _utils.dispatchEvent)(instance, 'endEditing', (0, _eventBuilder.buildEndEditingEvent)(finalText));
53
+ await (0, _utils.dispatchEvent)(instance, 'blur', (0, _eventBuilder.buildBlurEvent)());
55
54
  }
56
55
  }
57
- async function emitTypingEvents(element, {
56
+ async function emitTypingEvents(instance, {
58
57
  config,
59
58
  key,
60
59
  text,
61
60
  isAccepted
62
61
  }) {
63
- const isMultiline = element.props.multiline === true;
62
+ const isMultiline = instance.props.multiline === true;
64
63
  await (0, _utils.wait)(config);
65
- await (0, _utils.dispatchEvent)(element, 'keyPress', _eventBuilder.EventBuilder.TextInput.keyPress(key));
64
+ await (0, _utils.dispatchEvent)(instance, 'keyPress', (0, _eventBuilder.buildKeyPressEvent)(key));
66
65
 
67
66
  // Platform difference (based on experiments):
68
67
  // - iOS and RN Web: TextInput emits only `keyPress` event when max length has been reached
@@ -70,20 +69,20 @@ async function emitTypingEvents(element, {
70
69
  if (isAccepted === false) {
71
70
  return;
72
71
  }
73
- _nativeState.nativeState.valueForElement.set(element, text);
74
- await (0, _utils.dispatchEvent)(element, 'change', _eventBuilder.EventBuilder.TextInput.change(text));
75
- await (0, _utils.dispatchEvent)(element, 'changeText', text);
72
+ _nativeState.nativeState.valueForInstance.set(instance, text);
73
+ await (0, _utils.dispatchEvent)(instance, 'change', (0, _eventBuilder.buildTextChangeEvent)(text));
74
+ await (0, _utils.dispatchEvent)(instance, 'changeText', text);
76
75
  const selectionRange = {
77
76
  start: text.length,
78
77
  end: text.length
79
78
  };
80
- await (0, _utils.dispatchEvent)(element, 'selectionChange', _eventBuilder.EventBuilder.TextInput.selectionChange(selectionRange));
79
+ await (0, _utils.dispatchEvent)(instance, 'selectionChange', (0, _eventBuilder.buildTextSelectionChangeEvent)(selectionRange));
81
80
 
82
81
  // According to the docs only multiline TextInput emits contentSizeChange event
83
82
  // @see: https://reactnative.dev/docs/textinput#oncontentsizechange
84
83
  if (isMultiline) {
85
84
  const contentSize = (0, _utils.getTextContentSize)(text);
86
- await (0, _utils.dispatchEvent)(element, 'contentSizeChange', _eventBuilder.EventBuilder.TextInput.contentSizeChange(contentSize));
85
+ await (0, _utils.dispatchEvent)(instance, 'contentSizeChange', (0, _eventBuilder.buildContentSizeChangeEvent)(contentSize));
87
86
  }
88
87
  }
89
88
  function applyKey(text, key) {
@@ -95,8 +94,8 @@ function applyKey(text, key) {
95
94
  }
96
95
  return text + key;
97
96
  }
98
- function isTextChangeAccepted(element, text) {
99
- const maxLength = element.props.maxLength;
97
+ function isTextChangeAccepted(instance, text) {
98
+ const maxLength = instance.props.maxLength;
100
99
  return maxLength === undefined || text.length <= maxLength;
101
100
  }
102
101
  //# sourceMappingURL=type.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"type.js","names":["_errors","require","_hostComponentNames","_pointerEvents","_textInput","_nativeState","_eventBuilder","_utils","_parseKeys","type","element","text","options","isHostTextInput","ErrorWithStack","isEditableTextInput","isPointerEventEnabled","keys","parseKeys","skipPress","dispatchEvent","EventBuilder","Common","touch","focus","wait","config","currentText","getTextInputValue","key","previousText","proposedText","applyKey","isAccepted","isTextChangeAccepted","emitTypingEvents","finalText","submitEditing","TextInput","skipBlur","endEditing","blur","isMultiline","props","multiline","keyPress","nativeState","valueForElement","set","change","selectionRange","start","length","end","selectionChange","contentSize","getTextContentSize","contentSizeChange","slice","maxLength","undefined"],"sources":["../../../src/user-event/type/type.ts"],"sourcesContent":["import type { HostElement } from 'test-renderer';\n\nimport { ErrorWithStack } from '../../helpers/errors';\nimport { isHostTextInput } from '../../helpers/host-component-names';\nimport { isPointerEventEnabled } from '../../helpers/pointer-events';\nimport { getTextInputValue, isEditableTextInput } from '../../helpers/text-input';\nimport { nativeState } from '../../native-state';\nimport { EventBuilder } from '../event-builder';\nimport type { UserEventConfig, UserEventInstance } from '../setup';\nimport { dispatchEvent, getTextContentSize, wait } from '../utils';\nimport { parseKeys } from './parse-keys';\n\nexport interface TypeOptions {\n skipPress?: boolean;\n submitEditing?: boolean;\n skipBlur?: boolean;\n}\n\nexport async function type(\n this: UserEventInstance,\n element: HostElement,\n text: string,\n options?: TypeOptions,\n): Promise<void> {\n if (!isHostTextInput(element)) {\n throw new ErrorWithStack(\n `type() works only with host \"TextInput\" elements. Passed element has type \"${element.type}\".`,\n type,\n );\n }\n\n // Skip events if the element is disabled\n if (!isEditableTextInput(element) || !isPointerEventEnabled(element)) {\n return;\n }\n\n const keys = parseKeys(text);\n\n if (!options?.skipPress) {\n await dispatchEvent(element, 'pressIn', EventBuilder.Common.touch());\n }\n\n await dispatchEvent(element, 'focus', EventBuilder.Common.focus());\n\n if (!options?.skipPress) {\n await wait(this.config);\n await dispatchEvent(element, 'pressOut', EventBuilder.Common.touch());\n }\n\n let currentText = getTextInputValue(element);\n for (const key of keys) {\n const previousText = getTextInputValue(element);\n const proposedText = applyKey(previousText, key);\n const isAccepted = isTextChangeAccepted(element, proposedText);\n currentText = isAccepted ? proposedText : previousText;\n\n await emitTypingEvents(element, {\n config: this.config,\n key,\n text: currentText,\n isAccepted,\n });\n }\n\n const finalText = getTextInputValue(element);\n await wait(this.config);\n\n if (options?.submitEditing) {\n await dispatchEvent(element, 'submitEditing', EventBuilder.TextInput.submitEditing(finalText));\n }\n\n if (!options?.skipBlur) {\n await dispatchEvent(element, 'endEditing', EventBuilder.TextInput.endEditing(finalText));\n await dispatchEvent(element, 'blur', EventBuilder.Common.blur());\n }\n}\n\ntype EmitTypingEventsContext = {\n config: UserEventConfig;\n key: string;\n text: string;\n isAccepted?: boolean;\n};\n\nexport async function emitTypingEvents(\n element: HostElement,\n { config, key, text, isAccepted }: EmitTypingEventsContext,\n) {\n const isMultiline = element.props.multiline === true;\n\n await wait(config);\n await dispatchEvent(element, 'keyPress', EventBuilder.TextInput.keyPress(key));\n\n // Platform difference (based on experiments):\n // - iOS and RN Web: TextInput emits only `keyPress` event when max length has been reached\n // - Android: TextInputs does not emit any events\n if (isAccepted === false) {\n return;\n }\n\n nativeState.valueForElement.set(element, text);\n await dispatchEvent(element, 'change', EventBuilder.TextInput.change(text));\n await dispatchEvent(element, 'changeText', text);\n\n const selectionRange = {\n start: text.length,\n end: text.length,\n };\n await dispatchEvent(\n element,\n 'selectionChange',\n EventBuilder.TextInput.selectionChange(selectionRange),\n );\n\n // According to the docs only multiline TextInput emits contentSizeChange event\n // @see: https://reactnative.dev/docs/textinput#oncontentsizechange\n if (isMultiline) {\n const contentSize = getTextContentSize(text);\n await dispatchEvent(\n element,\n 'contentSizeChange',\n EventBuilder.TextInput.contentSizeChange(contentSize),\n );\n }\n}\n\nfunction applyKey(text: string, key: string) {\n if (key === 'Enter') {\n return `${text}\\n`;\n }\n\n if (key === 'Backspace') {\n return text.slice(0, -1);\n }\n\n return text + key;\n}\n\nfunction isTextChangeAccepted(element: HostElement, text: string) {\n const maxLength = element.props.maxLength;\n return maxLength === undefined || text.length <= maxLength;\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"type.js","names":["_eventBuilder","require","_errors","_hostComponentNames","_pointerEvents","_textInput","_nativeState","_utils","_parseKeys","type","instance","text","options","isHostTextInput","ErrorWithStack","isEditableTextInput","isPointerEventEnabled","keys","parseKeys","skipPress","dispatchEvent","buildTouchEvent","buildFocusEvent","wait","config","key","previousText","getTextInputValue","proposedText","applyKey","isAccepted","isTextChangeAccepted","currentText","emitTypingEvents","finalText","submitEditing","buildSubmitEditingEvent","skipBlur","buildEndEditingEvent","buildBlurEvent","isMultiline","props","multiline","buildKeyPressEvent","nativeState","valueForInstance","set","buildTextChangeEvent","selectionRange","start","length","end","buildTextSelectionChangeEvent","contentSize","getTextContentSize","buildContentSizeChangeEvent","slice","maxLength","undefined"],"sources":["../../../src/user-event/type/type.ts"],"sourcesContent":["import type { TestInstance } from 'test-renderer';\n\nimport {\n buildBlurEvent,\n buildContentSizeChangeEvent,\n buildEndEditingEvent,\n buildFocusEvent,\n buildKeyPressEvent,\n buildSubmitEditingEvent,\n buildTextChangeEvent,\n buildTextSelectionChangeEvent,\n buildTouchEvent,\n} from '../../event-builder';\nimport { ErrorWithStack } from '../../helpers/errors';\nimport { isHostTextInput } from '../../helpers/host-component-names';\nimport { isPointerEventEnabled } from '../../helpers/pointer-events';\nimport { getTextInputValue, isEditableTextInput } from '../../helpers/text-input';\nimport { nativeState } from '../../native-state';\nimport type { UserEventConfig, UserEventInstance } from '../setup';\nimport { dispatchEvent, getTextContentSize, wait } from '../utils';\nimport { parseKeys } from './parse-keys';\n\nexport interface TypeOptions {\n skipPress?: boolean;\n submitEditing?: boolean;\n skipBlur?: boolean;\n}\n\nexport async function type(\n this: UserEventInstance,\n instance: TestInstance,\n text: string,\n options?: TypeOptions,\n): Promise<void> {\n if (!isHostTextInput(instance)) {\n throw new ErrorWithStack(\n `type() works only with host \"TextInput\" instances. Passed instance has type \"${instance.type}\".`,\n type,\n );\n }\n\n // Skip events if the instance is disabled\n if (!isEditableTextInput(instance) || !isPointerEventEnabled(instance)) {\n return;\n }\n\n const keys = parseKeys(text);\n\n if (!options?.skipPress) {\n await dispatchEvent(instance, 'pressIn', buildTouchEvent());\n }\n\n await dispatchEvent(instance, 'focus', buildFocusEvent());\n\n if (!options?.skipPress) {\n await wait(this.config);\n await dispatchEvent(instance, 'pressOut', buildTouchEvent());\n }\n\n for (const key of keys) {\n const previousText = getTextInputValue(instance);\n const proposedText = applyKey(previousText, key);\n const isAccepted = isTextChangeAccepted(instance, proposedText);\n const currentText = isAccepted ? proposedText : previousText;\n\n await emitTypingEvents(instance, {\n config: this.config,\n key,\n text: currentText,\n isAccepted,\n });\n }\n\n const finalText = getTextInputValue(instance);\n await wait(this.config);\n\n if (options?.submitEditing) {\n await dispatchEvent(instance, 'submitEditing', buildSubmitEditingEvent(finalText));\n }\n\n if (!options?.skipBlur) {\n await dispatchEvent(instance, 'endEditing', buildEndEditingEvent(finalText));\n await dispatchEvent(instance, 'blur', buildBlurEvent());\n }\n}\n\ntype EmitTypingEventsContext = {\n config: UserEventConfig;\n key: string;\n text: string;\n isAccepted?: boolean;\n};\n\nexport async function emitTypingEvents(\n instance: TestInstance,\n { config, key, text, isAccepted }: EmitTypingEventsContext,\n) {\n const isMultiline = instance.props.multiline === true;\n\n await wait(config);\n await dispatchEvent(instance, 'keyPress', buildKeyPressEvent(key));\n\n // Platform difference (based on experiments):\n // - iOS and RN Web: TextInput emits only `keyPress` event when max length has been reached\n // - Android: TextInputs does not emit any events\n if (isAccepted === false) {\n return;\n }\n\n nativeState.valueForInstance.set(instance, text);\n await dispatchEvent(instance, 'change', buildTextChangeEvent(text));\n await dispatchEvent(instance, 'changeText', text);\n\n const selectionRange = {\n start: text.length,\n end: text.length,\n };\n await dispatchEvent(instance, 'selectionChange', buildTextSelectionChangeEvent(selectionRange));\n\n // According to the docs only multiline TextInput emits contentSizeChange event\n // @see: https://reactnative.dev/docs/textinput#oncontentsizechange\n if (isMultiline) {\n const contentSize = getTextContentSize(text);\n await dispatchEvent(instance, 'contentSizeChange', buildContentSizeChangeEvent(contentSize));\n }\n}\n\nfunction applyKey(text: string, key: string) {\n if (key === 'Enter') {\n return `${text}\\n`;\n }\n\n if (key === 'Backspace') {\n return text.slice(0, -1);\n }\n\n return text + key;\n}\n\nfunction isTextChangeAccepted(instance: TestInstance, text: string) {\n const maxLength = instance.props.maxLength;\n return maxLength === undefined || text.length <= maxLength;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,9 +1,9 @@
1
- import type { HostElement } from 'test-renderer';
1
+ import type { TestInstance } from 'test-renderer';
2
2
  /**
3
3
  * Basic dispatch event function used by User Event module.
4
4
  *
5
- * @param element element trigger event on
5
+ * @param instance instance to trigger event on
6
6
  * @param eventName name of the event
7
7
  * @param event event payload(s)
8
8
  */
9
- export declare function dispatchEvent(element: HostElement, eventName: string, ...event: unknown[]): Promise<void>;
9
+ export declare function dispatchEvent(instance: TestInstance, eventName: string, ...event: unknown[]): Promise<void>;
@@ -10,15 +10,15 @@ var _componentTree = require("../../helpers/component-tree");
10
10
  /**
11
11
  * Basic dispatch event function used by User Event module.
12
12
  *
13
- * @param element element trigger event on
13
+ * @param instance instance to trigger event on
14
14
  * @param eventName name of the event
15
15
  * @param event event payload(s)
16
16
  */
17
- async function dispatchEvent(element, eventName, ...event) {
18
- if (!(0, _componentTree.isElementMounted)(element)) {
17
+ async function dispatchEvent(instance, eventName, ...event) {
18
+ if (!(0, _componentTree.isInstanceMounted)(instance)) {
19
19
  return;
20
20
  }
21
- const handler = (0, _eventHandler.getEventHandlerFromProps)(element.props, eventName);
21
+ const handler = (0, _eventHandler.getEventHandlerFromProps)(instance.props, eventName);
22
22
  if (!handler) {
23
23
  return;
24
24
  }
@@ -1 +1 @@
1
- {"version":3,"file":"dispatch-event.js","names":["_act","require","_eventHandler","_componentTree","dispatchEvent","element","eventName","event","isElementMounted","handler","getEventHandlerFromProps","props","act"],"sources":["../../../src/user-event/utils/dispatch-event.ts"],"sourcesContent":["import type { HostElement } from 'test-renderer';\n\nimport { act } from '../../act';\nimport { getEventHandlerFromProps } from '../../event-handler';\nimport { isElementMounted } from '../../helpers/component-tree';\n\n/**\n * Basic dispatch event function used by User Event module.\n *\n * @param element element trigger event on\n * @param eventName name of the event\n * @param event event payload(s)\n */\nexport async function dispatchEvent(element: HostElement, eventName: string, ...event: unknown[]) {\n if (!isElementMounted(element)) {\n return;\n }\n\n const handler = getEventHandlerFromProps(element.props, eventName);\n if (!handler) {\n return;\n }\n\n await act(() => {\n handler(...event);\n });\n}\n"],"mappings":";;;;;;AAEA,IAAAA,IAAA,GAAAC,OAAA;AACA,IAAAC,aAAA,GAAAD,OAAA;AACA,IAAAE,cAAA,GAAAF,OAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,eAAeG,aAAaA,CAACC,OAAoB,EAAEC,SAAiB,EAAE,GAAGC,KAAgB,EAAE;EAChG,IAAI,CAAC,IAAAC,+BAAgB,EAACH,OAAO,CAAC,EAAE;IAC9B;EACF;EAEA,MAAMI,OAAO,GAAG,IAAAC,sCAAwB,EAACL,OAAO,CAACM,KAAK,EAAEL,SAAS,CAAC;EAClE,IAAI,CAACG,OAAO,EAAE;IACZ;EACF;EAEA,MAAM,IAAAG,QAAG,EAAC,MAAM;IACdH,OAAO,CAAC,GAAGF,KAAK,CAAC;EACnB,CAAC,CAAC;AACJ","ignoreList":[]}
1
+ {"version":3,"file":"dispatch-event.js","names":["_act","require","_eventHandler","_componentTree","dispatchEvent","instance","eventName","event","isInstanceMounted","handler","getEventHandlerFromProps","props","act"],"sources":["../../../src/user-event/utils/dispatch-event.ts"],"sourcesContent":["import type { TestInstance } from 'test-renderer';\n\nimport { act } from '../../act';\nimport { getEventHandlerFromProps } from '../../event-handler';\nimport { isInstanceMounted } from '../../helpers/component-tree';\n\n/**\n * Basic dispatch event function used by User Event module.\n *\n * @param instance instance to trigger event on\n * @param eventName name of the event\n * @param event event payload(s)\n */\nexport async function dispatchEvent(\n instance: TestInstance,\n eventName: string,\n ...event: unknown[]\n) {\n if (!isInstanceMounted(instance)) {\n return;\n }\n\n const handler = getEventHandlerFromProps(instance.props, eventName);\n if (!handler) {\n return;\n }\n\n await act(() => {\n handler(...event);\n });\n}\n"],"mappings":";;;;;;AAEA,IAAAA,IAAA,GAAAC,OAAA;AACA,IAAAC,aAAA,GAAAD,OAAA;AACA,IAAAE,cAAA,GAAAF,OAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,eAAeG,aAAaA,CACjCC,QAAsB,EACtBC,SAAiB,EACjB,GAAGC,KAAgB,EACnB;EACA,IAAI,CAAC,IAAAC,gCAAiB,EAACH,QAAQ,CAAC,EAAE;IAChC;EACF;EAEA,MAAMI,OAAO,GAAG,IAAAC,sCAAwB,EAACL,QAAQ,CAACM,KAAK,EAAEL,SAAS,CAAC;EACnE,IAAI,CAACG,OAAO,EAAE;IACZ;EACF;EAEA,MAAM,IAAAG,QAAG,EAAC,MAAM;IACdH,OAAO,CAAC,GAAGF,KAAK,CAAC;EACnB,CAAC,CAAC;AACJ","ignoreList":[]}
@@ -1,4 +1,3 @@
1
1
  export * from './content-size';
2
2
  export * from './dispatch-event';
3
- export * from './text-range';
4
3
  export * from './wait';
@@ -25,17 +25,6 @@ Object.keys(_dispatchEvent).forEach(function (key) {
25
25
  }
26
26
  });
27
27
  });
28
- var _textRange = require("./text-range");
29
- Object.keys(_textRange).forEach(function (key) {
30
- if (key === "default" || key === "__esModule") return;
31
- if (key in exports && exports[key] === _textRange[key]) return;
32
- Object.defineProperty(exports, key, {
33
- enumerable: true,
34
- get: function () {
35
- return _textRange[key];
36
- }
37
- });
38
- });
39
28
  var _wait = require("./wait");
40
29
  Object.keys(_wait).forEach(function (key) {
41
30
  if (key === "default" || key === "__esModule") return;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["_contentSize","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get","_dispatchEvent","_textRange","_wait"],"sources":["../../../src/user-event/utils/index.ts"],"sourcesContent":["export * from './content-size';\nexport * from './dispatch-event';\nexport * from './text-range';\nexport * from './wait';\n"],"mappings":";;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,YAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,YAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,YAAA,CAAAK,GAAA;IAAA;EAAA;AAAA;AACA,IAAAK,cAAA,GAAAT,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAO,cAAA,EAAAN,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAK,cAAA,CAAAL,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAC,cAAA,CAAAL,GAAA;IAAA;EAAA;AAAA;AACA,IAAAM,UAAA,GAAAV,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAQ,UAAA,EAAAP,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAM,UAAA,CAAAN,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAE,UAAA,CAAAN,GAAA;IAAA;EAAA;AAAA;AACA,IAAAO,KAAA,GAAAX,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAS,KAAA,EAAAR,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAO,KAAA,CAAAP,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAG,KAAA,CAAAP,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["_contentSize","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get","_dispatchEvent","_wait"],"sources":["../../../src/user-event/utils/index.ts"],"sourcesContent":["export * from './content-size';\nexport * from './dispatch-event';\nexport * from './wait';\n"],"mappings":";;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,YAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,YAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,YAAA,CAAAK,GAAA;IAAA;EAAA;AAAA;AACA,IAAAK,cAAA,GAAAT,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAO,cAAA,EAAAN,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAK,cAAA,CAAAL,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAC,cAAA,CAAAL,GAAA;IAAA;EAAA;AAAA;AACA,IAAAM,KAAA,GAAAV,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAQ,KAAA,EAAAP,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAM,KAAA,CAAAN,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAE,KAAA,CAAAN,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
package/build/within.d.ts CHANGED
@@ -1,5 +1,5 @@
1
- import type { HostElement } from 'test-renderer';
2
- export declare function within(element: HostElement): {
1
+ import type { TestInstance } from 'test-renderer';
2
+ export declare function within(instance: TestInstance): {
3
3
  getByRole: import("./queries/make-queries").GetByQuery<import("./queries/role").ByRoleMatcher, import("./queries/role").ByRoleOptions>;
4
4
  getAllByRole: import("./queries/make-queries").GetAllByQuery<import("./queries/role").ByRoleMatcher, import("./queries/role").ByRoleOptions>;
5
5
  queryByRole: import("./queries/make-queries").QueryByQuery<import("./queries/role").ByRoleMatcher, import("./queries/role").ByRoleOptions>;
@@ -55,4 +55,4 @@ export declare function within(element: HostElement): {
55
55
  findByText: import("./queries/make-queries").FindByQuery<import("./matches").TextMatch, import("./queries/options").CommonQueryOptions & import("./matches").TextMatchOptions>;
56
56
  findAllByText: import("./queries/make-queries").FindAllByQuery<import("./matches").TextMatch, import("./queries/options").CommonQueryOptions & import("./matches").TextMatchOptions>;
57
57
  };
58
- export declare const getQueriesForElement: typeof within;
58
+ export declare const getQueriesForInstance: typeof within;
package/build/within.js CHANGED
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.getQueriesForElement = void 0;
6
+ exports.getQueriesForInstance = void 0;
7
7
  exports.within = within;
8
8
  var _displayValue = require("./queries/display-value");
9
9
  var _hintText = require("./queries/hint-text");
@@ -12,16 +12,16 @@ var _placeholderText = require("./queries/placeholder-text");
12
12
  var _role = require("./queries/role");
13
13
  var _testId = require("./queries/test-id");
14
14
  var _text = require("./queries/text");
15
- function within(element) {
15
+ function within(instance) {
16
16
  return {
17
- ...(0, _text.bindByTextQueries)(element),
18
- ...(0, _testId.bindByTestIdQueries)(element),
19
- ...(0, _displayValue.bindByDisplayValueQueries)(element),
20
- ...(0, _placeholderText.bindByPlaceholderTextQueries)(element),
21
- ...(0, _labelText.bindByLabelTextQueries)(element),
22
- ...(0, _hintText.bindByHintTextQueries)(element),
23
- ...(0, _role.bindByRoleQueries)(element)
17
+ ...(0, _text.bindByTextQueries)(instance),
18
+ ...(0, _testId.bindByTestIdQueries)(instance),
19
+ ...(0, _displayValue.bindByDisplayValueQueries)(instance),
20
+ ...(0, _placeholderText.bindByPlaceholderTextQueries)(instance),
21
+ ...(0, _labelText.bindByLabelTextQueries)(instance),
22
+ ...(0, _hintText.bindByHintTextQueries)(instance),
23
+ ...(0, _role.bindByRoleQueries)(instance)
24
24
  };
25
25
  }
26
- const getQueriesForElement = exports.getQueriesForElement = within;
26
+ const getQueriesForInstance = exports.getQueriesForInstance = within;
27
27
  //# sourceMappingURL=within.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"within.js","names":["_displayValue","require","_hintText","_labelText","_placeholderText","_role","_testId","_text","within","element","bindByTextQueries","bindByTestIdQueries","bindByDisplayValueQueries","bindByPlaceholderTextQueries","bindByLabelTextQueries","bindByHintTextQueries","bindByRoleQueries","getQueriesForElement","exports"],"sources":["../src/within.ts"],"sourcesContent":["import type { HostElement } from 'test-renderer';\n\nimport { bindByDisplayValueQueries } from './queries/display-value';\nimport { bindByHintTextQueries } from './queries/hint-text';\nimport { bindByLabelTextQueries } from './queries/label-text';\nimport { bindByPlaceholderTextQueries } from './queries/placeholder-text';\nimport { bindByRoleQueries } from './queries/role';\nimport { bindByTestIdQueries } from './queries/test-id';\nimport { bindByTextQueries } from './queries/text';\n\nexport function within(element: HostElement) {\n return {\n ...bindByTextQueries(element),\n ...bindByTestIdQueries(element),\n ...bindByDisplayValueQueries(element),\n ...bindByPlaceholderTextQueries(element),\n ...bindByLabelTextQueries(element),\n ...bindByHintTextQueries(element),\n ...bindByRoleQueries(element),\n };\n}\n\nexport const getQueriesForElement = within;\n"],"mappings":";;;;;;;AAEA,IAAAA,aAAA,GAAAC,OAAA;AACA,IAAAC,SAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AACA,IAAAG,gBAAA,GAAAH,OAAA;AACA,IAAAI,KAAA,GAAAJ,OAAA;AACA,IAAAK,OAAA,GAAAL,OAAA;AACA,IAAAM,KAAA,GAAAN,OAAA;AAEO,SAASO,MAAMA,CAACC,OAAoB,EAAE;EAC3C,OAAO;IACL,GAAG,IAAAC,uBAAiB,EAACD,OAAO,CAAC;IAC7B,GAAG,IAAAE,2BAAmB,EAACF,OAAO,CAAC;IAC/B,GAAG,IAAAG,uCAAyB,EAACH,OAAO,CAAC;IACrC,GAAG,IAAAI,6CAA4B,EAACJ,OAAO,CAAC;IACxC,GAAG,IAAAK,iCAAsB,EAACL,OAAO,CAAC;IAClC,GAAG,IAAAM,+BAAqB,EAACN,OAAO,CAAC;IACjC,GAAG,IAAAO,uBAAiB,EAACP,OAAO;EAC9B,CAAC;AACH;AAEO,MAAMQ,oBAAoB,GAAAC,OAAA,CAAAD,oBAAA,GAAGT,MAAM","ignoreList":[]}
1
+ {"version":3,"file":"within.js","names":["_displayValue","require","_hintText","_labelText","_placeholderText","_role","_testId","_text","within","instance","bindByTextQueries","bindByTestIdQueries","bindByDisplayValueQueries","bindByPlaceholderTextQueries","bindByLabelTextQueries","bindByHintTextQueries","bindByRoleQueries","getQueriesForInstance","exports"],"sources":["../src/within.ts"],"sourcesContent":["import type { TestInstance } from 'test-renderer';\n\nimport { bindByDisplayValueQueries } from './queries/display-value';\nimport { bindByHintTextQueries } from './queries/hint-text';\nimport { bindByLabelTextQueries } from './queries/label-text';\nimport { bindByPlaceholderTextQueries } from './queries/placeholder-text';\nimport { bindByRoleQueries } from './queries/role';\nimport { bindByTestIdQueries } from './queries/test-id';\nimport { bindByTextQueries } from './queries/text';\n\nexport function within(instance: TestInstance) {\n return {\n ...bindByTextQueries(instance),\n ...bindByTestIdQueries(instance),\n ...bindByDisplayValueQueries(instance),\n ...bindByPlaceholderTextQueries(instance),\n ...bindByLabelTextQueries(instance),\n ...bindByHintTextQueries(instance),\n ...bindByRoleQueries(instance),\n };\n}\n\nexport const getQueriesForInstance = within;\n"],"mappings":";;;;;;;AAEA,IAAAA,aAAA,GAAAC,OAAA;AACA,IAAAC,SAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AACA,IAAAG,gBAAA,GAAAH,OAAA;AACA,IAAAI,KAAA,GAAAJ,OAAA;AACA,IAAAK,OAAA,GAAAL,OAAA;AACA,IAAAM,KAAA,GAAAN,OAAA;AAEO,SAASO,MAAMA,CAACC,QAAsB,EAAE;EAC7C,OAAO;IACL,GAAG,IAAAC,uBAAiB,EAACD,QAAQ,CAAC;IAC9B,GAAG,IAAAE,2BAAmB,EAACF,QAAQ,CAAC;IAChC,GAAG,IAAAG,uCAAyB,EAACH,QAAQ,CAAC;IACtC,GAAG,IAAAI,6CAA4B,EAACJ,QAAQ,CAAC;IACzC,GAAG,IAAAK,iCAAsB,EAACL,QAAQ,CAAC;IACnC,GAAG,IAAAM,+BAAqB,EAACN,QAAQ,CAAC;IAClC,GAAG,IAAAO,uBAAiB,EAACP,QAAQ;EAC/B,CAAC;AACH;AAEO,MAAMQ,qBAAqB,GAAAC,OAAA,CAAAD,qBAAA,GAAGT,MAAM","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@testing-library/react-native",
3
- "version": "14.0.0-beta.0",
3
+ "version": "14.0.0-rc.0",
4
4
  "description": "Simple and complete React Native testing utilities that encourage good testing practices.",
5
5
  "main": "build/index.js",
6
6
  "types": "build/index.d.ts",
@@ -8,8 +8,8 @@
8
8
  "type": "git",
9
9
  "url": "https://www.github.com/callstack/react-native-testing-library.git"
10
10
  },
11
- "homepage": "https://callstack.github.io/react-native-testing-library",
12
- "author": "Michał Pierzchała <thymikee@gmail.com> (https://github.com/thymikee), Maciej Jastrzębski <mdjastrzebski@gmail.com> (https://github.com/mdjastrzebski)",
11
+ "homepage": "https://oss.callstack.com/react-native-testing-library",
12
+ "author": "Maciej Jastrzębski <mdjastrzebski@gmail.com> (https://github.com/mdjastrzebski), Michał Pierzchała <thymikee@gmail.com> (https://github.com/thymikee)",
13
13
  "contributors": [
14
14
  "Augustin Le Fèvre <augustin.le-fevre@klarna.com> (https://github.com/AugustinLF)",
15
15
  "Pierre Zimmermann <pierrez@nam.tech> (https://github.com/pierrezimmermannbam)",
@@ -29,17 +29,21 @@
29
29
  "test:ci:coverage": "jest --maxWorkers=2 --collectCoverage=true",
30
30
  "test:codemods": "node scripts/test-codemods.mjs",
31
31
  "typecheck": "tsc",
32
+ "typecheck:react-19_2": "tsc -p tsconfig.react-19_2.json",
32
33
  "lint": "eslint src --cache",
33
34
  "prettier": "prettier --check .",
34
35
  "prettier:fix": "prettier --write .",
35
36
  "validate": "yarn typecheck && yarn test && yarn lint && yarn prettier",
37
+ "validate:examples": "yarn --cwd examples/basic validate && yarn --cwd examples/cookbook validate",
38
+ "validate:all": "yarn validate && yarn validate:examples && yarn --cwd website validate && yarn --cwd experiments-app validate",
36
39
  "validate:fix": "yarn prettier:fix && yarn lint --fix && yarn typecheck && yarn test -u",
37
40
  "build:js": "babel src --out-dir build --extensions \".js,.ts,.jsx,.tsx\" --source-maps --ignore \"**/__tests__/**\"",
38
41
  "build:ts": "tsc --build tsconfig.release.json",
39
42
  "build": "yarn clean && yarn build:js && yarn build:ts",
40
43
  "release": "release-it",
41
44
  "release:rc": "release-it --preRelease=rc",
42
- "release:beta": "release-it --preRelease=beta"
45
+ "release:beta": "release-it --preRelease=beta",
46
+ "release:codemods": "release-it --preRelease=alpha"
43
47
  },
44
48
  "files": [
45
49
  "build/",
@@ -50,16 +54,16 @@
50
54
  "dont-cleanup-after-each.js"
51
55
  ],
52
56
  "dependencies": {
53
- "jest-matcher-utils": "^30.2.0",
57
+ "jest-matcher-utils": "^30.3.0",
54
58
  "picocolors": "^1.1.1",
55
- "pretty-format": "^30.2.0",
59
+ "pretty-format": "^30.3.0",
56
60
  "redent": "^3.0.0"
57
61
  },
58
62
  "peerDependencies": {
59
63
  "jest": ">=29.0.0",
60
64
  "react": ">=19.0.0",
61
65
  "react-native": ">=0.78",
62
- "test-renderer": "^0.14.0"
66
+ "test-renderer": "^1.0.0"
63
67
  },
64
68
  "peerDependenciesMeta": {
65
69
  "jest": {
@@ -67,39 +71,45 @@
67
71
  }
68
72
  },
69
73
  "devDependencies": {
70
- "@babel/cli": "^7.28.3",
71
- "@babel/core": "^7.28.5",
74
+ "@babel/cli": "^7.28.6",
75
+ "@babel/core": "^7.29.0",
72
76
  "@babel/plugin-transform-strict-mode": "^7.27.1",
73
- "@babel/preset-env": "^7.28.5",
77
+ "@babel/preset-env": "^7.29.2",
74
78
  "@babel/preset-react": "^7.28.5",
75
79
  "@babel/preset-typescript": "^7.28.5",
76
80
  "@callstack/eslint-config": "^15.0.0",
77
- "@react-native/babel-preset": "0.83.1",
78
- "@release-it/conventional-changelog": "^10.0.2",
81
+ "@eslint/compat": "^2.0.5",
82
+ "@eslint/js": "^10.0.1",
83
+ "@react-native/babel-preset": "0.85.0",
84
+ "@react-native/jest-preset": "0.85.0",
85
+ "@release-it/conventional-changelog": "^10.0.6",
79
86
  "@relmify/jest-serializer-strip-ansi": "^1.0.2",
80
87
  "@types/jest": "^30.0.0",
81
- "@types/node": "^24.10.1",
82
- "@types/react": "^19.2.6",
83
- "babel-jest": "^30.2.0",
84
- "babel-plugin-module-resolver": "^5.0.2",
88
+ "@types/node": "^24.12.2",
89
+ "@types/react": "^19.2.14",
90
+ "babel-jest": "^30.3.0",
91
+ "babel-plugin-module-resolver": "^5.0.3",
85
92
  "del-cli": "^7.0.0",
86
- "eslint": "^9.39.1",
93
+ "eslint": "^10.2.0",
87
94
  "eslint-plugin-simple-import-sort": "^12.1.1",
88
- "jest": "^30.2.0",
89
- "prettier": "^3.6.2",
90
- "react": "19.2.0",
91
- "react-native": "0.83.1",
92
- "react-native-gesture-handler": "^2.29.1",
93
- "release-it": "^19.0.6",
94
- "test-renderer": "0.14.0",
95
- "typescript": "^5.9.3",
96
- "typescript-eslint": "^8.47.0"
95
+ "jest": "^30.3.0",
96
+ "prettier": "^3.8.2",
97
+ "react": "19.2.3",
98
+ "react-native": "0.85.0",
99
+ "release-it": "^19.2.4",
100
+ "test-renderer": "1.2.0",
101
+ "tsx": "^4.21.0",
102
+ "typescript": "^6.0.2",
103
+ "typescript-eslint": "^8.58.1"
97
104
  },
98
105
  "publishConfig": {
99
106
  "registry": "https://registry.npmjs.org"
100
107
  },
108
+ "resolutions": {
109
+ "@eslint/compat": "^2.0.5"
110
+ },
101
111
  "packageManager": "yarn@4.11.0",
102
112
  "engines": {
103
- "node": ">=20"
113
+ "node": "^22.13.0 || >=24"
104
114
  }
105
115
  }
@@ -1 +0,0 @@
1
- {"root":["../src/act.ts","../src/cleanup.ts","../src/config.ts","../src/event-handler.ts","../src/fire-event.ts","../src/flush-micro-tasks.ts","../src/index.ts","../src/matches.ts","../src/native-state.ts","../src/pure.ts","../src/render-hook.tsx","../src/render.tsx","../src/screen.ts","../src/types.ts","../src/wait-for-element-to-be-removed.ts","../src/wait-for.ts","../src/within.ts","../src/helpers/accessibility.ts","../src/helpers/component-tree.ts","../src/helpers/debug.ts","../src/helpers/errors.ts","../src/helpers/find-all.ts","../src/helpers/format-element.ts","../src/helpers/host-component-names.ts","../src/helpers/logger.ts","../src/helpers/map-props.ts","../src/helpers/object.ts","../src/helpers/pointer-events.ts","../src/helpers/text-content.ts","../src/helpers/text-input.ts","../src/helpers/timers.ts","../src/helpers/validate-options.ts","../src/helpers/wrap-async.ts","../src/helpers/matchers/match-accessibility-state.ts","../src/helpers/matchers/match-accessibility-value.ts","../src/helpers/matchers/match-array-prop.ts","../src/helpers/matchers/match-label-text.ts","../src/helpers/matchers/match-object-prop.ts","../src/helpers/matchers/match-string-prop.ts","../src/helpers/matchers/match-text-content.ts","../src/matchers/extend-expect.ts","../src/matchers/index.ts","../src/matchers/to-be-busy.ts","../src/matchers/to-be-checked.ts","../src/matchers/to-be-disabled.ts","../src/matchers/to-be-empty-element.ts","../src/matchers/to-be-expanded.ts","../src/matchers/to-be-on-the-screen.ts","../src/matchers/to-be-partially-checked.ts","../src/matchers/to-be-selected.ts","../src/matchers/to-be-visible.ts","../src/matchers/to-contain-element.ts","../src/matchers/to-have-accessibility-value.ts","../src/matchers/to-have-accessible-name.ts","../src/matchers/to-have-display-value.ts","../src/matchers/to-have-prop.ts","../src/matchers/to-have-style.ts","../src/matchers/to-have-text-content.ts","../src/matchers/types.ts","../src/matchers/utils.ts","../src/queries/display-value.ts","../src/queries/hint-text.ts","../src/queries/label-text.ts","../src/queries/make-queries.ts","../src/queries/options.ts","../src/queries/placeholder-text.ts","../src/queries/role.ts","../src/queries/test-id.ts","../src/queries/text.ts","../src/test-utils/console.ts","../src/test-utils/events.ts","../src/test-utils/json.ts","../src/test-utils/timers.ts","../src/test-utils/version.ts","../src/user-event/clear.ts","../src/user-event/index.ts","../src/user-event/paste.ts","../src/user-event/event-builder/base.ts","../src/user-event/event-builder/common.ts","../src/user-event/event-builder/index.ts","../src/user-event/event-builder/scroll-view.ts","../src/user-event/event-builder/text-input.ts","../src/user-event/press/index.ts","../src/user-event/press/press.ts","../src/user-event/scroll/index.ts","../src/user-event/scroll/scroll-to.ts","../src/user-event/scroll/utils.ts","../src/user-event/setup/index.ts","../src/user-event/setup/setup.ts","../src/user-event/type/index.ts","../src/user-event/type/parse-keys.ts","../src/user-event/type/type.ts","../src/user-event/utils/content-size.ts","../src/user-event/utils/dispatch-event.ts","../src/user-event/utils/index.ts","../src/user-event/utils/text-range.ts","../src/user-event/utils/wait.ts"],"version":"5.9.3"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"base.js","names":["baseSyntheticEvent","currentTarget","target","preventDefault","isDefaultPrevented","stopPropagation","isPropagationStopped","persist","isPersistent","timeStamp"],"sources":["../../../src/user-event/event-builder/base.ts"],"sourcesContent":["import type { BaseSyntheticEvent } from 'react';\n\n/** Builds base syntentic event stub, with prop values as inspected in RN runtime. */\ntype BaseEvent = Partial<BaseSyntheticEvent<object, unknown, unknown>> & {\n // `isPersistent` is not a standard prop, but it's used in RN runtime. See: https://react.dev/reference/react-dom/components/common#react-event-object-methods\n isPersistent: () => boolean;\n};\n\nexport function baseSyntheticEvent(): BaseEvent {\n return {\n currentTarget: {},\n target: {},\n preventDefault: () => {},\n isDefaultPrevented: () => false,\n stopPropagation: () => {},\n isPropagationStopped: () => false,\n persist: () => {},\n isPersistent: () => false,\n timeStamp: 0,\n };\n}\n"],"mappings":";;;;;;AAEA;;AAMO,SAASA,kBAAkBA,CAAA,EAAc;EAC9C,OAAO;IACLC,aAAa,EAAE,CAAC,CAAC;IACjBC,MAAM,EAAE,CAAC,CAAC;IACVC,cAAc,EAAEA,CAAA,KAAM,CAAC,CAAC;IACxBC,kBAAkB,EAAEA,CAAA,KAAM,KAAK;IAC/BC,eAAe,EAAEA,CAAA,KAAM,CAAC,CAAC;IACzBC,oBAAoB,EAAEA,CAAA,KAAM,KAAK;IACjCC,OAAO,EAAEA,CAAA,KAAM,CAAC,CAAC;IACjBC,YAAY,EAAEA,CAAA,KAAM,KAAK;IACzBC,SAAS,EAAE;EACb,CAAC;AACH","ignoreList":[]}
@@ -1,155 +0,0 @@
1
- /**
2
- * Experimental values:
3
- * - iOS: `{"changedTouches": [[Circular]], "identifier": 1, "locationX": 253, "locationY": 30.333328247070312, "pageX": 273, "pageY": 141.3333282470703, "target": 75, "timestamp": 875928682.0450834, "touches": [[Circular]]}`
4
- * - Android: `{"changedTouches": [[Circular]], "identifier": 0, "locationX": 160, "locationY": 40.3636360168457, "pageX": 180, "pageY": 140.36363220214844, "target": 53, "targetSurface": -1, "timestamp": 10290805, "touches": [[Circular]]}`
5
- */
6
- declare function touch(): {
7
- nativeEvent: {
8
- changedTouches: never[];
9
- identifier: number;
10
- locationX: number;
11
- locationY: number;
12
- pageX: number;
13
- pageY: number;
14
- target: number;
15
- timestamp: number;
16
- touches: never[];
17
- };
18
- currentTarget: {
19
- measure: () => void;
20
- };
21
- target?: unknown;
22
- bubbles?: boolean | undefined;
23
- cancelable?: boolean | undefined;
24
- defaultPrevented?: boolean | undefined;
25
- eventPhase?: number | undefined;
26
- isTrusted?: boolean | undefined;
27
- preventDefault?: (() => void) | undefined;
28
- isDefaultPrevented?: (() => boolean) | undefined;
29
- stopPropagation?: (() => void) | undefined;
30
- isPropagationStopped?: (() => boolean) | undefined;
31
- persist?: (() => void) | undefined;
32
- timeStamp?: number | undefined;
33
- type?: string | undefined;
34
- isPersistent: () => boolean;
35
- };
36
- export declare const CommonEventBuilder: {
37
- touch: typeof touch;
38
- responderGrant: () => {
39
- dispatchConfig: {
40
- registrationName: string;
41
- };
42
- nativeEvent: {
43
- changedTouches: never[];
44
- identifier: number;
45
- locationX: number;
46
- locationY: number;
47
- pageX: number;
48
- pageY: number;
49
- target: number;
50
- timestamp: number;
51
- touches: never[];
52
- };
53
- currentTarget: {
54
- measure: () => void;
55
- };
56
- target?: unknown;
57
- bubbles?: boolean | undefined;
58
- cancelable?: boolean | undefined;
59
- defaultPrevented?: boolean | undefined;
60
- eventPhase?: number | undefined;
61
- isTrusted?: boolean | undefined;
62
- preventDefault?: (() => void) | undefined;
63
- isDefaultPrevented?: (() => boolean) | undefined;
64
- stopPropagation?: (() => void) | undefined;
65
- isPropagationStopped?: (() => boolean) | undefined;
66
- persist?: (() => void) | undefined;
67
- timeStamp?: number | undefined;
68
- type?: string | undefined;
69
- isPersistent: () => boolean;
70
- };
71
- responderRelease: () => {
72
- dispatchConfig: {
73
- registrationName: string;
74
- };
75
- nativeEvent: {
76
- changedTouches: never[];
77
- identifier: number;
78
- locationX: number;
79
- locationY: number;
80
- pageX: number;
81
- pageY: number;
82
- target: number;
83
- timestamp: number;
84
- touches: never[];
85
- };
86
- currentTarget: {
87
- measure: () => void;
88
- };
89
- target?: unknown;
90
- bubbles?: boolean | undefined;
91
- cancelable?: boolean | undefined;
92
- defaultPrevented?: boolean | undefined;
93
- eventPhase?: number | undefined;
94
- isTrusted?: boolean | undefined;
95
- preventDefault?: (() => void) | undefined;
96
- isDefaultPrevented?: (() => boolean) | undefined;
97
- stopPropagation?: (() => void) | undefined;
98
- isPropagationStopped?: (() => boolean) | undefined;
99
- persist?: (() => void) | undefined;
100
- timeStamp?: number | undefined;
101
- type?: string | undefined;
102
- isPersistent: () => boolean;
103
- };
104
- /**
105
- * Experimental values:
106
- * - iOS: `{"eventCount": 0, "target": 75, "text": ""}`
107
- * - Android: `{"target": 53}`
108
- */
109
- focus: () => {
110
- nativeEvent: {
111
- target: number;
112
- };
113
- currentTarget?: unknown;
114
- target?: unknown;
115
- bubbles?: boolean | undefined;
116
- cancelable?: boolean | undefined;
117
- defaultPrevented?: boolean | undefined;
118
- eventPhase?: number | undefined;
119
- isTrusted?: boolean | undefined;
120
- preventDefault?: (() => void) | undefined;
121
- isDefaultPrevented?: (() => boolean) | undefined;
122
- stopPropagation?: (() => void) | undefined;
123
- isPropagationStopped?: (() => boolean) | undefined;
124
- persist?: (() => void) | undefined;
125
- timeStamp?: number | undefined;
126
- type?: string | undefined;
127
- isPersistent: () => boolean;
128
- };
129
- /**
130
- * Experimental values:
131
- * - iOS: `{"eventCount": 0, "target": 75, "text": ""}`
132
- * - Android: `{"target": 53}`
133
- */
134
- blur: () => {
135
- nativeEvent: {
136
- target: number;
137
- };
138
- currentTarget?: unknown;
139
- target?: unknown;
140
- bubbles?: boolean | undefined;
141
- cancelable?: boolean | undefined;
142
- defaultPrevented?: boolean | undefined;
143
- eventPhase?: number | undefined;
144
- isTrusted?: boolean | undefined;
145
- preventDefault?: (() => void) | undefined;
146
- isDefaultPrevented?: (() => boolean) | undefined;
147
- stopPropagation?: (() => void) | undefined;
148
- isPropagationStopped?: (() => boolean) | undefined;
149
- persist?: (() => void) | undefined;
150
- timeStamp?: number | undefined;
151
- type?: string | undefined;
152
- isPersistent: () => boolean;
153
- };
154
- };
155
- export {};