detox 20.1.0-next-is-hittable-check.0 → 20.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (144) hide show
  1. package/Detox-android/com/wix/detox/{20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-javadoc.jar → 20.1.0/detox-20.1.0-javadoc.jar} +0 -0
  2. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0-javadoc.jar.md5 +1 -0
  3. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0-javadoc.jar.sha1 +1 -0
  4. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0-javadoc.jar.sha256 +1 -0
  5. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0-javadoc.jar.sha512 +1 -0
  6. package/Detox-android/com/wix/detox/{20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-sources.jar → 20.1.0/detox-20.1.0-sources.jar} +0 -0
  7. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0-sources.jar.md5 +1 -0
  8. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0-sources.jar.sha1 +1 -0
  9. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0-sources.jar.sha256 +1 -0
  10. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0-sources.jar.sha512 +1 -0
  11. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.aar +0 -0
  12. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.aar.md5 +1 -0
  13. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.aar.sha1 +1 -0
  14. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.aar.sha256 +1 -0
  15. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.aar.sha512 +1 -0
  16. package/Detox-android/com/wix/detox/{20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.pom → 20.1.0/detox-20.1.0.pom} +1 -1
  17. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.pom.md5 +1 -0
  18. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.pom.sha1 +1 -0
  19. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.pom.sha256 +1 -0
  20. package/Detox-android/com/wix/detox/20.1.0/detox-20.1.0.pom.sha512 +1 -0
  21. package/Detox-android/com/wix/detox/maven-metadata.xml +4 -4
  22. package/Detox-android/com/wix/detox/maven-metadata.xml.md5 +1 -1
  23. package/Detox-android/com/wix/detox/maven-metadata.xml.sha1 +1 -1
  24. package/Detox-android/com/wix/detox/maven-metadata.xml.sha256 +1 -1
  25. package/Detox-android/com/wix/detox/maven-metadata.xml.sha512 +1 -1
  26. package/Detox-ios-src.tbz +0 -0
  27. package/Detox-ios.tbz +0 -0
  28. package/android/build.gradle +0 -1
  29. package/android/detox/src/full/java/com/wix/detox/TestEngineFacade.kt +3 -3
  30. package/android/detox/src/full/java/com/wix/detox/adapters/server/QueryStatusActionHandler.kt +12 -80
  31. package/android/detox/src/full/java/com/wix/detox/espresso/common/UiControllerImplReflected.kt +16 -0
  32. package/android/detox/src/full/java/com/wix/detox/espresso/idlingresources/DescriptiveIdlingResource.kt +8 -0
  33. package/android/detox/src/full/java/com/wix/detox/espresso/registry/BusyResourcesInquirer.kt +48 -0
  34. package/android/detox/src/full/java/com/wix/detox/inquiry/DetoxBusyResource.kt +92 -0
  35. package/android/detox/src/full/java/com/wix/detox/{reactnative/idlingresources/IdlingResourceDescription.kt → inquiry/DetoxBusyResourceDescription.kt} +6 -6
  36. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/AnimatedModuleIdlingResource.java +18 -7
  37. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/AsyncStorageIdlingResource.kt +2 -4
  38. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/BridgeIdlingResource.java +12 -6
  39. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/DetoxBaseIdlingResource.java +2 -0
  40. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/NetworkIdlingResource.java +14 -8
  41. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/timers/TimersIdlingResource.kt +1 -6
  42. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/uimodule/UIManagerModuleReflected.kt +1 -1
  43. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/uimodule/UIModuleIdlingResource.kt +4 -6
  44. package/android/detox/src/testFull/java/com/wix/detox/adapters/server/QueryStatusActionHandlerSpec.kt +35 -94
  45. package/android/detox/src/testFull/java/com/wix/detox/espresso/registry/{IRStatusInquirerTest.kt → BusyResourcesInquirerTest.kt} +46 -7
  46. package/android/detox/src/testFull/java/com/wix/detox/{reactnative/idlingresources/IdlingResourceDescriptionSpec.kt → inquiry/DetoxBusyResourceDescriptionSpec.kt} +6 -6
  47. package/android/detox/src/testFull/java/com/wix/detox/inquiry/DetoxBusyResourceSpec.kt +134 -0
  48. package/android/detox/src/testFull/java/com/wix/detox/reactnative/idlingresources/AsyncStorageIdlingResourceSpec.kt +4 -5
  49. package/android/detox/src/testFull/java/com/wix/detox/reactnative/idlingresources/NetworkIdlingResourcesTest.kt +5 -5
  50. package/android/detox/src/testFull/java/com/wix/detox/reactnative/idlingresources/timers/TimersIdlingResourceSpec.kt +4 -6
  51. package/index.d.ts +102 -18
  52. package/internals.d.ts +34 -9
  53. package/local-cli/cli.js +6 -3
  54. package/local-cli/init.js +1 -1
  55. package/local-cli/test.js +6 -6
  56. package/local-cli/testCommand/TestRunnerCommand.js +97 -94
  57. package/local-cli/testCommand/TestRunnerError.js +17 -0
  58. package/local-cli/testCommand/builder.js +0 -1
  59. package/local-cli/testCommand/middlewares.js +4 -13
  60. package/local-cli/testCommand/warnings.js +0 -3
  61. package/package.json +18 -15
  62. package/runners/deprecation.js +42 -44
  63. package/runners/jest/index.d.ts +60 -0
  64. package/runners/jest/index.js +3 -8
  65. package/runners/jest/reporters/DetoxReporter.js +21 -10
  66. package/runners/jest/testEnvironment/index.js +57 -41
  67. package/runners/jest/testEnvironment/listeners/DetoxCoreListener.js +62 -35
  68. package/runners/jest/testEnvironment/listeners/SpecReporter.js +12 -14
  69. package/runners/jest/testEnvironment/listeners/WorkerAssignReporter.js +1 -5
  70. package/runners/jest/testEnvironment/utils/assertJestCircus27.js +17 -3
  71. package/src/DetoxWorker.js +95 -49
  72. package/src/android/interactions/native.js +3 -2
  73. package/src/artifacts/ArtifactsManager.js +6 -6
  74. package/src/artifacts/utils/temporaryPath.js +32 -2
  75. package/src/client/actions/SyncStatusSchema.json +21 -0
  76. package/src/client/actions/formatters/SyncStatusFormatter.js +2 -0
  77. package/src/client/actions/formatters/sync-resources/BgThreadFormatter.js +5 -0
  78. package/src/configuration/collectCliConfig.js +1 -12
  79. package/src/configuration/composeRunnerConfig.js +5 -4
  80. package/src/devices/allocation/drivers/android/emulator/EmulatorLauncher.js +3 -3
  81. package/src/devices/allocation/drivers/android/emulator/launchEmulatorProcess.js +3 -16
  82. package/src/devices/common/drivers/android/exec/ADB.js +4 -0
  83. package/src/devices/common/drivers/ios/tools/AppleSimUtils.js +1 -1
  84. package/src/devices/lifecycle/GenyGlobalLifecycleHandler.js +4 -0
  85. package/src/devices/runtime/RuntimeDevice.js +3 -3
  86. package/src/errors/DetoxConfigErrorComposer.js +6 -1
  87. package/src/errors/DetoxError.js +5 -1
  88. package/src/ios/expectTwo.js +3 -2
  89. package/src/ipc/IPCClient.js +26 -17
  90. package/src/ipc/IPCServer.js +11 -3
  91. package/src/ipc/SessionState.js +11 -11
  92. package/src/logger/DetoxLogger.js +63 -43
  93. package/src/logger/index.js +1 -0
  94. package/src/logger/utils/BunyanLogger.js +50 -7
  95. package/src/logger/utils/CategoryThreadDispatcher.js +8 -29
  96. package/src/logger/utils/DetoxLogFinalizer.js +166 -0
  97. package/src/logger/utils/MessageStack.js +17 -6
  98. package/src/logger/utils/ThreadDispatcher.js +5 -25
  99. package/src/logger/utils/customConsoleLogger.js +22 -5
  100. package/src/logger/utils/getMainCategory.js +5 -0
  101. package/src/logger/utils/sanitizeBunyanContext.js +3 -1
  102. package/src/logger/utils/streams/BunyanTransformer.js +72 -0
  103. package/src/logger/utils/streams/ChromeTraceTransformer.js +132 -0
  104. package/src/logger/utils/streams/DetoxJSONLParser.js +31 -0
  105. package/src/logger/utils/streams/JSONLStringer.js +55 -0
  106. package/src/logger/utils/streams/index.js +7 -0
  107. package/src/logger/utils/streams/transformers.js +39 -0
  108. package/src/logger/utils/tracerLegacy.js +14 -25
  109. package/src/realms/DetoxContext.js +11 -7
  110. package/src/realms/DetoxInternalsFacade.js +0 -6
  111. package/src/realms/DetoxPrimaryContext.js +42 -87
  112. package/src/realms/DetoxSecondaryContext.js +8 -12
  113. package/src/utils/argparse.js +11 -0
  114. package/src/utils/logger.js +1 -1
  115. package/src/utils/pathUtils.js +11 -0
  116. package/src/utils/shellUtils.js +17 -0
  117. package/src/utils/traceInvocationCall.js +21 -0
  118. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-javadoc.jar.md5 +0 -1
  119. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-javadoc.jar.sha1 +0 -1
  120. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-javadoc.jar.sha256 +0 -1
  121. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-javadoc.jar.sha512 +0 -1
  122. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-sources.jar.md5 +0 -1
  123. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-sources.jar.sha1 +0 -1
  124. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-sources.jar.sha256 +0 -1
  125. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0-sources.jar.sha512 +0 -1
  126. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.aar +0 -0
  127. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.aar.md5 +0 -1
  128. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.aar.sha1 +0 -1
  129. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.aar.sha256 +0 -1
  130. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.aar.sha512 +0 -1
  131. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.pom.md5 +0 -1
  132. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.pom.sha1 +0 -1
  133. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.pom.sha256 +0 -1
  134. package/Detox-android/com/wix/detox/20.1.0-next-is-hittable-check.0/detox-20.1.0-next-is-hittable-check.0.pom.sha512 +0 -1
  135. package/android/detox/src/full/java/com/wix/detox/espresso/registry/IRStatusInquirer.kt +0 -24
  136. package/android/detox/src/full/java/com/wix/detox/reactnative/idlingresources/DescriptiveIdlingResource.kt +0 -10
  137. package/local-cli/build.test.js +0 -104
  138. package/local-cli/run-server.test.js +0 -23
  139. package/local-cli/test.test.js +0 -569
  140. package/runners/jest/deprecation.js +0 -25
  141. package/runners/jest/testEnvironment/utils/assertJestCircus27.test.js +0 -23
  142. package/src/configuration/utils/warnings.js +0 -12
  143. package/src/logger/utils/streamUtils.js +0 -240
  144. package/src/utils/trace.js +0 -3
