detox 21.0.0-breaking.new-global-lifecycle.0 → 21.0.1-rc.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (304) hide show
  1. package/.eslintrc.js +2 -7
  2. package/Detox-android/com/wix/detox/{21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-javadoc.jar → 21.0.1-rc.0/detox-21.0.1-rc.0-javadoc.jar} +0 -0
  3. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0-javadoc.jar.md5 +1 -0
  4. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0-javadoc.jar.sha1 +1 -0
  5. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0-javadoc.jar.sha256 +1 -0
  6. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0-javadoc.jar.sha512 +1 -0
  7. package/Detox-android/com/wix/detox/{21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-sources.jar → 21.0.1-rc.0/detox-21.0.1-rc.0-sources.jar} +0 -0
  8. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0-sources.jar.md5 +1 -0
  9. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0-sources.jar.sha1 +1 -0
  10. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0-sources.jar.sha256 +1 -0
  11. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0-sources.jar.sha512 +1 -0
  12. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.aar +0 -0
  13. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.aar.md5 +1 -0
  14. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.aar.sha1 +1 -0
  15. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.aar.sha256 +1 -0
  16. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.aar.sha512 +1 -0
  17. package/Detox-android/com/wix/detox/{21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.pom → 21.0.1-rc.0/detox-21.0.1-rc.0.pom} +22 -10
  18. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.pom.md5 +1 -0
  19. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.pom.sha1 +1 -0
  20. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.pom.sha256 +1 -0
  21. package/Detox-android/com/wix/detox/21.0.1-rc.0/detox-21.0.1-rc.0.pom.sha512 +1 -0
  22. package/Detox-android/com/wix/detox/maven-metadata.xml +4 -4
  23. package/Detox-android/com/wix/detox/maven-metadata.xml.md5 +1 -1
  24. package/Detox-android/com/wix/detox/maven-metadata.xml.sha1 +1 -1
  25. package/Detox-android/com/wix/detox/maven-metadata.xml.sha256 +1 -1
  26. package/Detox-android/com/wix/detox/maven-metadata.xml.sha512 +1 -1
  27. package/Detox-ios-framework.tbz +0 -0
  28. package/Detox-ios-src.tbz +0 -0
  29. package/Detox-ios-xcuitest.tbz +0 -0
  30. package/README.md +1 -1
  31. package/android/build.gradle +13 -8
  32. package/android/detox/build.gradle +24 -13
  33. package/android/detox/proguard-rules-app.pro +6 -0
  34. package/android/detox/proguard-rules.pro +3 -0
  35. package/android/detox/publish-pom.gradle +5 -1
  36. package/android/detox/publishing.gradle +35 -33
  37. package/android/detox/src/full/java/com/wix/detox/DetoxCrashHandler.kt +1 -1
  38. package/android/detox/src/full/java/com/wix/detox/LaunchArgs.java +9 -0
  39. package/android/detox/src/full/java/com/wix/detox/TestEngineFacade.kt +4 -4
  40. package/android/detox/src/full/java/com/wix/detox/adapters/server/QueryStatusActionHandler.kt +12 -80
  41. package/android/detox/src/full/java/com/wix/detox/adapters/server/WebSocketClient.java +3 -1
  42. package/android/detox/src/full/java/com/wix/detox/common/UIExtensions.kt +28 -0
  43. package/android/detox/src/full/java/com/wix/detox/espresso/DetoxAction.java +37 -3
  44. package/android/detox/src/full/java/com/wix/detox/espresso/DetoxMatcher.java +11 -1
  45. package/android/detox/src/full/java/com/wix/detox/espresso/UiAutomatorHelper.java +1 -1
  46. package/android/detox/src/full/java/com/wix/detox/espresso/action/AdjustSliderToPositionAction.kt +22 -0
  47. package/android/detox/src/{main → full}/java/com/wix/detox/espresso/action/GetAttributesAction.kt +17 -4
  48. package/android/detox/src/full/java/com/wix/detox/espresso/action/RNDetoxAccessibilityAction.kt +46 -0
  49. package/android/detox/src/full/java/com/wix/detox/espresso/common/SliderHelper.kt +75 -0
  50. package/android/detox/src/full/java/com/wix/detox/espresso/common/UiControllerImplReflected.kt +16 -0
  51. package/android/detox/src/full/java/com/wix/detox/espresso/idlingresources/DescriptiveIdlingResource.kt +8 -0
  52. package/android/detox/src/full/java/com/wix/detox/espresso/matcher/ViewMatchers.kt +24 -28
  53. package/android/detox/src/full/java/com/wix/detox/espresso/matcher/WithAccessibilityLabelMatcher.kt +23 -0
  54. package/android/detox/src/full/java/com/wix/detox/espresso/registry/BusyResourcesInquirer.kt +48 -0
  55. package/android/detox/src/full/java/com/wix/detox/inquiry/DetoxBusyResource.kt +92 -0
  56. package/android/detox/src/full/java/com/wix/detox/inquiry/DetoxBusyResourceDescription.kt +26 -0
  57. package/android/detox/src/full/java/com/wix/detox/reactnative/ReactNativeExtension.kt +15 -2
  58. package/android/detox/src/full/java/com/wix/detox/reactnative/ReactNativeIdlingResources.kt +43 -38
  59. package/android/detox/src/full/java/com/wix/detox/reactnative/ReactNativeLoadingMonitor.kt +54 -8
  60. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/AnimatedModuleIdlingResource.java +18 -7
  61. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/AsyncStorageIdlingResource.kt +3 -4
  62. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/BridgeIdlingResource.java +12 -6
  63. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/DetoxBaseIdlingResource.java +2 -0
  64. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/NetworkIdlingResource.java +43 -34
  65. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/timers/DelegatedIdleInterrogationStrategy.kt +7 -27
  66. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/timers/IdleInterrogationStrategy.kt +1 -11
  67. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/timers/TimersIdlingResource.kt +2 -6
  68. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/uimodule/RN66Workaround.kt +13 -4
  69. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/uimodule/UIManagerModuleReflected.kt +1 -1
  70. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/uimodule/UIModuleIdlingResource.kt +4 -6
  71. package/android/detox/src/full/java/com/wix/detox/reactnative/ui/UIExtensions.kt +37 -0
  72. package/android/detox/src/full/java/com/wix/detox/reactnative/utils/RNUtils.kt +6 -0
  73. package/android/detox/src/main/java/com/wix/detox/common/DetoxErrors.java +4 -1
  74. package/android/detox/src/main/java/com/wix/detox/common/TextFileReader.kt +1 -1
  75. package/android/detox/src/main/java/com/wix/detox/espresso/UiControllerSpy.kt +2 -1
  76. package/android/detox/src/main/java/com/wix/detox/espresso/action/common/ReflectUtils.kt +10 -0
  77. package/android/detox/src/main/java/com/wix/detox/espresso/action/common/utils/UiControllerUtils.kt +1 -1
  78. package/android/detox/src/testFull/java/com/wix/detox/UTHelpers.kt +12 -0
  79. package/android/detox/src/testFull/java/com/wix/detox/adapters/server/QueryStatusActionHandlerSpec.kt +35 -94
  80. package/android/detox/src/testFull/java/com/wix/detox/common/UIExtensionsTest.kt +107 -0
  81. package/android/detox/src/testFull/java/com/wix/detox/espresso/action/DetoxMultiTapSpec.kt +4 -3
  82. package/android/detox/src/testFull/java/com/wix/detox/espresso/action/GetAttributesActionTest.kt +22 -9
  83. package/android/detox/src/testFull/java/com/wix/detox/espresso/common/SliderHelperTest.kt +39 -0
  84. package/android/detox/src/testFull/java/com/wix/detox/espresso/matcher/ViewAtIndexMatcherSpec.kt +1 -2
  85. package/android/detox/src/testFull/java/com/wix/detox/espresso/registry/{IRStatusInquirerTest.kt → BusyResourcesInquirerTest.kt} +46 -7
  86. package/android/detox/src/testFull/java/com/wix/detox/{reactnative/idlingresources/IdlingResourceDescriptionSpec.kt → inquiry/DetoxBusyResourceDescriptionSpec.kt} +6 -6
  87. package/android/detox/src/testFull/java/com/wix/detox/inquiry/DetoxBusyResourceSpec.kt +134 -0
  88. package/android/detox/src/testFull/java/com/wix/detox/reactnative/idlingresources/AsyncStorageIdlingResourceSpec.kt +4 -5
  89. package/android/detox/src/testFull/java/com/wix/detox/reactnative/idlingresources/NetworkIdlingResourcesTest.kt +61 -0
  90. package/android/detox/src/testFull/java/com/wix/detox/reactnative/idlingresources/timers/DelegatedIdleInterrogationStrategySpec.kt +3 -11
  91. package/android/detox/src/testFull/java/com/wix/detox/reactnative/idlingresources/timers/TimersIdlingResourceSpec.kt +4 -6
  92. package/android/gradle/wrapper/gradle-wrapper.properties +2 -1
  93. package/android/gradlew +181 -107
  94. package/index.d.ts +239 -83
  95. package/index.js +12 -1
  96. package/internals.d.ts +219 -45
  97. package/internals.js +10 -3
  98. package/local-cli/build-framework-cache.js +1 -1
  99. package/local-cli/build-xcuitest-cache.js +16 -0
  100. package/local-cli/build.js +2 -2
  101. package/local-cli/clean-framework-cache.js +1 -1
  102. package/local-cli/clean-xcuitest-cache.js +19 -0
  103. package/local-cli/cli.js +13 -7
  104. package/local-cli/init.js +61 -21
  105. package/local-cli/rebuild-framework-cache.js +4 -4
  106. package/local-cli/rebuild-xcuitest-cache.js +21 -0
  107. package/local-cli/reset-lock-file.js +16 -0
  108. package/local-cli/run-server.js +12 -1
  109. package/local-cli/start.js +49 -0
  110. package/local-cli/startCommand/AppStartCommand.js +65 -0
  111. package/local-cli/templates/jest.js +13 -10
  112. package/local-cli/test.js +14 -8
  113. package/local-cli/testCommand/TestRunnerCommand.js +126 -77
  114. package/local-cli/testCommand/TestRunnerError.js +13 -0
  115. package/local-cli/testCommand/builder.js +5 -1
  116. package/local-cli/testCommand/middlewares.js +4 -13
  117. package/local-cli/testCommand/warnings.js +0 -3
  118. package/local-cli/utils/cliErrorHandling.js +15 -0
  119. package/local-cli/utils/jestInternals.js +4 -1
  120. package/package.json +46 -26
  121. package/runners/deprecation.js +42 -44
  122. package/runners/jest/globalSetup.js +1 -1
  123. package/runners/jest/globalTeardown.js +1 -1
  124. package/runners/jest/index.d.ts +61 -0
  125. package/runners/jest/index.js +3 -8
  126. package/runners/jest/reporters/DetoxReporter.js +33 -2
  127. package/runners/jest/testEnvironment/index.js +119 -68
  128. package/runners/jest/testEnvironment/listeners/DetoxCoreListener.js +97 -51
  129. package/runners/jest/testEnvironment/listeners/DetoxPlatformFilterListener.js +1 -1
  130. package/runners/jest/testEnvironment/listeners/SpecReporter.js +15 -17
  131. package/runners/jest/testEnvironment/listeners/WorkerAssignReporter.js +3 -7
  132. package/runners/jest/testEnvironment/utils/assertJestCircus27.js +17 -3
  133. package/scripts/build_framework.ios.sh +26 -60
  134. package/scripts/build_local_framework.ios.sh +62 -0
  135. package/scripts/build_local_xcuitest.ios.sh +53 -0
  136. package/scripts/build_xcuitest.ios.sh +23 -0
  137. package/scripts/pack_ios.sh +14 -5
  138. package/scripts/postinstall.js +10 -4
  139. package/src/DetoxWorker.js +112 -64
  140. package/src/android/actions/native.js +16 -0
  141. package/src/android/core/NativeElement.js +72 -20
  142. package/src/android/core/NativeExpect.js +28 -9
  143. package/src/android/core/NativeMatcher.js +31 -10
  144. package/src/android/core/NativeWaitFor.js +8 -0
  145. package/src/android/espressoapi/DetoxAction.js +37 -0
  146. package/src/android/espressoapi/DetoxMatcher.js +24 -0
  147. package/src/android/espressoapi/EspressoDetox.js +1 -1
  148. package/src/android/espressoapi/web/WebElement.js +1 -1
  149. package/src/android/interactions/native.js +25 -18
  150. package/src/android/matchers/index.js +2 -2
  151. package/src/android/matchers/native.js +10 -3
  152. package/src/artifacts/ArtifactsManager.js +14 -47
  153. package/src/artifacts/instruments/ios/SimulatorInstrumentsRecording.js +3 -3
  154. package/src/artifacts/log/android/ADBLogcatRecording.js +11 -28
  155. package/src/artifacts/log/ios/SimulatorLogRecording.js +1 -1
  156. package/src/artifacts/screenshot/SimulatorScreenshotPlugin.js +1 -1
  157. package/src/artifacts/templates/artifact/Artifact.js +1 -1
  158. package/src/artifacts/templates/plugin/ArtifactPlugin.js +2 -2
  159. package/src/artifacts/templates/plugin/TwoSnapshotsPerTestPlugin.js +2 -1
  160. package/src/artifacts/templates/plugin/WholeTestRecorderPlugin.js +3 -2
  161. package/src/artifacts/timeline/TimelineContextTypes.js +7 -0
  162. package/src/artifacts/utils/temporaryPath.js +47 -8
  163. package/src/artifacts/video/SimulatorRecordVideoPlugin.js +1 -1
  164. package/src/client/AsyncWebSocket.js +11 -19
  165. package/src/client/Client.js +35 -3
  166. package/src/client/actions/SyncStatusSchema.json +21 -0
  167. package/src/client/actions/actions.js +38 -0
  168. package/src/client/actions/formatters/SyncStatusFormatter.js +2 -0
  169. package/src/client/actions/formatters/sync-resources/BgThreadFormatter.js +5 -0
  170. package/src/client/actions/formatters/sync-resources/NetworkFormatter.js +1 -1
  171. package/src/configuration/collectCliConfig.js +3 -13
  172. package/src/configuration/composeAppsConfig.js +5 -1
  173. package/src/configuration/composeDeviceConfig.js +1 -1
  174. package/src/configuration/composeLoggerConfig.js +20 -10
  175. package/src/configuration/composeRunnerConfig.js +62 -9
  176. package/src/configuration/index.js +14 -9
  177. package/src/configuration/loadExternalConfig.js +1 -1
  178. package/src/devices/allocation/DeviceAllocator.js +15 -2
  179. package/src/devices/allocation/drivers/AllocationDriverBase.js +10 -2
  180. package/src/devices/allocation/drivers/android/attached/AttachedAndroidAllocDriver.js +10 -1
  181. package/src/devices/allocation/drivers/android/emulator/AVDValidator.js +5 -5
  182. package/src/devices/allocation/drivers/android/emulator/EmulatorAllocDriver.js +28 -29
  183. package/src/devices/allocation/drivers/android/emulator/EmulatorAllocationHelper.js +1 -1
  184. package/src/devices/allocation/drivers/android/emulator/EmulatorLauncher.js +6 -5
  185. package/src/devices/allocation/drivers/android/emulator/EmulatorVersionResolver.js +4 -6
  186. package/src/devices/allocation/drivers/android/emulator/launchEmulatorProcess.js +4 -17
  187. package/src/devices/allocation/drivers/android/genycloud/GenyAllocDriver.js +27 -18
  188. package/src/devices/allocation/drivers/android/genycloud/GenyInstanceAllocationHelper.js +1 -1
  189. package/src/devices/allocation/drivers/ios/SimulatorAllocDriver.js +12 -7
  190. package/src/devices/allocation/factories/base.js +1 -1
  191. package/src/devices/common/drivers/android/exec/ADB.js +9 -0
  192. package/src/devices/common/drivers/android/genycloud/exec/GenyCloudExec.js +1 -1
  193. package/src/devices/common/drivers/android/genycloud/services/GenyInstanceNaming.js +3 -3
  194. package/src/devices/common/drivers/android/genycloud/services/GenyRecipesService.js +1 -1
  195. package/src/devices/common/drivers/android/tools/AppInstallHelper.js +4 -4
  196. package/src/devices/common/drivers/android/tools/EmulatorTelnet.js +1 -1
  197. package/src/devices/common/drivers/android/tools/{FileXfer.js → FileTransfer.js} +2 -2
  198. package/src/devices/common/drivers/android/tools/FreeDeviceFinder.js +1 -1
  199. package/src/devices/common/drivers/android/tools/MonitoredInstrumentation.js +1 -1
  200. package/src/devices/common/drivers/android/tools/TempFileTransfer.js +14 -0
  201. package/src/devices/common/drivers/ios/tools/AppleSimUtils.js +21 -4
  202. package/src/devices/lifecycle/GenyGlobalLifecycleHandler.js +13 -15
  203. package/src/devices/runtime/RuntimeDevice.js +24 -12
  204. package/src/devices/runtime/drivers/DeviceDriverBase.js +2 -1
  205. package/src/devices/runtime/drivers/android/AndroidDriver.js +17 -8
  206. package/src/devices/runtime/drivers/ios/SimulatorDriver.js +42 -2
  207. package/src/devices/runtime/drivers/ios/XCUITestUtils.js +209 -0
  208. package/src/devices/runtime/drivers/ios/allowNetworkPermissionsXCUITest.scpt +14 -0
  209. package/src/devices/runtime/factories/android.js +6 -5
  210. package/src/devices/runtime/factories/base.js +3 -2
  211. package/src/errors/DetoxConfigErrorComposer.js +18 -3
  212. package/src/errors/DetoxError.js +5 -1
  213. package/src/ios/expectTwo.js +199 -78
  214. package/src/ipc/IPCClient.js +36 -27
  215. package/src/ipc/IPCServer.js +40 -21
  216. package/src/ipc/SessionState.js +60 -0
  217. package/src/logger/DetoxLogger.js +287 -154
  218. package/src/logger/index.js +5 -0
  219. package/src/logger/utils/BunyanLogger.js +105 -0
  220. package/src/logger/utils/CategoryThreadDispatcher.js +37 -0
  221. package/src/logger/utils/DetoxLogFinalizer.js +166 -0
  222. package/src/logger/utils/MessageStack.js +35 -0
  223. package/src/logger/utils/ThreadDispatcher.js +61 -0
  224. package/src/logger/{customConsoleLogger.js → utils/customConsoleLogger.js} +23 -6
  225. package/src/logger/utils/getMainCategory.js +5 -0
  226. package/src/logger/utils/sanitizeBunyanContext.js +30 -0
  227. package/src/logger/utils/streams/BunyanTransformer.js +72 -0
  228. package/src/logger/utils/streams/ChromeTraceTransformer.js +132 -0
  229. package/src/logger/utils/streams/DetoxJSONLParser.js +31 -0
  230. package/src/logger/utils/streams/JSONLStringer.js +55 -0
  231. package/src/logger/utils/streams/index.js +7 -0
  232. package/src/logger/utils/streams/transformers.js +39 -0
  233. package/src/logger/utils/tracerLegacy.js +37 -0
  234. package/src/realms/DetoxContext.js +83 -66
  235. package/src/realms/DetoxInternalsFacade.js +9 -13
  236. package/src/realms/DetoxPrimaryContext.js +117 -74
  237. package/src/realms/DetoxSecondaryContext.js +32 -35
  238. package/src/{symbols.js → realms/symbols.js} +16 -22
  239. package/src/server/DetoxConnection.js +18 -23
  240. package/src/server/DetoxServer.js +7 -10
  241. package/src/server/DetoxSession.js +9 -6
  242. package/src/server/DetoxSessionManager.js +2 -1
  243. package/src/server/handlers/AnonymousConnectionHandler.js +1 -0
  244. package/src/server/handlers/RegisteredConnectionHandler.js +1 -2
  245. package/src/servicelocator/android/index.js +2 -2
  246. package/src/utils/ExclusiveLockfile.js +1 -0
  247. package/src/utils/Timer.js +59 -36
  248. package/src/utils/argparse.js +11 -27
  249. package/src/utils/childProcess/exec.js +4 -2
  250. package/src/utils/childProcess/spawn.js +1 -1
  251. package/src/utils/dateUtils.js +5 -0
  252. package/src/utils/environment.js +55 -16
  253. package/src/utils/errorUtils.js +24 -3
  254. package/src/utils/invocationTraceDescriptions.js +44 -0
  255. package/src/utils/isPromise.js +8 -1
  256. package/src/utils/logger.js +2 -2
  257. package/src/utils/pathUtils.js +11 -0
  258. package/src/utils/shellUtils.js +17 -0
  259. package/src/utils/traceInvocationCall.js +21 -0
  260. package/src/utils/traceMethods.js +15 -0
  261. package/src/validation/ios/IosSimulatorEnvValidator.js +7 -4
  262. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-javadoc.jar.md5 +0 -1
  263. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-javadoc.jar.sha1 +0 -1
  264. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-javadoc.jar.sha256 +0 -1
  265. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-javadoc.jar.sha512 +0 -1
  266. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-sources.jar.md5 +0 -1
  267. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-sources.jar.sha1 +0 -1
  268. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-sources.jar.sha256 +0 -1
  269. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0-sources.jar.sha512 +0 -1
  270. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.aar +0 -0
  271. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.aar.md5 +0 -1
  272. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.aar.sha1 +0 -1
  273. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.aar.sha256 +0 -1
  274. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.aar.sha512 +0 -1
  275. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.pom.md5 +0 -1
  276. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.pom.sha1 +0 -1
  277. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.pom.sha256 +0 -1
  278. package/Detox-android/com/wix/detox/21.0.0-breaking.new-global-lifecycle.0/detox-21.0.0-breaking.new-global-lifecycle.0.pom.sha512 +0 -1
  279. package/Detox-ios.tbz +0 -0
  280. package/android/detox/src/full/java/com/wix/detox/espresso/registry/IRStatusInquirer.kt +0 -24
  281. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/DescriptiveIdlingResource.kt +0 -10
  282. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/IdlingResourceDescription.kt +0 -20
  283. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/timers/DefaultIdleInterrogationStrategy.kt +0 -84
  284. package/android/detox/src/main/java/com/wix/detox/espresso/action/AdjustSliderToPositionAction.kt +0 -36
  285. package/android/detox/src/testFull/java/com/wix/detox/espresso/action/AdjustSliderToPositionActionTest.kt +0 -59
  286. package/android/detox/src/testFull/java/com/wix/detox/reactnative/idlingresources/timers/DefaultIdleInterrogationStrategySpec.kt +0 -115
  287. package/local-cli/build.test.js +0 -104
  288. package/local-cli/run-server.test.js +0 -23
  289. package/local-cli/test.test.js +0 -515
  290. package/runners/jest/deprecation.js +0 -25
  291. package/runners/jest/testEnvironment/utils/assertJestCircus27.test.js +0 -23
  292. package/scripts/build_universal_framework.sh +0 -14
  293. package/scripts/build_universal_framework_legacy.sh +0 -76
  294. package/scripts/build_universal_framework_modern.sh +0 -28
  295. package/src/configuration/utils/warnings.js +0 -12
  296. package/src/devices/common/drivers/android/tools/TempFileXfer.js +0 -16
  297. package/src/ipc/state.js +0 -76
  298. package/src/logger/DetoxTraceEventBuilder.js +0 -21
  299. package/src/logger/DetoxTracer.js +0 -133
  300. package/src/logger/TraceThreadDispatcher.js +0 -52
  301. package/src/realms/index.js +0 -10
  302. package/src/utils/ChromeTracingExporter.js +0 -53
  303. package/src/utils/streamUtils.js +0 -214
  304. package/src/utils/trace.js +0 -19
