@react-native-harness/runtime 1.0.0-alpha.14 → 1.0.0-alpha.17

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 (209) hide show
  1. package/assets/moduleSystem.flow.js +15 -3
  2. package/dist/bundler/evaluate.d.ts.map +1 -1
  3. package/dist/bundler/evaluate.js +7 -7
  4. package/dist/client/factory.d.ts.map +1 -1
  5. package/dist/client/factory.js +26 -12
  6. package/dist/client/setup-files.d.ts +12 -0
  7. package/dist/client/setup-files.d.ts.map +1 -0
  8. package/dist/client/setup-files.js +60 -0
  9. package/dist/collector/functions.d.ts +1 -1
  10. package/dist/collector/functions.d.ts.map +1 -1
  11. package/dist/collector/functions.js +2 -2
  12. package/dist/collector/types.d.ts +1 -1
  13. package/dist/collector/types.d.ts.map +1 -1
  14. package/dist/entry-point.d.ts +2 -0
  15. package/dist/entry-point.d.ts.map +1 -0
  16. package/dist/entry-point.js +4 -0
  17. package/dist/expect/index.d.ts.map +1 -1
  18. package/dist/expect/index.js +2 -0
  19. package/dist/expect/setup.js +2 -0
  20. package/dist/filtering/index.d.ts +1 -1
  21. package/dist/filtering/index.d.ts.map +1 -1
  22. package/dist/filtering/index.js +1 -1
  23. package/dist/filtering/testNameFilter.d.ts +6 -0
  24. package/dist/filtering/testNameFilter.d.ts.map +1 -1
  25. package/dist/filtering/testNameFilter.js +36 -5
  26. package/dist/globals.d.ts +5 -2
  27. package/dist/globals.d.ts.map +1 -1
  28. package/dist/globals.js +7 -1
  29. package/dist/index.d.ts +1 -0
  30. package/dist/index.d.ts.map +1 -1
  31. package/dist/index.js +1 -0
  32. package/dist/initialize.js +7 -0
  33. package/dist/jest-mock.d.ts +2 -0
  34. package/dist/jest-mock.d.ts.map +1 -0
  35. package/dist/jest-mock.js +25 -0
  36. package/dist/render/ErrorBoundary.d.ts +17 -0
  37. package/dist/render/ErrorBoundary.d.ts.map +1 -0
  38. package/dist/render/ErrorBoundary.js +73 -0
  39. package/dist/render/TestComponentOverlay.d.ts +3 -0
  40. package/dist/render/TestComponentOverlay.d.ts.map +1 -0
  41. package/dist/render/TestComponentOverlay.js +36 -0
  42. package/dist/render/cleanup.d.ts +2 -0
  43. package/dist/render/cleanup.d.ts.map +1 -0
  44. package/dist/render/cleanup.js +6 -0
  45. package/dist/render/index.d.ts +6 -0
  46. package/dist/render/index.d.ts.map +1 -0
  47. package/dist/render/index.js +66 -0
  48. package/dist/render/setup.d.ts +2 -0
  49. package/dist/render/setup.d.ts.map +1 -0
  50. package/dist/render/setup.js +7 -0
  51. package/dist/render/types.d.ts +12 -0
  52. package/dist/render/types.d.ts.map +1 -0
  53. package/dist/render/types.js +1 -0
  54. package/dist/runner/factory.d.ts.map +1 -1
  55. package/dist/runner/factory.js +6 -1
  56. package/dist/symbolicate.d.ts.map +1 -1
  57. package/dist/symbolicate.js +5 -4
  58. package/dist/tsconfig.lib.tsbuildinfo +1 -1
  59. package/dist/ui/ReadyScreen.d.ts.map +1 -1
  60. package/dist/ui/ReadyScreen.js +2 -1
  61. package/dist/ui/state.d.ts +14 -1
  62. package/dist/ui/state.d.ts.map +1 -1
  63. package/dist/ui/state.js +22 -0
  64. package/dist/utils/emitter.d.ts.map +1 -1
  65. package/dist/waitFor.d.ts.map +1 -1
  66. package/dist/waitFor.js +4 -0
  67. package/eslint.config.mjs +1 -7
  68. package/out-tsc/vitest/src/__tests__/collector.test.d.ts +2 -0
  69. package/out-tsc/vitest/src/__tests__/collector.test.d.ts.map +1 -0
  70. package/out-tsc/vitest/src/__tests__/error-handling.test.d.ts +2 -0
  71. package/out-tsc/vitest/src/__tests__/error-handling.test.d.ts.map +1 -0
  72. package/out-tsc/vitest/src/__tests__/expect.test.d.ts +2 -0
  73. package/out-tsc/vitest/src/__tests__/expect.test.d.ts.map +1 -0
  74. package/out-tsc/vitest/src/__tests__/spy.test.d.ts +2 -0
  75. package/out-tsc/vitest/src/__tests__/spy.test.d.ts.map +1 -0
  76. package/out-tsc/vitest/src/bundler/bundle.d.ts +2 -0
  77. package/out-tsc/vitest/src/bundler/bundle.d.ts.map +1 -0
  78. package/out-tsc/vitest/src/bundler/errors.d.ts +15 -0
  79. package/out-tsc/vitest/src/bundler/errors.d.ts.map +1 -0
  80. package/out-tsc/vitest/src/bundler/evaluate.d.ts +2 -0
  81. package/out-tsc/vitest/src/bundler/evaluate.d.ts.map +1 -0
  82. package/out-tsc/vitest/src/bundler/factory.d.ts +3 -0
  83. package/out-tsc/vitest/src/bundler/factory.d.ts.map +1 -0
  84. package/out-tsc/vitest/src/bundler/index.d.ts +4 -0
  85. package/out-tsc/vitest/src/bundler/index.d.ts.map +1 -0
  86. package/out-tsc/vitest/src/bundler/types.d.ts +7 -0
  87. package/out-tsc/vitest/src/bundler/types.d.ts.map +1 -0
  88. package/out-tsc/vitest/src/client/factory.d.ts +2 -0
  89. package/out-tsc/vitest/src/client/factory.d.ts.map +1 -0
  90. package/out-tsc/vitest/src/client/getDeviceDescriptor.d.ts +8 -0
  91. package/out-tsc/vitest/src/client/getDeviceDescriptor.d.ts.map +1 -0
  92. package/out-tsc/vitest/src/client/getWSServer.d.ts +2 -0
  93. package/out-tsc/vitest/src/client/getWSServer.d.ts.map +1 -0
  94. package/out-tsc/vitest/src/client/index.d.ts +2 -0
  95. package/out-tsc/vitest/src/client/index.d.ts.map +1 -0
  96. package/out-tsc/vitest/src/collector/errors.d.ts +8 -0
  97. package/out-tsc/vitest/src/collector/errors.d.ts.map +1 -0
  98. package/out-tsc/vitest/src/collector/factory.d.ts +3 -0
  99. package/out-tsc/vitest/src/collector/factory.d.ts.map +1 -0
  100. package/out-tsc/vitest/src/collector/functions.d.ts +22 -0
  101. package/out-tsc/vitest/src/collector/functions.d.ts.map +1 -0
  102. package/out-tsc/vitest/src/collector/index.d.ts +5 -0
  103. package/out-tsc/vitest/src/collector/index.d.ts.map +1 -0
  104. package/out-tsc/vitest/src/collector/types.d.ts +10 -0
  105. package/out-tsc/vitest/src/collector/types.d.ts.map +1 -0
  106. package/out-tsc/vitest/src/collector/validation.d.ts +4 -0
  107. package/out-tsc/vitest/src/collector/validation.d.ts.map +1 -0
  108. package/out-tsc/vitest/src/constants.d.ts +3 -0
  109. package/out-tsc/vitest/src/constants.d.ts.map +1 -0
  110. package/out-tsc/vitest/src/entry-point.d.ts +2 -0
  111. package/out-tsc/vitest/src/entry-point.d.ts.map +1 -0
  112. package/out-tsc/vitest/src/errors.d.ts +6 -0
  113. package/out-tsc/vitest/src/errors.d.ts.map +1 -0
  114. package/out-tsc/vitest/src/expect/index.d.ts +9 -0
  115. package/out-tsc/vitest/src/expect/index.d.ts.map +1 -0
  116. package/out-tsc/vitest/src/expect/setup.d.ts +2 -0
  117. package/out-tsc/vitest/src/expect/setup.d.ts.map +1 -0
  118. package/out-tsc/vitest/src/filtering/index.d.ts +2 -0
  119. package/out-tsc/vitest/src/filtering/index.d.ts.map +1 -0
  120. package/out-tsc/vitest/src/filtering/testNameFilter.d.ts +12 -0
  121. package/out-tsc/vitest/src/filtering/testNameFilter.d.ts.map +1 -0
  122. package/out-tsc/vitest/src/globals.d.ts +8 -0
  123. package/out-tsc/vitest/src/globals.d.ts.map +1 -0
  124. package/out-tsc/vitest/src/index.d.ts +9 -0
  125. package/out-tsc/vitest/src/index.d.ts.map +1 -0
  126. package/out-tsc/vitest/src/initialize.d.ts +2 -0
  127. package/out-tsc/vitest/src/initialize.d.ts.map +1 -0
  128. package/out-tsc/vitest/src/mocker/index.d.ts +2 -0
  129. package/out-tsc/vitest/src/mocker/index.d.ts.map +1 -0
  130. package/out-tsc/vitest/src/mocker/registry.d.ts +7 -0
  131. package/out-tsc/vitest/src/mocker/registry.d.ts.map +1 -0
  132. package/out-tsc/vitest/src/mocker/types.d.ts +6 -0
  133. package/out-tsc/vitest/src/mocker/types.d.ts.map +1 -0
  134. package/out-tsc/vitest/src/namespace.d.ts +18 -0
  135. package/out-tsc/vitest/src/namespace.d.ts.map +1 -0
  136. package/out-tsc/vitest/src/runner/errors.d.ts +11 -0
  137. package/out-tsc/vitest/src/runner/errors.d.ts.map +1 -0
  138. package/out-tsc/vitest/src/runner/factory.d.ts +3 -0
  139. package/out-tsc/vitest/src/runner/factory.d.ts.map +1 -0
  140. package/out-tsc/vitest/src/runner/hooks.d.ts +4 -0
  141. package/out-tsc/vitest/src/runner/hooks.d.ts.map +1 -0
  142. package/out-tsc/vitest/src/runner/index.d.ts +4 -0
  143. package/out-tsc/vitest/src/runner/index.d.ts.map +1 -0
  144. package/out-tsc/vitest/src/runner/runSuite.d.ts +4 -0
  145. package/out-tsc/vitest/src/runner/runSuite.d.ts.map +1 -0
  146. package/out-tsc/vitest/src/runner/types.d.ts +13 -0
  147. package/out-tsc/vitest/src/runner/types.d.ts.map +1 -0
  148. package/out-tsc/vitest/src/spy/index.d.ts +2 -0
  149. package/out-tsc/vitest/src/spy/index.d.ts.map +1 -0
  150. package/out-tsc/vitest/src/symbolicate.d.ts +3 -0
  151. package/out-tsc/vitest/src/symbolicate.d.ts.map +1 -0
  152. package/out-tsc/vitest/src/ui/ReadyScreen.d.ts +2 -0
  153. package/out-tsc/vitest/src/ui/ReadyScreen.d.ts.map +1 -0
  154. package/out-tsc/vitest/src/ui/WrongEnvironmentScreen.d.ts +2 -0
  155. package/out-tsc/vitest/src/ui/WrongEnvironmentScreen.d.ts.map +1 -0
  156. package/out-tsc/vitest/src/ui/index.d.ts +2 -0
  157. package/out-tsc/vitest/src/ui/index.d.ts.map +1 -0
  158. package/out-tsc/vitest/src/ui/state.d.ts +7 -0
  159. package/out-tsc/vitest/src/ui/state.d.ts.map +1 -0
  160. package/out-tsc/vitest/src/utils/dev-server.d.ts +2 -0
  161. package/out-tsc/vitest/src/utils/dev-server.d.ts.map +1 -0
  162. package/out-tsc/vitest/src/utils/emitter.d.ts +16 -0
  163. package/out-tsc/vitest/src/utils/emitter.d.ts.map +1 -0
  164. package/out-tsc/vitest/src/waitFor.d.ts +21 -0
  165. package/out-tsc/vitest/src/waitFor.d.ts.map +1 -0
  166. package/out-tsc/vitest/tsconfig.spec.tsbuildinfo +1 -0
  167. package/out-tsc/vitest/vite.config.d.ts +3 -0
  168. package/out-tsc/vitest/vite.config.d.ts.map +1 -0
  169. package/package.json +10 -4
  170. package/src/__tests__/collector.test.ts +55 -55
  171. package/src/__tests__/error-handling.test.ts +34 -34
  172. package/src/__tests__/expect.test.ts +13 -5
  173. package/src/bundler/bundle.ts +1 -2
  174. package/src/bundler/evaluate.ts +9 -9
  175. package/src/client/factory.ts +30 -14
  176. package/src/client/setup-files.ts +81 -0
  177. package/src/collector/functions.ts +4 -2
  178. package/src/collector/types.ts +4 -1
  179. package/src/entry-point.ts +8 -0
  180. package/src/expect/index.ts +8 -2
  181. package/src/expect/setup.ts +3 -0
  182. package/src/filtering/index.ts +4 -1
  183. package/src/filtering/testNameFilter.ts +53 -8
  184. package/src/globals.ts +14 -2
  185. package/src/index.ts +1 -0
  186. package/src/initialize.ts +11 -1
  187. package/src/jest-mock.ts +32 -0
  188. package/src/mocker/metro-require.d.ts +1 -0
  189. package/src/react-native.d.ts +2 -10
  190. package/src/render/ErrorBoundary.tsx +108 -0
  191. package/src/render/TestComponentOverlay.tsx +47 -0
  192. package/src/render/cleanup.ts +7 -0
  193. package/src/render/index.ts +96 -0
  194. package/src/render/setup.ts +8 -0
  195. package/src/render/types.ts +11 -0
  196. package/src/runner/factory.ts +8 -1
  197. package/src/symbolicate.ts +6 -4
  198. package/src/ui/ReadyScreen.tsx +2 -0
  199. package/src/ui/state.ts +39 -0
  200. package/src/utils/emitter.ts +1 -0
  201. package/src/waitFor.ts +6 -1
  202. package/tsconfig.spec.json +7 -3
  203. package/tsconfig.tsbuildinfo +1 -1
  204. package/dist/utils/progressLogger.d.ts +0 -8
  205. package/dist/utils/progressLogger.d.ts.map +0 -1
  206. package/dist/utils/progressLogger.js +0 -79
  207. package/src/utils/progressLogger.ts +0 -98
  208. package/types/global.d.ts +0 -2
  209. package/types/index.d.ts +0 -1