@@ -1,240 +0,0 @@
1
- const { PassThrough, Transform } = require('stream');
2
-
3
- const bunyanDebugStream = require('bunyan-debug-stream');
4
- const duplexify = require('duplexify');
5
- const fs = require('fs-extra');
6
- const glob = require('glob');
7
- const multiSort = require('multi-sort-stream');
8
- const pipe = require('multipipe');
9
- const JsonlParser = require('stream-json/jsonl/Parser');
10
- const stripAnsi = require('strip-ansi');
11
- const { AbstractEventBuilder } = require('trace-event-lib');
12
-
13
- const temporary = require('../../artifacts/utils/temporaryPath');
14
- const log = require('../../utils/logger').child({ cat: 'logger' });
15
-
16
- function compareTimestamps(a, b) {
17
- return +(a.value.time > b.value.time) - +(a.value.time < b.value.time);
18
- }
19
-
20
- function mapTransform(fn) {
21
- return new Transform({
22
- objectMode: true,
23
- transform(chunk, encoding, callback){
24
- this.push(fn(chunk));
25
- callback();
26
- },
27
- });
28
- }
29
-
30
- function flatMapTransform(fn) {
31
- let index = 0;
32
-
33
- return new Transform({
34
- objectMode: true,
35
- transform(chunk, encoding, callback){
36
- const result = fn(chunk, index++);
37
- if (Array.isArray(result)) {
38
- // eslint-disable-next-line unicorn/no-array-method-this-argument
39
- result.forEach(pushThis, this);
40
- } else if (result) {
41
- this.push(result);
42
- }
43
-
44
- callback();
45
- },
46
- });
47
- }
48
-
49
- function pushThis(x) {
50
- return this.push(x);
51
- }
52
-
53
- function extractValue({ value }) {
54
- value.msg = stripAnsi(value.msg);
55
-
56
- if (typeof value.time === 'string') {
57
- value.time = new Date(value.time);
58
- }
59
-
60
- return value;
61
- }
62
-
63
- function through() {
64
- return new PassThrough({ objectMode: true });
65
- }
66
-
67
- function mergeSortedJSONL(jsonlStreams, comparator = compareTimestamps) {
68
- const intermediate = mapTransform(extractValue);
69
- const reemitError = (err) => intermediate.emit('error', err);
70
- const addReemit = (stream) => stream.on('error', reemitError);
71
- return pipe(multiSort(jsonlStreams.map(addReemit), comparator), intermediate, through());
72
- }
73
-
74
- function writeJSONL() {
75
- return new JsonlStringer({
76
- header: '',
77
- delimiter: '\n',
78
- footer: '',
79
- });
80
- }
81
-
82
- function writeJSON() {
83
- return new JsonlStringer({
84
- header: '[\n\t',
85
- delimiter: ',\n\t',
86
- footer: '\n]\n',
87
- });
88
- }
89
-
90
- function debugStream(options) {
91
- const out = new PassThrough({ encoding: 'utf8' });
92
- const writable = bunyanDebugStream.default({
93
- ...options,
94
- colors: false,
95
- out,
96
- });
97
-
98
- return duplexify(writable, out, {
99
- readableObjectMode: false,
100
- writableObjectMode: true
101
- });
102
- }
103
-
104
- class JsonlStringer extends Transform {
105
- constructor({ replacer = undefined, header = '', delimiter = '\n', footer = '' } = {}) {
106
- super({ writableObjectMode: true, readableObjectMode: false });
107
-
108
- this._replacer = replacer;
109
- this._header = header;
110
- this._delimiter = delimiter;
111
- this._footer = footer;
112
- }
113
-
114
- _transform(chunk, _, callback) {
115
- if (this._header) {
116
- this.push(this._header);
117
- }
118
-
119
- this.push(JSON.stringify(chunk, this._replacer));
120
- this._transform = this._nextTransform;
121
- callback(null);
122
- }
123
-
124
- _nextTransform(chunk, _, callback) {
125
- this.push(this._delimiter + JSON.stringify(chunk, this._replacer));
126
- callback(null);
127
- }
128
-
129
- _flush(callback) {
130
- if (this._footer) {
131
- this.push(this._footer);
132
- }
133
-
134
- callback();
135
- }
136
- }
137
-
138
- class SimpleEventBuilder extends AbstractEventBuilder {
139
- events = [];
140
-
141
- send(event) {
142
- this.events.push(event);
143
- }
144
- }
145
-
146
- function chromeTraceStream() {
147
- const knownPids = new Set();
148
- const knownTids = new Set();
149
-
150
- return flatMapTransform((data) => {
151
- // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars
152
- const { cat = 'default', msg: name, ph = 'i', pid, tid, time, name: _name, hostname: _hostname, ...args } = data;
153
- const ts = new Date(time).getTime() * 1E3;
154
-
155
- const builder = new SimpleEventBuilder();
156
- if (!knownPids.has(pid)) {
157
- builder.process_name(pid === process.pid ? 'primary' : 'secondary', pid);
158
- knownPids.add(pid);
159
- }
160
-
161
- const tidHash = `${pid}:${tid}`;
162
- if (!knownTids.has(tidHash)) {
163
- const primaryCategory = cat.split(',', 1)[0];
164
- builder.thread_name(primaryCategory, tid, pid);
165
- builder.thread_sort_index(tid, tid, pid);
166
- knownTids.add(tidHash);
167
- }
168
-
169
- const event = { ph, name, pid, tid, cat, ts, args };
170
- if (ph === 'E') {
171
- delete event.name;
172
- }
173
-
174
- builder.events.push(event);
175
- return builder.events;
176
- });
177
- }
178
-
179
- // TODO: create PR to https://github.com/mafintosh/duplexify
180
- // should be able to pass { error: false } to end-of-stream
181
- function preventErrorSubscriptions(emitter) {
182
- const originalOn = emitter.on.bind(emitter);
183
- emitter.on = (event, ...args) => {
184
- if (event === 'error') {
185
- return emitter;
186
- }
187
-
188
- return originalOn(event, ...args);
189
- };
190
-
191
- return emitter;
192
- }
193
-
194
- function readJSONL() {
195
- const readable = through();
196
- const writable = JsonlParser.make({ checkErrors: true })
197
- .on('error', (err) => {
198
- if (err instanceof SyntaxError) {
199
- log.debug({ err });
200
- readable.end();
201
- } else {
202
- readable.emit('error', err);
203
- }
204
- });
205
-
206
- return duplexify.obj(preventErrorSubscriptions(writable), writable.pipe(readable));
207
- }
208
-
209
- /**
210
- * @param {string} sessionId
211
- * @returns {NodeJS.ReadableStream}
212
- */
213
- function uniteSessionLogs(sessionId) {
214
- const readable = through();
215
-
216
- glob(temporary.for.jsonl(`${sessionId}.*`), function (err, logs) {
217
- if (err) {
218
- return readable.emit('error', err);
219
- }
220
-
221
- if (logs.length === 0) {
222
- return;
223
- }
224
-
225
- const jsonlStreams = logs.map(filePath => fs.createReadStream(filePath).pipe(readJSONL()));
226
- mergeSortedJSONL(jsonlStreams).pipe(readable);
227
- });
228
-
229
- return readable;
230
- }
231
-
232
- module.exports = {
233
- readJSONL,
234
- writeJSON,
235
- writeJSONL,
236
- mergeSortedJSONL,
237
- debugStream,
238
- chromeTraceStream,
239
- uniteSessionLogs,
240
- };
@@ -1,3 +0,0 @@
1
- const { trace, traceCall } = require('../..');
2
-
3
- module.exports = { trace, traceCall };