@@ -0,0 +1,39 @@
1
+ const { PassThrough, Transform } = require('stream');
2
+
3
+ function through() {
4
+ return new PassThrough({ objectMode: true });
5
+ }
6
+
7
+ function mapTransform(fn) {
8
+ return new Transform({
9
+ objectMode: true,
10
+ transform(chunk, encoding, callback){
11
+ this.push(fn(chunk));
12
+ callback();
13
+ },
14
+ });
15
+ }
16
+
17
+ function flatMapTransform(fn) {
18
+ let index = 0;
19
+
20
+ return new Transform({
21
+ objectMode: true,
22
+ transform(chunk, encoding, callback){
23
+ const results = fn(chunk, index++);
24
+ // eslint-disable-next-line unicorn/no-array-method-this-argument
25
+ results.forEach(pushThis, this);
26
+ callback();
27
+ },
28
+ });
29
+ }
30
+
31
+ function pushThis(x) {
32
+ return this.push(x);
33
+ }
34
+
35
+ module.exports = {
36
+ through,
37
+ mapTransform,
38
+ flatMapTransform,
39
+ };
@@ -0,0 +1,37 @@
1
+ const methods = {
2
+ startSection(logger) {
3
+ return (msg, args) => {
4
+ if (args !== undefined) {
5
+ return logger.trace.begin(args, msg);
6
+ } else {
7
+ return logger.trace.begin(msg);
8
+ }
9
+ };
10
+ },
11
+
12
+ endSection(logger) {
13
+ return (_msg, args) => {
14
+ if (args !== undefined) {
15
+ return logger.trace.end(args);
16
+ } else {
17
+ return logger.trace.end();
18
+ }
19
+ };
20
+ },
21
+
22
+ traceCall(logger) {
23
+ return (name, action, args = {}) => logger.trace.complete(args, name, action);
24
+ },
25
+ };
26
+
27
+ function installLegacyTracerInterface(logger, target) {
28
+ target.traceCall = methods.traceCall(logger);
29
+ target.trace = Object.freeze({
30
+ startSection: methods.startSection(logger),
31
+ endSection: methods.endSection(logger),
32
+ });
33
+
34
+ return this;
35
+ }
36
+
37
+ module.exports = { install: installLegacyTracerInterface };
@@ -1,48 +1,71 @@
1
1
  const funpermaproxy = require('funpermaproxy');