package/dist/ui/state.js CHANGED
@@ -1,6 +1,28 @@
1
1
  import { create, useStore } from 'zustand/react';
2
+ import { shallow } from 'zustand/shallow';
3
+ import { useStoreWithEqualityFn } from 'zustand/traditional';
4
+ const generateRenderKey = () => {
5
+ return `render-${Date.now()}-${Math.random().toString(36).slice(2, 9)}`;
6
+ };
2
7
  export const store = create((set) => ({
3
8
  status: 'loading',
4
9
  setStatus: (status) => set({ status }),
10
+ renderedElement: null,
11
+ setRenderedElement: (element) => set({
12
+ renderedElement: element,
13
+ renderKey: generateRenderKey(),
14
+ }),
15
+ updateRenderedElement: (element) => set({
16
+ renderedElement: element,
17
+ }),
18
+ renderKey: null,
19
+ onLayoutCallback: null,
20
+ setOnLayoutCallback: (callback) => set({ onLayoutCallback: callback }),
21
+ onRenderCallback: null,
22
+ setOnRenderCallback: (callback) => set({ onRenderCallback: callback }),
5
23
  }));
6
24
  export const useRunnerStatus = () => useStore(store, (state) => state.status);
25
+ export const useRenderedElement = () => useStoreWithEqualityFn(store, (state) => ({
26
+ element: state.renderedElement,
27
+ key: state.renderKey,
28
+ }), shallow);
@@ -1 +1 @@
1
- {"version":3,"file":"emitter.d.ts","sourceRoot":"","sources":["../../src/utils/emitter.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,CAAC,MAAM,IAAI,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;AAE5D,MAAM,MAAM,YAAY,CAAC,OAAO,IAAI;IAClC,WAAW,EAAE,CAAC,QAAQ,EAAE,aAAa,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC;IACxD,cAAc,EAAE,CAAC,QAAQ,EAAE,aAAa,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC;IAC3D,IAAI,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IAC/B,iBAAiB,EAAE,MAAM,IAAI,CAAC;CAC/B,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,OAAO;4BAIN,aAAa,CAAC,OAAO,CAAC;+BAGnB,aAAa,CAAC,OAAO,CAAC;kBAGnC,OAAO;;CAOxB,CAAC;AAEF,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,QAAQ,EACrD,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,EAChC,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,GAC/B,YAAY,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC;AACrC,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAC/D,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,EAChC,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,EAChC,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,GAC/B,YAAY,CAAC,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC,CAAC"}
1
+ {"version":3,"file":"emitter.d.ts","sourceRoot":"","sources":["../../src/utils/emitter.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,CAAC,MAAM,IAAI,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;AAE5D,MAAM,MAAM,YAAY,CAAC,OAAO,IAAI;IAClC,WAAW,EAAE,CAAC,QAAQ,EAAE,aAAa,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC;IACxD,cAAc,EAAE,CAAC,QAAQ,EAAE,aAAa,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC;IAC3D,IAAI,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IAC/B,iBAAiB,EAAE,MAAM,IAAI,CAAC;CAC/B,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,OAAO;4BAIN,aAAa,CAAC,OAAO,CAAC;+BAGnB,aAAa,CAAC,OAAO,CAAC;kBAGnC,OAAO;;CAOxB,CAAC;AAGF,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,QAAQ,EACrD,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,EAChC,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,GAC/B,YAAY,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC;AACrC,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAC/D,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,EAChC,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,EAChC,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,GAC/B,YAAY,CAAC,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"waitFor.d.ts","sourceRoot":"","sources":["../src/waitFor.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,eAAe,CAAC,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAEtD,MAAM,WAAW,cAAc;IAC7B;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AASD,wBAAgB,OAAO,CAAC,CAAC,EACvB,QAAQ,EAAE,eAAe,CAAC,CAAC,CAAC,EAC5B,OAAO,GAAE,MAAM,GAAG,cAAmB,GACpC,OAAO,CAAC,CAAC,CAAC,CA4EZ;AAED,MAAM,MAAM,iBAAiB,CAAC,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAExD,MAAM,WAAW,gBACf,SAAQ,IAAI,CAAC,cAAc,EAAE,UAAU,GAAG,SAAS,CAAC;CAAG;AAEzD,KAAK,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,KAAK,GAAG,EAAE,GAAG,CAAC,GAAG,IAAI,GAAG,SAAS,GAAG,KAAK,GAAG,CAAC,CAAC;AAEzE,wBAAgB,SAAS,CAAC,CAAC,EACzB,QAAQ,EAAE,iBAAiB,CAAC,CAAC,CAAC,EAC9B,OAAO,GAAE,MAAM,GAAG,gBAAqB,GACtC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CA6EpB"}
1
+ {"version":3,"file":"waitFor.d.ts","sourceRoot":"","sources":["../src/waitFor.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,eAAe,CAAC,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAEtD,MAAM,WAAW,cAAc;IAC7B;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AASD,wBAAgB,OAAO,CAAC,CAAC,EACvB,QAAQ,EAAE,eAAe,CAAC,CAAC,CAAC,EAC5B,OAAO,GAAE,MAAM,GAAG,cAAmB,GACpC,OAAO,CAAC,CAAC,CAAC,CA8EZ;AAED,MAAM,MAAM,iBAAiB,CAAC,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAGxD,MAAM,WAAW,gBACf,SAAQ,IAAI,CAAC,cAAc,EAAE,UAAU,GAAG,SAAS,CAAC;CAAG;AAEzD,KAAK,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,KAAK,GAAG,EAAE,GAAG,CAAC,GAAG,IAAI,GAAG,SAAS,GAAG,KAAK,GAAG,CAAC,CAAC;AAEzE,wBAAgB,SAAS,CAAC,CAAC,EACzB,QAAQ,EAAE,iBAAiB,CAAC,CAAC,CAAC,EAC9B,OAAO,GAAE,MAAM,GAAG,gBAAqB,GACtC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CA+EpB"}
package/dist/waitFor.js CHANGED
@@ -12,7 +12,9 @@ export function waitFor(callback, options = {}) {
12
12
  return new Promise((resolve, reject) => {
13
13
  let lastError;
14
14
  let promiseStatus = 'idle';
15
+ // eslint-disable-next-line prefer-const
15
16
  let timeoutId;
17
+ // eslint-disable-next-line prefer-const
16
18
  let intervalId;
17
19
  const onResolve = (result) => {
18
20
  if (timeoutId) {
@@ -73,7 +75,9 @@ export function waitUntil(callback, options = {}) {
73
75
  const STACK_TRACE_ERROR = new Error('STACK_TRACE_ERROR');
74
76
  return new Promise((resolve, reject) => {
75
77
  let promiseStatus = 'idle';
78
+ // eslint-disable-next-line prefer-const
76
79
  let timeoutId;
80
+ // eslint-disable-next-line prefer-const
77
81
  let intervalId;
78
82
  const onReject = (error) => {
79
83
  if (intervalId) {
package/eslint.config.mjs CHANGED
@@ -5,12 +5,6 @@ export default [
5
5
  ...baseConfig,
6
6
  ...nx.configs['flat/react'],
7
7
  {
8
- files: ['./src/rntl/**/*.ts'],
9
- rules: {
10
- 'react-hooks/rules-of-hooks': 'off',
11
- },
12
- },
13
- {
14
- ignores: ['public', '.cache', 'node_modules'],
8
+ ignores: ['public', '.cache', 'node_modules', 'assets'],
15
9
  },
16
10
  ];
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=collector.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collector.test.d.ts","sourceRoot":"","sources":["../../../../src/__tests__/collector.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=error-handling.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error-handling.test.d.ts","sourceRoot":"","sources":["../../../../src/__tests__/error-handling.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=expect.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"expect.test.d.ts","sourceRoot":"","sources":["../../../../src/__tests__/expect.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=spy.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spy.test.d.ts","sourceRoot":"","sources":["../../../../src/__tests__/spy.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export declare const fetchModule: (fileName: string) => Promise<string>;
2
+ //# sourceMappingURL=bundle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bundle.d.ts","sourceRoot":"","sources":["../../../../src/bundler/bundle.ts"],"names":[],"mappings":"AAgBA,eAAO,MAAM,WAAW,GAAU,UAAU,MAAM,KAAG,OAAO,CAAC,MAAM,CAUlE,CAAC"}
@@ -0,0 +1,15 @@
1
+ export declare class ModuleNotFoundError extends Error {
2
+ readonly modulePath: string;
3
+ constructor(modulePath: string);
4
+ }
5
+ export declare class MalformedModuleError extends Error {
6
+ readonly modulePath: string;
7
+ readonly reason: string;
8
+ constructor(modulePath: string, reason: string);
9
+ }
10
+ export declare class BundlingFailedError extends Error {
11
+ readonly modulePath: string;
12
+ readonly reason: string;
13
+ constructor(modulePath: string, reason: string);
14
+ }
15
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../../src/bundler/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,mBAAoB,SAAQ,KAAK;aAChB,UAAU,EAAE,MAAM;gBAAlB,UAAU,EAAE,MAAM;CAI/C;AAED,qBAAa,oBAAqB,SAAQ,KAAK;aAE3B,UAAU,EAAE,MAAM;aAClB,MAAM,EAAE,MAAM;gBADd,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM;CAKjC;AAED,qBAAa,mBAAoB,SAAQ,KAAK;aAE1B,UAAU,EAAE,MAAM;aAClB,MAAM,EAAE,MAAM;gBADd,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM;CAKjC"}
@@ -0,0 +1,2 @@
1
+ export declare const evaluateModule: (moduleJs: string, modulePath: string) => void;
2
+ //# sourceMappingURL=evaluate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evaluate.d.ts","sourceRoot":"","sources":["../../../../src/bundler/evaluate.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,cAAc,GAAI,UAAU,MAAM,EAAE,YAAY,MAAM,KAAG,IAqBrE,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Bundler } from './types.js';
2
+ export declare const getBundler: () => Bundler;
3
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../../src/bundler/factory.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAIrC,eAAO,MAAM,UAAU,QAAO,OAoC7B,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { evaluateModule } from './evaluate.js';
2
+ export { getBundler } from './factory.js';
3
+ export type { Bundler } from './types.js';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/bundler/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,YAAY,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { BundlerEvents } from '@react-native-harness/bridge';
2
+ import { EventEmitter } from '../utils/emitter.js';
3
+ export type Bundler = {
4
+ events: EventEmitter<BundlerEvents>;
5
+ getModule: (filePath: string) => Promise<string>;
6
+ };
7
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/bundler/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,MAAM,MAAM,OAAO,GAAG;IACpB,MAAM,EAAE,YAAY,CAAC,aAAa,CAAC,CAAC;IACpC,SAAS,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;CAClD,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const getClient: () => Promise<import("@react-native-harness/bridge/client").BridgeClient>;
2
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../../src/client/factory.ts"],"names":[],"mappings":"AAeA,eAAO,MAAM,SAAS,2EA+DrB,CAAC"}
@@ -0,0 +1,8 @@
1
+ export type DeviceDescriptor = {
2
+ platform: 'ios' | 'android' | 'vega';
3
+ manufacturer: string;
4
+ model: string;
5
+ osVersion: string;
6
+ };
7
+ export declare const getDeviceDescriptor: () => DeviceDescriptor;
8
+ //# sourceMappingURL=getDeviceDescriptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getDeviceDescriptor.d.ts","sourceRoot":"","sources":["../../../../src/client/getDeviceDescriptor.ts"],"names":[],"mappings":"AAYA,MAAM,MAAM,gBAAgB,GAAG;IAC7B,QAAQ,EAAE,KAAK,GAAG,SAAS,GAAG,MAAM,CAAC;IACrC,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,mBAAmB,QAAO,gBA+BtC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const getWSServer: () => string;
2
+ //# sourceMappingURL=getWSServer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getWSServer.d.ts","sourceRoot":"","sources":["../../../../src/client/getWSServer.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,WAAW,QAAO,MAK9B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { getClient } from './factory.js';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/client/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1,8 @@
1
+ export type TestErrorCode = 'CONTEXT_NOT_INITIALIZED' | 'OUTSIDE_DESCRIBE_BLOCK' | 'INVALID_TEST_NAME' | 'DUPLICATE_TEST_NAME' | 'INVALID_FUNCTION';
2
+ export declare class TestError extends Error {
3
+ code: TestErrorCode;
4
+ functionName: string;
5
+ context?: Record<string, unknown> | undefined;
6
+ constructor(code: TestErrorCode, functionName: string, context?: Record<string, unknown> | undefined);
7
+ }
8
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../../src/collector/errors.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GACrB,yBAAyB,GACzB,wBAAwB,GACxB,mBAAmB,GACnB,qBAAqB,GACrB,kBAAkB,CAAC;AAEvB,qBAAa,SAAU,SAAQ,KAAK;IAEzB,IAAI,EAAE,aAAa;IACnB,YAAY,EAAE,MAAM;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;gBAFjC,IAAI,EAAE,aAAa,EACnB,YAAY,EAAE,MAAM,EACpB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,YAAA;CAe3C"}
@@ -0,0 +1,3 @@
1
+ import { TestCollector } from './types.js';
2
+ export declare const getTestCollector: () => TestCollector;
3
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../../src/collector/factory.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C,eAAO,MAAM,gBAAgB,QAAO,aA0BnC,CAAC"}
@@ -0,0 +1,22 @@
1
+ import type { CollectionResult } from '@react-native-harness/bridge';
2
+ import type { TestFn } from './types.js';
3
+ export declare const describe: ((name: string, fn: () => void) => void) & {
4
+ skip: (name: string, fn: () => void) => void;
5
+ only: (name: string, fn: () => void) => void;
6
+ };
7
+ export declare const test: ((name: string, fn: TestFn) => void) & {
8
+ skip: (name: string, fn: TestFn) => void;
9
+ only: (name: string, fn: TestFn) => void;
10
+ todo: (name: string) => void;
11
+ };
12
+ export declare const it: ((name: string, fn: TestFn) => void) & {
13
+ skip: (name: string, fn: TestFn) => void;
14
+ only: (name: string, fn: TestFn) => void;
15
+ todo: (name: string) => void;
16
+ };
17
+ export declare function beforeAll(fn: TestFn): void;
18
+ export declare function afterAll(fn: TestFn): void;
19
+ export declare function beforeEach(fn: TestFn): void;
20
+ export declare function afterEach(fn: TestFn): void;
21
+ export declare const collectTests: (fn: () => void) => CollectionResult;
22
+ //# sourceMappingURL=functions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"functions.d.ts","sourceRoot":"","sources":["../../../../src/collector/functions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAGV,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AACtC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AA4LzC,eAAO,MAAM,QAAQ,UACZ,MAAM,MAAM,MAAM,IAAI;iBAsBd,MAAM,MAAM,MAAM,IAAI;iBAqBtB,MAAM,MAAM,MAAM,IAAI;CAsBtC,CAAC;AAEF,eAAO,MAAM,IAAI,UACR,MAAM,MAAM,MAAM;iBAaV,MAAM,MAAM,MAAM;iBAWlB,MAAM,MAAM,MAAM;iBAWlB,MAAM;CAiBtB,CAAC;AAEF,eAAO,MAAM,EAAE,UAtDN,MAAM,MAAM,MAAM;iBAaV,MAAM,MAAM,MAAM;iBAWlB,MAAM,MAAM,MAAM;iBAWlB,MAAM;CAmBD,CAAC;AAEvB,wBAAgB,SAAS,CAAC,EAAE,EAAE,MAAM,QAQnC;AAED,wBAAgB,QAAQ,CAAC,EAAE,EAAE,MAAM,QAQlC;AAED,wBAAgB,UAAU,CAAC,EAAE,EAAE,MAAM,QAQpC;AAED,wBAAgB,SAAS,CAAC,EAAE,EAAE,MAAM,QAQnC;AAgBD,eAAO,MAAM,YAAY,GAAI,IAAI,MAAM,IAAI,KAAG,gBAiB7C,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { describe, test, it, beforeAll, afterAll, beforeEach, afterEach, } from './functions.js';
2
+ export { TestError, type TestErrorCode } from './errors.js';
3
+ export type { TestCollector, TestCollectorEventsEmitter } from './types.js';
4
+ export { getTestCollector } from './factory.js';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/collector/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EACR,IAAI,EACJ,EAAE,EACF,SAAS,EACT,QAAQ,EACR,UAAU,EACV,SAAS,GACV,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5D,YAAY,EAAE,aAAa,EAAE,0BAA0B,EAAE,MAAM,YAAY,CAAC;AAC5E,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { EventEmitter } from '../utils/emitter.js';
2
+ import { TestCollectorEvents, CollectionResult } from '@react-native-harness/bridge';
3
+ export type TestFn = () => void | Promise<void>;
4
+ export type TestCollectorEventsEmitter = EventEmitter<TestCollectorEvents>;
5
+ export type TestCollector = {
6
+ events: TestCollectorEventsEmitter;
7
+ collect: (fn: () => void, testFilePath: string) => Promise<CollectionResult>;
8
+ dispose: () => void;
9
+ };
10
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/collector/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EACL,mBAAmB,EACnB,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AAEtC,MAAM,MAAM,MAAM,GAAG,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;AAEhD,MAAM,MAAM,0BAA0B,GAAG,YAAY,CAAC,mBAAmB,CAAC,CAAC;AAE3E,MAAM,MAAM,aAAa,GAAG;IAC1B,MAAM,EAAE,0BAA0B,CAAC;IACnC,OAAO,EAAE,CAAC,EAAE,EAAE,MAAM,IAAI,EAAE,YAAY,EAAE,MAAM,KAAK,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAC7E,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { TestFn } from './types.js';
2
+ export declare const validateTestName: (name: string, functionName: string) => void;
3
+ export declare const validateTestFunction: (fn: TestFn, functionName: string) => void;
4
+ //# sourceMappingURL=validation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../../../src/collector/validation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAEpC,eAAO,MAAM,gBAAgB,GAAI,MAAM,MAAM,EAAE,cAAc,MAAM,KAAG,IAMrE,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAC/B,IAAI,MAAM,EACV,cAAc,MAAM,KACnB,IAMF,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare const LOGO_IMAGE: any;
2
+ export declare const WS_SERVER_PORT = 3001;
3
+ //# sourceMappingURL=constants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,UAAU,KAAgC,CAAC;AACxD,eAAO,MAAM,cAAc,OAAO,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=entry-point.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entry-point.d.ts","sourceRoot":"","sources":["../../../src/entry-point.ts"],"names":[],"mappings":""}
@@ -0,0 +1,6 @@
1
+ export declare class EnvironmentError extends Error {
2
+ readonly context: string;
3
+ readonly details?: string | undefined;
4
+ constructor(context: string, details?: string | undefined);
5
+ }
6
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../src/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,gBAAiB,SAAQ,KAAK;aAEvB,OAAO,EAAE,MAAM;aACf,OAAO,CAAC,EAAE,MAAM;gBADhB,OAAO,EAAE,MAAM,EACf,OAAO,CAAC,EAAE,MAAM,YAAA;CAQnC"}
@@ -0,0 +1,9 @@
1
+ import type { ExpectStatic } from '@vitest/expect';
2
+ import * as chai from 'chai';
3
+ import './setup.js';
4
+ export declare function createExpect(): ExpectStatic;
5
+ declare const globalExpect: ExpectStatic;
6
+ export { assert, should } from 'chai';
7
+ export { chai, globalExpect as expect };
8
+ export type { Assertion, AsymmetricMatchersContaining, DeeplyAllowMatchers, ExpectStatic, JestAssertion, Matchers, } from '@vitest/expect';
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/expect/index.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAa,YAAY,EAAgB,MAAM,gBAAgB,CAAC;AAS5E,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAG7B,OAAO,YAAY,CAAC;AAEpB,wBAAgB,YAAY,IAAI,YAAY,CAqF3C;AAED,QAAA,MAAM,YAAY,EAAE,YAA6B,CAAC;AAQlD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,EAAE,IAAI,EAAE,YAAY,IAAI,MAAM,EAAE,CAAC;AAExC,YAAY,EACV,SAAS,EACT,4BAA4B,EAC5B,mBAAmB,EACnB,YAAY,EACZ,aAAa,EACb,QAAQ,GACT,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=setup.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../../../src/expect/setup.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export { filterTestsByName, markTestsAsSkippedByName, } from './testNameFilter.js';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/filtering/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,wBAAwB,GACzB,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,12 @@
1
+ import { TestSuite } from '@react-native-harness/bridge';
2
+ /**
3
+ * Filters tests by name pattern, matching against test names and suite+test combinations
4
+ * @deprecated Use markTestsAsSkippedByName instead - this function will be removed in a future version
5
+ */
6
+ export declare const filterTestsByName: (suite: TestSuite, testNamePattern: string) => TestSuite;
7
+ /**
8
+ * Marks tests as skipped based on name pattern, keeping all tests in the structure
9
+ * but setting non-matching tests to 'skipped' status
10
+ */
11
+ export declare const markTestsAsSkippedByName: (suite: TestSuite, testNamePattern: string) => TestSuite;
12
+ //# sourceMappingURL=testNameFilter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"testNameFilter.d.ts","sourceRoot":"","sources":["../../../../src/filtering/testNameFilter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAEzD;;;GAGG;AACH,eAAO,MAAM,iBAAiB,GAC5B,OAAO,SAAS,EAChB,iBAAiB,MAAM,KACtB,SAGF,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,wBAAwB,GACnC,OAAO,SAAS,EAChB,iBAAiB,MAAM,KACtB,SAGF,CAAC"}
@@ -0,0 +1,8 @@
1
+ export type HarnessGlobal = {
2
+ appRegistryComponentName: string;
3
+ };
4
+ declare global {
5
+ var RN_HARNESS: HarnessGlobal | undefined;
6
+ }
7
+ export declare const getHarnessGlobal: () => HarnessGlobal;
8
+ //# sourceMappingURL=globals.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"globals.d.ts","sourceRoot":"","sources":["../../../src/globals.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GAAG;IAC1B,wBAAwB,EAAE,MAAM,CAAC;CAClC,CAAC;AAEF,OAAO,CAAC,MAAM,CAAC;IACb,IAAI,UAAU,EAAE,aAAa,GAAG,SAAS,CAAC;CAC3C;AAED,eAAO,MAAM,gBAAgB,QAAO,aAQnC,CAAC"}
@@ -0,0 +1,9 @@
1
+ import './globals.d.ts';
2
+ export { UI as ReactNativeHarness } from './ui/index.js';
3
+ export * from './spy/index.js';
4
+ export * from './expect/index.js';
5
+ export * from './collector/index.js';
6
+ export * from './mocker/index.js';
7
+ export * from './namespace.js';
8
+ export * from './waitFor.js';
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,gBAAgB,CAAC;AAExB,OAAO,EAAE,EAAE,IAAI,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACzD,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=initialize.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"initialize.d.ts","sourceRoot":"","sources":["../../../src/initialize.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export { mock, requireActual, clearMocks, unmock, resetModules, } from './registry.js';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/mocker/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,IAAI,EACJ,aAAa,EACb,UAAU,EACV,MAAM,EACN,YAAY,GACb,MAAM,eAAe,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { ModuleFactory } from './types.js';
2
+ export declare const mock: (moduleId: string, factory: ModuleFactory) => void;
3
+ export declare const clearMocks: () => void;
4
+ export declare const requireActual: <T = any>(moduleId: string) => T;
5
+ export declare const unmock: (moduleId: string) => void;
6
+ export declare const resetModules: () => void;
7
+ //# sourceMappingURL=registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../../../src/mocker/registry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAqB,MAAM,YAAY,CAAC;AAO9D,eAAO,MAAM,IAAI,GAAI,UAAU,MAAM,EAAE,SAAS,aAAa,KAAG,IAG/D,CAAC;AAEF,eAAO,MAAM,UAAU,QAAO,IAG7B,CAAC;AAkBF,eAAO,MAAM,aAAa,GAAI,CAAC,GAAG,GAAG,EAAE,UAAU,MAAM,KAAG,CAEH,CAAC;AAExD,eAAO,MAAM,MAAM,GAAI,UAAU,MAAM,SAGtC,CAAC;AAEF,eAAO,MAAM,YAAY,QAAO,IAK/B,CAAC"}
@@ -0,0 +1,6 @@
1
+ export type ModuleId = number;
2
+ export type Require = {
3
+ (moduleId: number): unknown;
4
+ };
5
+ export type ModuleFactory = () => unknown;
6
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/mocker/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC;AAC9B,MAAM,MAAM,OAAO,GAAG;IACpB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC"}
@@ -0,0 +1,18 @@
1
+ import { spyOn, fn, clearAllMocks, resetAllMocks, restoreAllMocks } from './spy/index.js';
2
+ import { mock, unmock, requireActual, resetModules } from './mocker/index.js';
3
+ import { waitFor, waitUntil } from './waitFor.js';
4
+ export type HarnessNamespace = {
5
+ spyOn: typeof spyOn;
6
+ fn: typeof fn;
7
+ mock: typeof mock;
8
+ unmock: typeof unmock;
9
+ requireActual: typeof requireActual;
10
+ clearAllMocks: typeof clearAllMocks;
11
+ resetAllMocks: typeof resetAllMocks;
12
+ restoreAllMocks: typeof restoreAllMocks;
13
+ resetModules: typeof resetModules;
14
+ waitFor: typeof waitFor;
15
+ waitUntil: typeof waitUntil;
16
+ };
17
+ export declare const harness: HarnessNamespace;
18
+ //# sourceMappingURL=namespace.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EACL,EAAE,EACF,aAAa,EACb,aAAa,EACb,eAAe,EAChB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAC9E,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAElD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,KAAK,EAAE,OAAO,KAAK,CAAC;IACpB,EAAE,EAAE,OAAO,EAAE,CAAC;IACd,IAAI,EAAE,OAAO,IAAI,CAAC;IAClB,MAAM,EAAE,OAAO,MAAM,CAAC;IACtB,aAAa,EAAE,OAAO,aAAa,CAAC;IACpC,aAAa,EAAE,OAAO,aAAa,CAAC;IACpC,aAAa,EAAE,OAAO,aAAa,CAAC;IACpC,eAAe,EAAE,OAAO,eAAe,CAAC;IACxC,YAAY,EAAE,OAAO,YAAY,CAAC;IAClC,OAAO,EAAE,OAAO,OAAO,CAAC;IACxB,SAAS,EAAE,OAAO,SAAS,CAAC;CAC7B,CAAC;AAkBF,eAAO,MAAM,OAAO,kBAA2B,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type { SerializedError, CodeFrame } from '@react-native-harness/bridge';
2
+ export declare class TestExecutionError extends Error {
3
+ file: string;
4
+ suite: string;
5
+ test: string;
6
+ codeFrame?: CodeFrame;
7
+ constructor(error: unknown, file: string, suite: string, test: string, codeFrame?: CodeFrame);
8
+ toSerializedJSON(): SerializedError;
9
+ }
10
+ export declare const getTestExecutionError: (error: unknown, file: string, suite: string, test: string) => Promise<TestExecutionError>;
11
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../../src/runner/errors.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAG/E,qBAAa,kBAAmB,SAAQ,KAAK;IAC3C,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,SAAS,CAAC;gBAGpB,KAAK,EAAE,OAAO,EACd,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,MAAM,EACZ,SAAS,CAAC,EAAE,SAAS;IAWvB,gBAAgB,IAAI,eAAe;CAapC;AAED,eAAO,MAAM,qBAAqB,GAChC,OAAO,OAAO,EACd,MAAM,MAAM,EACZ,OAAO,MAAM,EACb,MAAM,MAAM,KACX,OAAO,CAAC,kBAAkB,CAe5B,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { TestRunner } from './types.js';
2
+ export declare const getTestRunner: () => TestRunner;
3
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../../src/runner/factory.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAExC,eAAO,MAAM,aAAa,QAAO,UAehC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { TestSuite } from '@react-native-harness/bridge';
2
+ export type HookType = 'beforeEach' | 'afterEach' | 'beforeAll' | 'afterAll';
3
+ export declare const runHooks: (suite: TestSuite, hookType: HookType) => Promise<void>;
4
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../../src/runner/hooks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAE9D,MAAM,MAAM,QAAQ,GAAG,YAAY,GAAG,WAAW,GAAG,WAAW,GAAG,UAAU,CAAC;AAuC7E,eAAO,MAAM,QAAQ,GACnB,OAAO,SAAS,EAChB,UAAU,QAAQ,KACjB,OAAO,CAAC,IAAI,CAMd,CAAC"}
@@ -0,0 +1,4 @@
1
+ export type { TestRunnerEventsEmitter, TestRunner, TestRunnerContext, } from './types.js';
2
+ export { TestExecutionError } from './errors.js';
3
+ export { getTestRunner } from './factory.js';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/runner/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,uBAAuB,EACvB,UAAU,EACV,iBAAiB,GAClB,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { TestSuite, TestSuiteResult } from '@react-native-harness/bridge';
2
+ import { TestRunnerContext } from './types.js';
3
+ export declare const runSuite: (suite: TestSuite, context: TestRunnerContext) => Promise<TestSuiteResult>;
4
+ //# sourceMappingURL=runSuite.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runSuite.d.ts","sourceRoot":"","sources":["../../../../src/runner/runSuite.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAGV,SAAS,EACT,eAAe,EAChB,MAAM,8BAA8B,CAAC;AAGtC,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAsH/C,eAAO,MAAM,QAAQ,GACnB,OAAO,SAAS,EAChB,SAAS,iBAAiB,KACzB,OAAO,CAAC,eAAe,CAoIzB,CAAC"}
@@ -0,0 +1,13 @@
1
+ import { EventEmitter } from '../utils/emitter.js';
2
+ import type { TestRunnerEvents, TestSuite, TestSuiteResult } from '@react-native-harness/bridge';
3
+ export type TestRunnerEventsEmitter = EventEmitter<TestRunnerEvents>;
4
+ export type TestRunnerContext = {
5
+ events: TestRunnerEventsEmitter;
6
+ testFilePath: string;
7
+ };
8
+ export type TestRunner = {
9
+ events: TestRunnerEventsEmitter;
10
+ run: (testSuite: TestSuite, testFilePath: string) => Promise<TestSuiteResult>;
11
+ dispose: () => void;
12
+ };
13
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/runner/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EACV,gBAAgB,EAChB,SAAS,EACT,eAAe,EAChB,MAAM,8BAA8B,CAAC;AAEtC,MAAM,MAAM,uBAAuB,GAAG,YAAY,CAAC,gBAAgB,CAAC,CAAC;AAErE,MAAM,MAAM,iBAAiB,GAAG;IAC9B,MAAM,EAAE,uBAAuB,CAAC;IAChC,YAAY,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG;IACvB,MAAM,EAAE,uBAAuB,CAAC;IAChC,GAAG,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,KAAK,OAAO,CAAC,eAAe,CAAC,CAAC;IAC9E,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from '@vitest/spy';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/spy/index.ts"],"names":[],"mappings":"AACA,cAAc,aAAa,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { CodeFrame } from '@react-native-harness/bridge';
2
+ export declare const getCodeFrame: (error: Error) => Promise<CodeFrame | null>;
3
+ //# sourceMappingURL=symbolicate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"symbolicate.d.ts","sourceRoot":"","sources":["../../../src/symbolicate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAI9D,eAAO,MAAM,YAAY,GAAU,OAAO,KAAK,KAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAmBzE,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const ReadyScreen: () => import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=ReadyScreen.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReadyScreen.d.ts","sourceRoot":"","sources":["../../../../src/ui/ReadyScreen.tsx"],"names":[],"mappings":"AAcA,eAAO,MAAM,WAAW,+CAkCvB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const WrongEnvironmentScreen: () => import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=WrongEnvironmentScreen.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WrongEnvironmentScreen.d.ts","sourceRoot":"","sources":["../../../../src/ui/WrongEnvironmentScreen.tsx"],"names":[],"mappings":"AAUA,eAAO,MAAM,sBAAsB,+CAoBlC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const UI: any;
2
+ //# sourceMappingURL=index.d.ts.map