@testing-library/react-native 12.1.3 → 12.2.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.
- package/.DS_Store +0 -0
- package/.eslintcache +1 -1
- package/build/fireEvent.js +3 -6
- package/build/fireEvent.js.map +1 -1
- package/build/helpers/deprecation.js +1 -1
- package/build/helpers/deprecation.js.map +1 -1
- package/build/helpers/host-component-names.d.ts +3 -0
- package/build/helpers/host-component-names.js +8 -0
- package/build/helpers/host-component-names.js.map +1 -1
- package/build/pure.d.ts +2 -0
- package/build/pure.js +7 -0
- package/build/pure.js.map +1 -1
- package/build/user-event/event-builder/common.d.ts +48 -6
- package/build/user-event/event-builder/common.js +37 -20
- package/build/user-event/event-builder/common.js.map +1 -1
- package/build/user-event/event-builder/index.d.ts +94 -0
- package/build/user-event/event-builder/index.js +3 -1
- package/build/user-event/event-builder/index.js.map +1 -1
- package/build/user-event/event-builder/text-input.d.ts +91 -0
- package/build/user-event/event-builder/text-input.js +117 -0
- package/build/user-event/event-builder/text-input.js.map +1 -0
- package/build/user-event/index.d.ts +4 -2
- package/build/user-event/index.js +7 -1
- package/build/user-event/index.js.map +1 -1
- package/build/user-event/press/index.d.ts +1 -1
- package/build/user-event/press/index.js +6 -0
- package/build/user-event/press/index.js.map +1 -1
- package/build/user-event/press/press.d.ts +3 -3
- package/build/user-event/press/press.js +55 -62
- package/build/user-event/press/press.js.map +1 -1
- package/build/user-event/setup/setup.d.ts +33 -3
- package/build/user-event/setup/setup.js +14 -1
- package/build/user-event/setup/setup.js.map +1 -1
- package/build/user-event/type/index.d.ts +1 -1
- package/build/user-event/type/index.js +6 -0
- package/build/user-event/type/index.js.map +1 -1
- package/build/user-event/type/parseKeys.d.ts +1 -0
- package/build/user-event/type/parseKeys.js +40 -0
- package/build/user-event/type/parseKeys.js.map +1 -0
- package/build/user-event/type/type.d.ts +5 -1
- package/build/user-event/type/type.js +66 -8
- package/build/user-event/type/type.js.map +1 -1
- package/build/user-event/utils/content-size.d.ts +15 -0
- package/build/user-event/utils/content-size.js +26 -0
- package/build/user-event/utils/content-size.js.map +1 -0
- package/build/user-event/utils/{events.d.ts → dispatch-event.d.ts} +2 -2
- package/build/user-event/utils/dispatch-event.js +36 -0
- package/build/user-event/utils/dispatch-event.js.map +1 -0
- package/build/user-event/utils/index.d.ts +4 -1
- package/build/user-event/utils/index.js +37 -4
- package/build/user-event/utils/index.js.map +1 -1
- package/build/user-event/utils/text-range.d.ts +5 -0
- package/build/user-event/utils/text-range.js +13 -0
- package/build/user-event/utils/text-range.js.map +1 -0
- package/build/user-event/utils/warn-about-real-timers.d.ts +1 -0
- package/build/user-event/utils/warn-about-real-timers.js +20 -0
- package/build/user-event/utils/warn-about-real-timers.js.map +1 -0
- package/coverage/clover.xml +1176 -0
- package/coverage/coverage-final.json +70 -0
- package/coverage/lcov-report/base.css +224 -0
- package/coverage/lcov-report/block-navigation.js +87 -0
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +266 -0
- package/coverage/lcov-report/prettify.css +1 -0
- package/coverage/lcov-report/prettify.js +2 -0
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +196 -0
- package/coverage/lcov-report/src/act.ts.html +343 -0
- package/coverage/lcov-report/src/cleanup.ts.html +130 -0
- package/coverage/lcov-report/src/config.ts.html +301 -0
- package/coverage/lcov-report/src/fireEvent.ts.html +559 -0
- package/coverage/lcov-report/src/flushMicroTasks.ts.html +124 -0
- package/coverage/lcov-report/src/helpers/accessiblity.ts.html +412 -0
- package/coverage/lcov-report/src/helpers/component-tree.ts.html +352 -0
- package/coverage/lcov-report/src/helpers/debugDeep.ts.html +166 -0
- package/coverage/lcov-report/src/helpers/debugShallow.ts.html +151 -0
- package/coverage/lcov-report/src/helpers/deprecation.ts.html +244 -0
- package/coverage/lcov-report/src/helpers/errors.ts.html +283 -0
- package/coverage/lcov-report/src/helpers/filterNodeByType.ts.html +106 -0
- package/coverage/lcov-report/src/helpers/findAll.ts.html +289 -0
- package/coverage/lcov-report/src/helpers/format-default.ts.html +301 -0
- package/coverage/lcov-report/src/helpers/format.ts.html +226 -0
- package/coverage/lcov-report/src/helpers/getTextContent.ts.html +145 -0
- package/coverage/lcov-report/src/helpers/host-component-names.tsx.html +286 -0
- package/coverage/lcov-report/src/helpers/index.html +326 -0
- package/coverage/lcov-report/src/helpers/matchers/accessibilityState.ts.html +229 -0
- package/coverage/lcov-report/src/helpers/matchers/accessibilityValue.ts.html +157 -0
- package/coverage/lcov-report/src/helpers/matchers/index.html +206 -0
- package/coverage/lcov-report/src/helpers/matchers/matchArrayProp.ts.html +148 -0
- package/coverage/lcov-report/src/helpers/matchers/matchLabelText.ts.html +238 -0
- package/coverage/lcov-report/src/helpers/matchers/matchObjectProp.ts.html +160 -0
- package/coverage/lcov-report/src/helpers/matchers/matchStringProp.ts.html +154 -0
- package/coverage/lcov-report/src/helpers/matchers/matchTextContent.ts.html +145 -0
- package/coverage/lcov-report/src/helpers/query-name.ts.html +97 -0
- package/coverage/lcov-report/src/helpers/stringValidation.ts.html +193 -0
- package/coverage/lcov-report/src/helpers/timers.ts.html +382 -0
- package/coverage/lcov-report/src/index.html +356 -0
- package/coverage/lcov-report/src/index.ts.html +184 -0
- package/coverage/lcov-report/src/matches.ts.html +232 -0
- package/coverage/lcov-report/src/pure.ts.html +157 -0
- package/coverage/lcov-report/src/queries/a11yState.ts.html +478 -0
- package/coverage/lcov-report/src/queries/a11yValue.ts.html +478 -0
- package/coverage/lcov-report/src/queries/displayValue.ts.html +319 -0
- package/coverage/lcov-report/src/queries/hintText.ts.html +421 -0
- package/coverage/lcov-report/src/queries/index.html +281 -0
- package/coverage/lcov-report/src/queries/labelText.ts.html +262 -0
- package/coverage/lcov-report/src/queries/makeQueries.ts.html +850 -0
- package/coverage/lcov-report/src/queries/placeholderText.ts.html +322 -0
- package/coverage/lcov-report/src/queries/role.ts.html +481 -0
- package/coverage/lcov-report/src/queries/testId.ts.html +298 -0
- package/coverage/lcov-report/src/queries/text.ts.html +283 -0
- package/coverage/lcov-report/src/queries/unsafeProps.ts.html +313 -0
- package/coverage/lcov-report/src/queries/unsafeType.ts.html +304 -0
- package/coverage/lcov-report/src/react-versions.ts.html +118 -0
- package/coverage/lcov-report/src/render-act.ts.html +142 -0
- package/coverage/lcov-report/src/render.tsx.html +592 -0
- package/coverage/lcov-report/src/renderHook.tsx.html +262 -0
- package/coverage/lcov-report/src/screen.ts.html +454 -0
- package/coverage/lcov-report/src/shallow.ts.html +139 -0
- package/coverage/lcov-report/src/test-utils/events.ts.html +145 -0
- package/coverage/lcov-report/src/test-utils/index.html +131 -0
- package/coverage/lcov-report/src/test-utils/index.ts.html +88 -0
- package/coverage/lcov-report/src/user-event/event-builder/common.ts.html +229 -0
- package/coverage/lcov-report/src/user-event/event-builder/index.html +146 -0
- package/coverage/lcov-report/src/user-event/event-builder/index.ts.html +106 -0
- package/coverage/lcov-report/src/user-event/event-builder/test-input.ts.html +343 -0
- package/coverage/lcov-report/src/user-event/event-builder/text-input.ts.html +343 -0
- package/coverage/lcov-report/src/user-event/index.html +116 -0
- package/coverage/lcov-report/src/user-event/index.ts.html +121 -0
- package/coverage/lcov-report/src/user-event/press/index.html +131 -0
- package/coverage/lcov-report/src/user-event/press/index.ts.html +88 -0
- package/coverage/lcov-report/src/user-event/press/press.ts.html +133 -0
- package/coverage/lcov-report/src/user-event/setup/index.html +131 -0
- package/coverage/lcov-report/src/user-event/setup/index.ts.html +91 -0
- package/coverage/lcov-report/src/user-event/setup/setup.ts.html +358 -0
- package/coverage/lcov-report/src/user-event/type/index.html +146 -0
- package/coverage/lcov-report/src/user-event/type/index.ts.html +88 -0
- package/coverage/lcov-report/src/user-event/type/parseKeys.ts.html +208 -0
- package/coverage/lcov-report/src/user-event/type/type.ts.html +484 -0
- package/coverage/lcov-report/src/user-event/utils/content-size.ts.html +160 -0
- package/coverage/lcov-report/src/user-event/utils/dispatch-event.ts.html +367 -0
- package/coverage/lcov-report/src/user-event/utils/events.ts.html +247 -0
- package/coverage/lcov-report/src/user-event/utils/index.html +176 -0
- package/coverage/lcov-report/src/user-event/utils/index.ts.html +97 -0
- package/coverage/lcov-report/src/user-event/utils/text-range.ts.html +118 -0
- package/coverage/lcov-report/src/user-event/utils/wait.ts.html +130 -0
- package/coverage/lcov-report/src/waitFor.ts.html +772 -0
- package/coverage/lcov-report/src/waitForElementToBeRemoved.ts.html +211 -0
- package/coverage/lcov-report/src/within.ts.html +175 -0
- package/coverage/lcov.info +2614 -0
- package/examples/.DS_Store +0 -0
- package/examples/basic/.expo/README.md +17 -0
- package/examples/basic/.expo/devices.json +3 -0
- package/examples/basic/.expo/packager-info.json +4 -0
- package/examples/basic/.expo/settings.json +8 -0
- package/examples/basic/package.json +7 -7
- package/examples/basic/yarn-error.log +8083 -0
- package/examples/basic/yarn.lock +8878 -0
- package/examples/react-navigation/README.md +2 -0
- package/examples/react-navigation/package.json +5 -5
- package/examples/react-navigation/yarn.lock +5610 -0
- package/examples/redux/README.md +5 -0
- package/examples/redux/package.json +7 -7
- package/examples/redux/yarn-error.log +8083 -0
- package/examples/redux/yarn.lock +8423 -0
- package/experiments-app/.expo/settings.json +2 -1
- package/experiments-app/src/screens/TextInputEvents.tsx +10 -0
- package/package.json +1 -1
- package/src/.DS_Store +0 -0
- package/src/__tests__/.DS_Store +0 -0
- package/src/__tests__/act.test.tsx +4 -0
- package/src/fireEvent.ts +2 -6
- package/src/helpers/deprecation.ts +1 -1
- package/src/helpers/host-component-names.tsx +8 -0
- package/src/pure.ts +2 -0
- package/src/user-event/event-builder/common.ts +35 -19
- package/src/user-event/event-builder/index.ts +2 -0
- package/src/user-event/event-builder/text-input.ts +86 -0
- package/src/user-event/index.ts +6 -3
- package/src/user-event/press/__tests__/longPress.real-timers.test.tsx +4 -2
- package/src/user-event/press/__tests__/press.real-timers.test.tsx +4 -2
- package/src/user-event/press/__tests__/press.test.tsx +40 -5
- package/src/user-event/press/index.ts +1 -1
- package/src/user-event/press/press.ts +93 -58
- package/src/user-event/setup/setup.ts +39 -5
- package/src/user-event/type/__tests__/__snapshots__/type-managed.test.tsx.snap +339 -0
- package/src/user-event/type/__tests__/__snapshots__/type.test.tsx.snap +644 -2
- package/src/user-event/type/__tests__/parseKeys.test.ts +23 -0
- package/src/user-event/type/__tests__/type-managed.test.tsx +121 -0
- package/src/user-event/type/__tests__/type.test.tsx +300 -27
- package/src/user-event/type/index.ts +1 -1
- package/src/user-event/type/parseKeys.ts +41 -0
- package/src/user-event/type/type.ts +125 -10
- package/src/user-event/utils/__tests__/dispatch-event.test.tsx +41 -0
- package/src/user-event/utils/content-size.ts +25 -0
- package/src/user-event/utils/dispatch-event.ts +38 -0
- package/src/user-event/utils/index.ts +4 -1
- package/src/user-event/utils/text-range.ts +11 -0
- package/src/user-event/{press/utils/warnAboutRealTimers.ts → utils/warn-about-real-timers.ts} +8 -1
- package/website/.DS_Store +0 -0
- package/website/.docusaurus/DONT-EDIT-THIS-FOLDER +5 -0
- package/website/.docusaurus/client-modules.js +6 -0
- package/website/.docusaurus/codeTranslations.json +1 -0
- package/website/.docusaurus/docusaurus-plugin-content-blog/default/blog-post-list-prop-default.json +4 -0
- package/website/.docusaurus/docusaurus-plugin-content-blog/default/plugin-route-context-module-100.json +4 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/plugin-route-context-module-100.json +4 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-api-md-c82.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-eslint-p-llugin-testing-library-md-d24.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-faq-md-ad8.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-getting-started-md-8a6.json +23 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-how-should-i-query-md-f2d.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-migration-v-11-md-add.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-migration-v-12-md-14f.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-migration-v-2-md-698.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-migration-v-7-md-6bb.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-migration-v-9-md-f69.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-queries-md-7ad.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-react-navigation-md-1bd.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-redux-integration-md-77b.json +23 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-testing-environment-md-1c6.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-troubleshooting-md-01d.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-understanding-act-md-aa9.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/site-docs-user-event-md-501.json +27 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/default/version-current-metadata-prop-751.json +268 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/react-native-testing-library-docs-route-96e.json +115 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-api-md-c82.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-eslint-p-llugin-testing-library-md-d24.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-faq-md-ad8.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-getting-started-md-8a6.json +15 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-how-should-i-query-md-f2d.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-migration-v-11-md-add.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-migration-v-2-md-698.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-migration-v-7-md-6bb.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-migration-v-9-md-f69.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-queries-md-7ad.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-react-navigation-md-1bd.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-redux-integration-md-77b.json +15 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-troubleshooting-md-01d.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-docs/site-docs-understanding-act-md-aa9.json +19 -0
- package/website/.docusaurus/docusaurus-plugin-content-pages/default/plugin-route-context-module-100.json +4 -0
- package/website/.docusaurus/docusaurus-plugin-debug/default/docusaurus-debug-all-content-673.json +623 -0
- package/website/.docusaurus/docusaurus-plugin-debug/default/plugin-route-context-module-100.json +4 -0
- package/website/.docusaurus/docusaurus-theme-search-algolia/default/plugin-route-context-module-100.json +4 -0
- package/website/.docusaurus/docusaurus.config.js +267 -0
- package/website/.docusaurus/docusaurus.config.mjs +365 -0
- package/website/.docusaurus/globalData.json +113 -0
- package/website/.docusaurus/i18n.json +17 -0
- package/website/.docusaurus/registry.js +35 -0
- package/website/.docusaurus/routes.js +162 -0
- package/website/.docusaurus/routesChunkNames.json +133 -0
- package/website/.docusaurus/site-metadata.json +36 -0
- package/website/docs/API.md +19 -25
- package/website/docs/UserEvent.md +86 -9
- package/website/sidebars.js +1 -1
- package/yarn-error.log +10613 -0
- package/build/user-event/press/utils/warnAboutRealTimers.d.ts +0 -1
- package/build/user-event/press/utils/warnAboutRealTimers.js +0 -14
- package/build/user-event/press/utils/warnAboutRealTimers.js.map +0 -1
- package/build/user-event/utils/events.js +0 -44
- package/build/user-event/utils/events.js.map +0 -1
- package/experiments-app/.expo/packager-info.json +0 -9
- package/src/user-event/utils/events.ts +0 -54
|
@@ -5,11 +5,31 @@ title: User Event
|
|
|
5
5
|
|
|
6
6
|
### Table of contents
|
|
7
7
|
|
|
8
|
-
- [
|
|
8
|
+
- [Comparison with Fire Event API](#comparison-with-fire-event-api)
|
|
9
|
+
- [`setup()`](#setup)
|
|
9
10
|
- [Options](#options)
|
|
11
|
+
- [`press()`](#press)
|
|
12
|
+
- [`longPress()`](#longpress)
|
|
13
|
+
- [Options](#options-1)
|
|
14
|
+
- [`type()`](#type)
|
|
15
|
+
- [Options](#options-2)
|
|
16
|
+
- [Sequence of events](#sequence-of-events)
|
|
10
17
|
|
|
18
|
+
:::caution
|
|
19
|
+
User Event API is in beta stage.
|
|
11
20
|
|
|
12
|
-
|
|
21
|
+
This means that we plan to keep the public API signatures to remain stable, but we might introduce breaking behavioural changes, e.g. changing the ordering or timing of emitted events, without a major version update. Hopefully, well written code should not rely on such specific details.
|
|
22
|
+
:::
|
|
23
|
+
|
|
24
|
+
## Comparison with Fire Event API
|
|
25
|
+
|
|
26
|
+
Fire Event is our original event simulation API. It offers ability to invoke **any event handler** declared on **either host or composite elements**. If the element does not have `onEventName` event handler for passed `eventName` event, or the element is disabled, Fire Event will traverse up the component tree, looking for event handler on both host and composite elements along the way. By default it will **not pass any event data**, but the user might provide it in the last argument.
|
|
27
|
+
|
|
28
|
+
In contrast, User Event provides realistic event simulation for main user interactions like `press` or `type`. Each of the interactions will trigger a **sequence of events** corresponding to React Native runtime behavior. These events will be invoked **only on host elements**, and **will automatically receive event data** corresponding to each event.
|
|
29
|
+
|
|
30
|
+
If User Event supports given interaction you should always prefer it over Fire Event counterpart, as it will make your tests much more realistic and hence reliable. In other cases, e.g. when event is not supported by User Event, or when invoking event handlers on composite elements, you have to use Fire Event as the only available option.
|
|
31
|
+
|
|
32
|
+
## `setup()`
|
|
13
33
|
|
|
14
34
|
```ts
|
|
15
35
|
userEvent.setup(options?: {
|
|
@@ -23,11 +43,11 @@ Example
|
|
|
23
43
|
const user = userEvent.setup();
|
|
24
44
|
```
|
|
25
45
|
|
|
26
|
-
Creates User Event
|
|
46
|
+
Creates an User Event object instance which can be used to trigger events.
|
|
27
47
|
|
|
28
48
|
### Options
|
|
29
|
-
- `delay` - controls the default delay between subsequent events, e.g. keystrokes
|
|
30
|
-
- `advanceTimers` - time advancement utility function that should be used for fake timers. The default setup handles both real and Jest fake timers.
|
|
49
|
+
- `delay` - controls the default delay between subsequent events, e.g. keystrokes.
|
|
50
|
+
- `advanceTimers` - time advancement utility function that should be used for fake timers. The default setup handles both real timers and Jest fake timers.
|
|
31
51
|
|
|
32
52
|
|
|
33
53
|
## `press()`
|
|
@@ -41,11 +61,10 @@ press(
|
|
|
41
61
|
Example
|
|
42
62
|
```ts
|
|
43
63
|
const user = userEvent.setup();
|
|
44
|
-
|
|
45
64
|
await user.press(element);
|
|
46
65
|
```
|
|
47
66
|
|
|
48
|
-
This helper simulates a press on any pressable element, e.g. `Pressable`, `TouchableOpacity`, `Text`, `TextInput`, etc. Unlike `fireEvent.press()` which is a simpler API that will only call the `onPress` prop, this simulates the entire press
|
|
67
|
+
This helper simulates a press on any pressable element, e.g. `Pressable`, `TouchableOpacity`, `Text`, `TextInput`, etc. Unlike `fireEvent.press()` which is a simpler API that will only call the `onPress` prop, this function simulates the entire press interaction in a more realistic way by reproducing event sequence emitted by React Native runtime. This helper will trigger additional events like `pressIn` and `pressOut`.
|
|
49
68
|
|
|
50
69
|
## `longPress()`
|
|
51
70
|
|
|
@@ -59,8 +78,66 @@ longPress(
|
|
|
59
78
|
Example
|
|
60
79
|
```ts
|
|
61
80
|
const user = userEvent.setup();
|
|
62
|
-
|
|
63
81
|
await user.longPress(element);
|
|
64
82
|
```
|
|
65
83
|
|
|
66
|
-
Simulates a long press user interaction. In React Native the `longPress` event is emitted when the press duration exceeds long press threshold (by default 500 ms). In other aspects this actions behaves similar to regular `press` action, e.g. by emitting `pressIn` and `pressOut` events. The press duration is customisable through the options. This should be useful if you use the `delayLongPress` prop. When using real timers this will take 500 ms so it is highly recommended to use that API with fake timers to prevent test taking a long time to run.
|
|
84
|
+
Simulates a long press user interaction. In React Native the `longPress` event is emitted when the press duration exceeds long press threshold (by default 500 ms). In other aspects this actions behaves similar to regular `press` action, e.g. by emitting `pressIn` and `pressOut` events. The press duration is customisable through the options. This should be useful if you use the `delayLongPress` prop. When using real timers this will take 500 ms so it is highly recommended to use that API with fake timers to prevent test taking a long time to run.
|
|
85
|
+
|
|
86
|
+
### Options
|
|
87
|
+
- `duration` - duration of the press in miliseconds. Default value is 500 ms.
|
|
88
|
+
|
|
89
|
+
## `type()`
|
|
90
|
+
|
|
91
|
+
```ts
|
|
92
|
+
type(
|
|
93
|
+
element: ReactTestInstance,
|
|
94
|
+
text: string,
|
|
95
|
+
options?: {
|
|
96
|
+
skipPress?: boolean
|
|
97
|
+
submitEditing?: boolean
|
|
98
|
+
}
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
Example
|
|
102
|
+
```ts
|
|
103
|
+
const user = userEvent.setup();
|
|
104
|
+
await user.type(textInput, "Hello world!");
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
This helper simulates user focusing on `TextInput` element, typing `text` one character at a time, and leaving the element.
|
|
108
|
+
|
|
109
|
+
This function supports only host `TextInput` elements. Passing other element type will result in throwing error.
|
|
110
|
+
|
|
111
|
+
### Options
|
|
112
|
+
- `skipPress` - if true, `pressIn` and `pressOut` events will not be triggered.
|
|
113
|
+
- `submitEditing` - if true, `submitEditing` event will be triggered after typing the text.
|
|
114
|
+
|
|
115
|
+
### Sequence of events
|
|
116
|
+
|
|
117
|
+
The sequence of events depends on `multiline` prop, as well as passed options.
|
|
118
|
+
|
|
119
|
+
Events will not be emitted if `editable` prop is set to `false`.
|
|
120
|
+
|
|
121
|
+
**Entering the element**:
|
|
122
|
+
- `pressIn` (optional)
|
|
123
|
+
- `focus`
|
|
124
|
+
- `pressOut` (optional)
|
|
125
|
+
|
|
126
|
+
The `pressIn` and `pressOut` events are sent by default, but can be skipped by passing `skipPress: true` option.
|
|
127
|
+
|
|
128
|
+
**Typing (for each character)**:
|
|
129
|
+
- `keyPress`
|
|
130
|
+
- `textInput` (optional)
|
|
131
|
+
- `change`
|
|
132
|
+
- `changeText`
|
|
133
|
+
- `selectionChange`
|
|
134
|
+
|
|
135
|
+
The `textInput` event is sent only for mutliline text inputs.
|
|
136
|
+
|
|
137
|
+
**Leaving the element**:
|
|
138
|
+
- `submitEditing` (optional)
|
|
139
|
+
- `endEditing`
|
|
140
|
+
- `blur`
|
|
141
|
+
|
|
142
|
+
The `submitEditing` event is skipped by default. It can sent by setting `submitEditing: true` option.
|
|
143
|
+
|