2
2
 
3
+ const temporary = require('../artifacts/utils/temporaryPath');
3
4
  const { DetoxRuntimeError } = require('../errors');
4
- const DetoxLogger = require('../logger/DetoxLogger');
5
- const DetoxTracer = require('../logger/DetoxTracer');
6
- const symbols = require('../symbols');
5
+ const { DetoxLogger, DetoxLogFinalizer, installLegacyTracerInterface } = require('../logger');
7
6
 
8
7
  const DetoxConstants = require('./DetoxConstants');
8
+ const symbols = require('./symbols');
9
9
 
10
+ //#region Protected symbols
10
11
  const $cleanup = Symbol('cleanup');
11
- const $logger = Symbol('logger');
12
+ const $logFinalizer = Symbol('logFinalizer');
12
13
  const $restoreSessionState = Symbol('restoreSessionState');
13
14
  const $sessionState = Symbol('restoreSessionState');
14
- const $tracer = Symbol('tracer');
15
-
16
- const _worker = Symbol('worker');
15
+ const $status = Symbol('status');
16
+ const $worker = Symbol('worker');
17
+ //#endregion
17
18
 
18
19
  class DetoxContext {
19
20
  constructor() {
20
- this[symbols.globalSetup] = this[symbols.globalSetup].bind(this);
21
- this[symbols.globalTeardown] = this[symbols.globalTeardown].bind(this);
22
- this[symbols.reportFailedTests] = this[symbols.reportFailedTests].bind(this);
21
+ /** @type {DetoxInternals.DetoxStatus} */
22
+ this[$status] = 'inactive';
23
+
24
+ const _init = this[symbols.init].bind(this);
25
+ this[symbols.init] = async (opts) => {
26
+ this[$status] = 'init';
27
+ await _init(opts);
28
+ this[$status] = 'active';
29
+ };
30
+
31
+ const _cleanup = this[symbols.cleanup].bind(this);
32
+ this[symbols.cleanup] = async () => {
33
+ this[$status] = 'cleanup';
34
+ try {
35
+ await _cleanup();
36
+ } finally {
37
+ this[$status] = 'inactive';
38
+ }
39
+ };
40
+
41
+ this[symbols.getStatus] = this[symbols.getStatus].bind(this);
42
+ this[symbols.reportTestResults] = this[symbols.reportTestResults].bind(this);
23
43
  this[symbols.resolveConfig] = this[symbols.resolveConfig].bind(this);
24
- this[symbols.setup] = this[symbols.setup].bind(this);
25
- this[symbols.teardown] = this[symbols.teardown].bind(this);
44
+ this[symbols.installWorker] = this[symbols.installWorker].bind(this);
45
+ this[symbols.uninstallWorker] = this[symbols.uninstallWorker].bind(this);
26
46
 
27
47
  this[$sessionState] = this[$restoreSessionState]();
28
48
 
29
- const loggerConfig = this[$sessionState].detoxConfig
30
- ? this[$sessionState].detoxConfig.loggerConfig
31
- : undefined;
32
-
33
49
  /**
34
- * @protected
35
50
  * @type {DetoxLogger & Detox.Logger}
36
51
  */
37
- this[$logger] = new DetoxLogger(loggerConfig);
38
- /** @protected */
39
- this[$tracer] = DetoxTracer.default({
40
- logger: this[$logger],
52
+ this[symbols.logger] = new DetoxLogger({
53
+ file: temporary.for.jsonl(`${this[$sessionState].id}.${process.pid}`),
54
+ userConfig: this[$sessionState].detoxConfig
55
+ ? this[$sessionState].detoxConfig.logger
56
+ : null,
41
57
  });
42
- /** @deprecated */
43
- this.traceCall = this[$tracer].bind(this[$tracer]);
58
+
59
+ this.log = this[symbols.logger].child({ cat: 'user' });
60
+ installLegacyTracerInterface(this.log, this);
61
+
62
+ this[$logFinalizer] = new DetoxLogFinalizer({
63
+ session: this[$sessionState],
64
+ logger: this[symbols.logger],
65
+ });
66
+
44
67
  /** @type {import('../DetoxWorker') | null} */
45
- this[_worker] = null;
68
+ this[$worker] = null;
46
69
  }
47
70
 
48
71
  //#region Public members
@@ -62,91 +85,84 @@ class DetoxContext {
62
85
  return DetoxConstants;
63
86
  }
64
87
 
65
- /**
66
- * @returns {Detox.Logger}
67
- */
68
- get log() {
69
- return this[$logger];
70
- }
71
-
72
- /**
73
- * @returns {Detox.Tracer}
74
- */
75
- get trace() {
76
- return this[$tracer];
77
- }
78
88
  //#endregion
79
89
 
80
90
  //#region Internal members
81
- [symbols.onRunStart] = (...args) => this[symbols.worker].onRunStart(...args);
82
91
  [symbols.onRunDescribeStart] = (...args) => this[symbols.worker].onRunDescribeStart(...args);
83
92
  [symbols.onTestStart] = (...args) => this[symbols.worker].onTestStart(...args);
84
- [symbols.onHookStart] = (...args) => this[symbols.worker].onHookStart(...args);
85
93
  [symbols.onHookFailure] = (...args) => this[symbols.worker].onHookFailure(...args);
86
- [symbols.onHookSuccess] = (...args) => this[symbols.worker].onHookSuccess(...args);
87
- [symbols.onTestFnStart] = (...args) => this[symbols.worker].onTestFnStart(...args);
88
94
  [symbols.onTestFnFailure] = (...args) => this[symbols.worker].onTestFnFailure(...args);
89
- [symbols.onTestFnSuccess] = (...args) => this[symbols.worker].onTestFnSuccess(...args);
90
95
  [symbols.onTestDone] = (...args) => this[symbols.worker].onTestDone(...args);
91
96
  [symbols.onRunDescribeFinish] = (...args) => this[symbols.worker].onRunDescribeFinish(...args);
92
- [symbols.onRunFinish] = (...args) => this[symbols.worker].onRunFinish(...args);
93
97
  [symbols.config] = funpermaproxy(() => this[symbols.session].detoxConfig);
94
98
  [symbols.session] = funpermaproxy(() => this[$sessionState]);
99
+ [symbols.tracing] = Object.freeze({
100
+ createEventStream: () => this[$logFinalizer].createEventStream(),
101
+ });
95
102
  /** @abstract */
96
- [symbols.reportFailedTests](_testFilePaths) {}
103
+ [symbols.reportTestResults](_testResults) {}
97
104
  /**
98
105
  * @abstract
99
- * @param {Partial<DetoxInternals.DetoxGlobalSetupOptions>} _opts
106
+ * @param {Partial<DetoxInternals.DetoxInitOptions>} _opts
100
107
  * @returns {Promise<DetoxInternals.RuntimeConfig>}
101
108
  */
102
109
  async [symbols.resolveConfig](_opts) { return null; }
103
110
 
111
+ [symbols.getStatus]() {
112
+ return this[$status];
113
+ }
114
+
104
115
  get [symbols.worker]() {
105
- if (!this[_worker]) {
116
+ if (!this[$worker]) {
106
117
  throw new DetoxRuntimeError({
107
- message: `Detox worker instance has not been initialized in this context (${this.constructor.name}).`,
108
- hint: DetoxRuntimeError.reportIssueIfJest + '\n' + 'Otherwise, make sure you call detox.setup() beforehand.',
118
+ message: `Detox worker instance has not been installed in this context (${this.constructor.name}).`,
119
+ hint: DetoxRuntimeError.reportIssueIfJest + '\n' + 'Otherwise, make sure you call detox.installWorker() beforehand.',
109
120
  });
110
121
  }
111
122
 
112
- return this[_worker];
123
+ return this[$worker];
113
124
  }
114
125
 
115
126
  /**
116
127
  * @abstract
117
- * @param {Partial<DetoxInternals.DetoxGlobalSetupOptions>} [_opts]
128
+ * @param {Partial<DetoxInternals.DetoxInitOptions>} [_opts]
118
129
  * @returns {Promise<void>}
119
130
  */
120
- async [symbols.globalSetup](_opts = {}) {}
131
+ async [symbols.init](_opts = {}) {}
121
132
 
122
133
  /**
123
- * @param {Partial<DetoxInternals.DetoxConfigurationSetupOptions>} [opts]
134
+ * @param {Partial<DetoxInternals.DetoxInstallWorkerOptions>} [opts]
124
135
  */
125
- async [symbols.setup](opts) {
126
- const theGlobal = opts.global || global;
127
- theGlobal['__detox__'] = this;
128
- this[$logger].overrideConsole(theGlobal);
136
+ async [symbols.installWorker](opts) {
137
+ if (opts.global) {
138
+ opts.global['__detox__'] = {
139
+ clientApi: require('../../index'),
140
+ internalsApi: require('../../internals'),
141
+ };
142
+ this.log.overrideConsole(opts.global);
143
+ }
129
144
 
130
145
  const DetoxWorker = require('../DetoxWorker');
131
- DetoxWorker.global = theGlobal;
132
- this[_worker] = new DetoxWorker(this);
133
- await this[_worker].init();
146
+ DetoxWorker.global = opts.global || global;
147
+ this[$worker] = new DetoxWorker(this);
148
+ this[$worker].id = opts.workerId;
149
+ await this[$worker].init();
134
150
  }
135
151
 
136
- async [symbols.teardown]() {
152
+ async [symbols.uninstallWorker]() {
137
153
  try {
138
- if (this[_worker]) {
139
- await this[_worker].cleanup();
154
+ if (this[$worker]) {
155
+ await this[$worker].cleanup();
140
156
  }
141
157
  } finally {
142
- this[_worker] = null;
158
+ this[$worker] = null;
143
159
  }
144
160
  }
145
161
 
146
162
  /**
147
163
  * @abstract
148
164
  */
149
- async [symbols.globalTeardown]() {}
165
+ async [symbols.cleanup]() {}
150
166
  //#endregion
151
167
 
152
168
  //#region Protected members
@@ -163,8 +179,9 @@ class DetoxContext {
163
179
  module.exports = DetoxContext;
164
180
  module.exports.protected = {
165
181
  $cleanup,
166
- $logger,
182
+ $logFinalizer,
167
183
  $restoreSessionState,
184
+ $status,
168
185
  $sessionState,
169
- $tracer,
186
+ $worker,
170
187
  };
@@ -1,6 +1,6 @@
1
1
  const funpermaproxy = require('funpermaproxy');
2
2
 
3
- const symbols = require('../symbols');
3
+ const symbols = require('./symbols');
4
4
 
5
5
  class DetoxInternalsFacade {
6
6
  /**
@@ -8,26 +8,22 @@ class DetoxInternalsFacade {
8
8
  */
9
9
  constructor(context) {
10
10
  this.config = context[symbols.config];
11
- this.globalSetup = context[symbols.globalSetup];
12
- this.globalTeardown = context[symbols.globalTeardown];
13
- this.log = context.log;
14
- this.setup = context[symbols.setup];
15
- this.teardown = context[symbols.teardown];
11
+ this.getStatus = context[symbols.getStatus];
12
+ this.init = context[symbols.init];
13
+ this.cleanup = context[symbols.cleanup];
14
+ this.log = context[symbols.logger];
15
+ this.installWorker = context[symbols.installWorker];
16
+ this.uninstallWorker = context[symbols.uninstallWorker];
16
17
  this.onHookFailure = context[symbols.onHookFailure];
17
- this.onHookStart = context[symbols.onHookStart];
18
- this.onHookSuccess = context[symbols.onHookSuccess];
19
18
  this.onRunDescribeFinish = context[symbols.onRunDescribeFinish];
20
19
  this.onRunDescribeStart = context[symbols.onRunDescribeStart];
21
- this.onRunFinish = context[symbols.onRunFinish];
22
- this.onRunStart = context[symbols.onRunStart];
23
20
  this.onTestDone = context[symbols.onTestDone];
24
21
  this.onTestFnFailure = context[symbols.onTestFnFailure];
25
- this.onTestFnStart = context[symbols.onTestFnStart];
26
- this.onTestFnSuccess = context[symbols.onTestFnSuccess];
27
22
  this.onTestStart = context[symbols.onTestStart];
28
- this.reportFailedTests = context[symbols.reportFailedTests];
23
+ this.reportTestResults = context[symbols.reportTestResults];
29
24
  this.resolveConfig = context[symbols.resolveConfig];
30
25
  this.session = context[symbols.session];
26
+ this.tracing = context[symbols.tracing];
31
27
  this.worker = funpermaproxy(() => context[symbols.worker]);
32
28
  }
33
29
  }
@@ -1,24 +1,31 @@
1
- const path = require('path');
2
1
  const { URL } = require('url');
3
2
 
4
3
  const fs = require('fs-extra');
5
- const pipe = require('multipipe');
4
+ const onSignalExit = require('signal-exit');
6
5
 
7
6
  const temporary = require('../artifacts/utils/temporaryPath');
8
7
  const { DetoxRuntimeError } = require('../errors');
9
- const { PrimarySessionState } = require('../ipc/state');
10
- const symbols = require('../symbols');
8
+ const SessionState = require('../ipc/SessionState');
9
+ const { getCurrentCommand } = require('../utils/argparse');
10
+ const uuid = require('../utils/uuid');
11
11
 
12
12
  const DetoxContext = require('./DetoxContext');
13
+ const symbols = require('./symbols');
13
14
 
14
- const { $logger, $restoreSessionState, $sessionState } = DetoxContext.protected;
15
+ // Protected symbols
16
+ const { $logFinalizer, $restoreSessionState, $sessionState, $worker } = DetoxContext.protected;
15
17
 
16
- const _finalizeLogs = Symbol('finalizeLogs');
18
+ //#region Private symbols
17
19
  const _globalLifecycleHandler = Symbol('globalLifecycleHandler');
18
20
  const _ipcServer = Symbol('ipcServer');
19
21
  const _resetLockFile = Symbol('resetLockFile');
20
22
  const _wss = Symbol('wss');
21
23
  const _dirty = Symbol('dirty');
24
+ const _emergencyTeardown = Symbol('emergencyTeardown');
25
+ const _lifecycleLogger = Symbol('lifecycleLogger');
26
+ const _sessionFile = Symbol('sessionFile');
27
+ const _logFinalError = Symbol('logFinalError');
28
+ //#endregion
22
29
 
23
30
  class DetoxPrimaryContext extends DetoxContext {
24
31
  constructor() {
@@ -27,21 +34,26 @@ class DetoxPrimaryContext extends DetoxContext {
27
34
  this[_dirty] = false;
28
35
  this[_wss] = null;
29
36
  this[_globalLifecycleHandler] = null;
37
+ /** Path to file where the initial session object is serialized */
38
+ this[_sessionFile] = '';
30
39
  /**
31
40
  * @type {import('../ipc/IPCServer') | null}
32
41
  */
33
42
  this[_ipcServer] = null;
43
+ /** @type {Detox.Logger} */
44
+ this[_lifecycleLogger] = this[symbols.logger].child({ cat: 'lifecycle' });
34
45
  }
35
46
 
36
47
  //#region Internal members
37
- async [symbols.reportFailedTests](testFilePaths) {
48
+ async [symbols.reportTestResults](testResults) {
38
49
  if (this[_ipcServer]) {
39
- this[_ipcServer].onFailedTests({ testFilePaths });
50
+ this[_ipcServer].onReportTestResults({ testResults });
40
51
  }
41
52
  }
42
53
 
43
- async [symbols.resolveConfig](opts = {}) {
44
- const session = this[symbols.session];
54
+ async [symbols.resolveConfig](opts = { argv: { configuration: process.env.DETOX_DBG_SELECTED_CFG } })
55
+ {
56
+ const session = this[$sessionState];
45
57
  if (!session.detoxConfig) {
46
58
  const configuration = require('../configuration');
47
59
  session.detoxConfig = await configuration.composeDetoxConfig(opts);
@@ -52,9 +64,9 @@ class DetoxPrimaryContext extends DetoxContext {
52
64
 
53
65
  /**
54
66
  * @override
55
- * @param {Partial<DetoxInternals.DetoxGlobalSetupOptions>} [opts]
67
+ * @param {Partial<DetoxInternals.DetoxInitOptions>} [opts]
56
68
  */
57
- async [symbols.globalSetup](opts) {
69
+ async [symbols.init](opts = {}) {
58
70
  if (this[_dirty]) {
59
71
  throw new DetoxRuntimeError({
60
72
  message: 'Cannot initialize primary Detox context more than once.',
@@ -63,21 +75,28 @@ class DetoxPrimaryContext extends DetoxContext {
63
75
  }
64
76
 
65
77
  this[_dirty] = true;
78
+ onSignalExit(this[_emergencyTeardown]);
79
+
66
80
  const detoxConfig = await this[symbols.resolveConfig](opts);
67
81
 
68
- const { behaviorConfig, deviceConfig, loggerConfig, sessionConfig } = detoxConfig;
69
- await this[$logger].setConfig(loggerConfig);
82
+ const {
83
+ behavior: behaviorConfig,
84
+ device: deviceConfig,
85
+ logger: loggerConfig,
86
+ session: sessionConfig
87
+ } = detoxConfig;
88
+ await this[symbols.logger].setConfig(loggerConfig);
70
89
 
71
- this.trace.begin({
72
- cat: 'lifecycle',
73
- args: this[$sessionState],
74
- name: process.argv.slice(1).join(' '),
75
- });
90
+ this[_lifecycleLogger].trace.begin({
91
+ cwd: process.cwd(),
92
+ data: this[$sessionState],
93
+ }, getCurrentCommand());
76
94
 
95
+ // TODO: IPC Server creation ought to be delegated to a generator/factory.
77
96
  const IPCServer = require('../ipc/IPCServer');
78
97
  this[_ipcServer] = new IPCServer({
79
98
  sessionState: this[$sessionState],
80
- logger: this[$logger],
99
+ logger: this[symbols.logger],
81
100
  });
82
101
 
83
102
  await this[_ipcServer].init();
@@ -93,6 +112,7 @@ class DetoxPrimaryContext extends DetoxContext {
93
112
  await this[_resetLockFile]();
94
113
  }
95
114
 
115
+ // TODO: Detox-server creation ought to be delegated to a generator/factory.
96
116
  const DetoxServer = require('../server/DetoxServer');
97
117
  if (sessionConfig.autoStart) {
98
118
  this[_wss] = new DetoxServer({
@@ -105,106 +125,129 @@ class DetoxPrimaryContext extends DetoxContext {
105
125
  await this[_wss].open();
106
126
  }
107
127
 
128
+ // TODO: double check that this config is indeed propogated onto the client create at the detox-worker side
108
129
  if (!sessionConfig.server && this[_wss]) {
130
+ // @ts-ignore
109
131
  sessionConfig.server = `ws://localhost:${this[_wss].port}`;
110
132
  }
111
133
 
112
- await fs.writeFile(this[$sessionState].detoxConfigSnapshotPath, this[$sessionState].stringify());
113
- process.env.DETOX_CONFIG_SNAPSHOT_PATH = this[$sessionState].detoxConfigSnapshotPath;
134
+ this[_sessionFile] = temporary.for.json(this[$sessionState].id);
135
+ await fs.writeFile(this[_sessionFile], this[$sessionState].stringify());
136
+ process.env.DETOX_CONFIG_SNAPSHOT_PATH = this[_sessionFile];
137
+ this[_lifecycleLogger].trace(`Serialized the session state at: ${this[_sessionFile]}`);
114
138
 
115
- // TODO: think about signal-exit and cleaning up the logs
139
+ if (opts.workerId !== null) {
140
+ await this[symbols.installWorker](opts);
141
+ }
116
142
  }
117
143
 
118
144
  /**
119
145
  * @override
120
- * @param {Partial<DetoxInternals.DetoxConfigurationSetupOptions>} [opts]
146
+ * @param {Partial<DetoxInternals.DetoxInstallWorkerOptions>} [opts]
121
147
  */
122
- async [symbols.setup](opts) {
123
- const workerId = opts.workerId || 1;
148
+ async [symbols.installWorker](opts = {}) {
149
+ const workerId = opts.workerId || 'worker';
150
+
124
151
  this[$sessionState].workerId = workerId;
125
152
  this[_ipcServer].onRegisterWorker({ workerId });
126
- await super[symbols.setup](opts);
153
+
154
+ await super[symbols.installWorker]({ ...opts, workerId });
127
155
  }
128
156
 
129
157
  /** @override */
130
- async [symbols.globalTeardown]() {
158
+ async [symbols.cleanup]() {
159
+ try {
160
+ if (this[$worker]) {
161
+ await this[symbols.uninstallWorker]();
162
+ }
163
+ } finally {
164
+ if (this[_globalLifecycleHandler]) {
165
+ await this[_globalLifecycleHandler].globalCleanup();
166
+ this[_globalLifecycleHandler] = null;
167
+ }
168
+
169
+ if (this[_wss]) {
170
+ await this[_wss].close();
171
+ this[_wss] = null;
172
+ }
173
+
174
+ if (this[_ipcServer]) {
175
+ await this[_ipcServer].dispose();
176
+ this[_ipcServer] = null;
177
+ }
178
+
179
+ if (this[_sessionFile]) {
180
+ await fs.remove(this[_sessionFile]);
181
+ }
182
+
183
+ if (this[_dirty]) {
184
+ try {
185
+ this[_lifecycleLogger].trace.end();
186
+ await this[symbols.logger].close();
187
+ await this[$logFinalizer].finalize();
188
+ } catch (err) {
189
+ this[_logFinalError](err);
190
+ }
191
+ }
192
+ }
193
+ }
194
+
195
+ [_emergencyTeardown] = (_code, signal) => {
196
+ if (!signal) {
197
+ return;
198
+ }
199
+
131
200
  if (this[_globalLifecycleHandler]) {
132
- await this[_globalLifecycleHandler].globalCleanup();
201
+ this[_globalLifecycleHandler].emergencyCleanup();
133
202
  this[_globalLifecycleHandler] = null;
134
203
  }
135
204
 
136
205
  if (this[_wss]) {
137
- await this[_wss].close();
138
- this[_wss] = null;
206
+ this[_wss].close();
139
207
  }
140
208
 
141
209
  if (this[_ipcServer]) {
142
- await this[_ipcServer].dispose();
143
- this[_ipcServer] = null;
210
+ this[_ipcServer].dispose();
144
211
  }
145
212
 
146
- await fs.remove(this[$sessionState].detoxConfigSnapshotPath);
147
- delete process.env.DETOX_CONFIG_SNAPSHOT_PATH;
213
+ if (this[_sessionFile]) {
214
+ fs.removeSync(this[_sessionFile]);
215
+ }
148
216
 
149
217
  try {
150
- this.trace.end({ cat: 'lifecycle' });
151
- await this[_finalizeLogs]();
218
+ this[_lifecycleLogger].trace.end({ abortSignal: signal });
219
+ this[symbols.logger].close().catch(this[_logFinalError]);
220
+ this[$logFinalizer].finalizeSync();
152
221
  } catch (err) {
153
- this[$logger].error({ err }, 'Encountered an error while merging the process logs:');
222
+ this[_logFinalError](err);
154
223
  }
155
- }
224
+ };
225
+
226
+ [_logFinalError] = (err) => {
227
+ this[_lifecycleLogger].error(err, 'Encountered an error while merging the process logs:');
228
+ };
229
+
156
230
  //#endregion
157
231
 
158
232
  //#region Protected members
159
233
  /**
160
234
  * @protected
161
235
  * @override
162
- * @return {PrimarySessionState}
236
+ * @return {SessionState}
163
237
  */
164
238
  [$restoreSessionState]() {
165
- return new PrimarySessionState({
166
- detoxConfigSnapshotPath: temporary.for.json(),
239
+ return new SessionState({
240
+ id: uuid.UUID(),
167
241
  detoxIPCServer: `primary-${process.pid}`,
168
242
  });
169
243
  }
170
244
  //#endregion
171
245
 
172
246
  //#region Private members
173
- async[_finalizeLogs]() {
174
- const logs = [this[$logger].file, ...this[$sessionState].logFiles].filter(f => f && fs.existsSync(f));
175
- if (logs.length === 0) {
176
- return;
177
- }
178
-
179
- const streamUtils = require('../utils/streamUtils');
180
- const { rootDir, plugins } = this[symbols.config].artifactsConfig || {};
181
- const logConfig = plugins && plugins.log || 'none';
182
- const enabled = rootDir && (typeof logConfig === 'string' ? logConfig !== 'none' : logConfig.enabled);
183
-
184
- if (enabled) {
185
- await fs.mkdirp(rootDir);
186
- const [out1Stream, out2Stream, out3Stream] = ['detox.log.jsonl', 'detox.log', 'detox.trace.json']
187
- .map((filename) => fs.createWriteStream(path.join(rootDir, filename)));
188
-
189
- const mergedStream = streamUtils
190
- .mergeSortedJSONL(
191
- logs.map(filePath => fs.createReadStream(filePath).pipe(streamUtils.readJSONL()))
192
- );
193
-
194
- await Promise.all([
195
- pipe(mergedStream, streamUtils.writeJSONL(), out1Stream),
196
- pipe(mergedStream, streamUtils.debugStream(this[$logger].config.options), out2Stream),
197
- pipe(mergedStream, streamUtils.chromeTraceStream(), streamUtils.writeJSON(), out3Stream),
198
- ]);
199
- }
200
-
201
- await Promise.all(logs.map(filepath => fs.remove(filepath)));
202
- }
203
-
204
247
  async[_resetLockFile]() {
205
248
  const DeviceRegistry = require('../devices/DeviceRegistry');
206
249
 
207
- const deviceType = this[symbols.config].deviceConfig.type;
250
+ const deviceType = this[symbols.config].device.type;
208
251
 
209
252
  switch (deviceType) {
210
253
  case 'ios.none':