@alwaysai/device-agent 1.3.1 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/application-control/config.js +2 -2
- package/lib/application-control/config.js.map +1 -1
- package/lib/application-control/environment-variables.d.ts.map +1 -1
- package/lib/application-control/environment-variables.js +9 -4
- package/lib/application-control/environment-variables.js.map +1 -1
- package/lib/application-control/environment-variables.test.js +1 -1
- package/lib/application-control/environment-variables.test.js.map +1 -1
- package/lib/application-control/install.d.ts.map +1 -1
- package/lib/application-control/install.js +7 -2
- package/lib/application-control/install.js.map +1 -1
- package/lib/application-control/models.d.ts +5 -0
- package/lib/application-control/models.d.ts.map +1 -1
- package/lib/application-control/models.js +28 -14
- package/lib/application-control/models.js.map +1 -1
- package/lib/application-control/status.d.ts.map +1 -1
- package/lib/application-control/status.js +14 -17
- package/lib/application-control/status.js.map +1 -1
- package/lib/application-control/utils.js +2 -2
- package/lib/application-control/utils.js.map +1 -1
- package/lib/cloud-connection/device-agent-cloud-connection.d.ts +5 -5
- package/lib/cloud-connection/device-agent-cloud-connection.d.ts.map +1 -1
- package/lib/cloud-connection/device-agent-cloud-connection.js +140 -105
- package/lib/cloud-connection/device-agent-cloud-connection.js.map +1 -1
- package/lib/cloud-connection/live-updates-handler.d.ts +4 -2
- package/lib/cloud-connection/live-updates-handler.d.ts.map +1 -1
- package/lib/cloud-connection/live-updates-handler.js +46 -25
- package/lib/cloud-connection/live-updates-handler.js.map +1 -1
- package/lib/cloud-connection/live-updates-handler.test.js +132 -16
- package/lib/cloud-connection/live-updates-handler.test.js.map +1 -1
- package/lib/cloud-connection/messages.d.ts.map +1 -1
- package/lib/cloud-connection/messages.js +3 -4
- package/lib/cloud-connection/messages.js.map +1 -1
- package/lib/cloud-connection/passthrough-handler.d.ts +5 -3
- package/lib/cloud-connection/passthrough-handler.d.ts.map +1 -1
- package/lib/cloud-connection/passthrough-handler.js +76 -62
- package/lib/cloud-connection/passthrough-handler.js.map +1 -1
- package/lib/cloud-connection/shadow-handler.d.ts +16 -21
- package/lib/cloud-connection/shadow-handler.d.ts.map +1 -1
- package/lib/cloud-connection/shadow-handler.js +162 -108
- package/lib/cloud-connection/shadow-handler.js.map +1 -1
- package/lib/cloud-connection/shadow-handler.test.js +100 -83
- package/lib/cloud-connection/shadow-handler.test.js.map +1 -1
- package/lib/cloud-connection/transaction-manager.d.ts +3 -0
- package/lib/cloud-connection/transaction-manager.d.ts.map +1 -1
- package/lib/cloud-connection/transaction-manager.js +11 -0
- package/lib/cloud-connection/transaction-manager.js.map +1 -1
- package/lib/cloud-connection/transaction-manager.test.js +102 -0
- package/lib/cloud-connection/transaction-manager.test.js.map +1 -1
- package/lib/device-control/device-control.d.ts +16 -15
- package/lib/device-control/device-control.d.ts.map +1 -1
- package/lib/device-control/device-control.js +117 -18
- package/lib/device-control/device-control.js.map +1 -1
- package/lib/docker/docker-compose.d.ts +14 -0
- package/lib/docker/docker-compose.d.ts.map +1 -0
- package/lib/docker/docker-compose.js +56 -0
- package/lib/docker/docker-compose.js.map +1 -0
- package/lib/index.js +2 -5
- package/lib/index.js.map +1 -1
- package/lib/infrastructure/agent-config.d.ts +45 -14
- package/lib/infrastructure/agent-config.d.ts.map +1 -1
- package/lib/infrastructure/agent-config.js +30 -15
- package/lib/infrastructure/agent-config.js.map +1 -1
- package/lib/infrastructure/agent-config.test.js +3 -0
- package/lib/infrastructure/agent-config.test.js.map +1 -1
- package/lib/local-connection/rabbitmq-connection.js +11 -11
- package/lib/local-connection/rabbitmq-connection.js.map +1 -1
- package/lib/secure-tunneling/secure-tunneling.d.ts +97 -0
- package/lib/secure-tunneling/secure-tunneling.d.ts.map +1 -0
- package/lib/secure-tunneling/secure-tunneling.js +435 -0
- package/lib/secure-tunneling/secure-tunneling.js.map +1 -0
- package/lib/secure-tunneling/secure-tunneling.test.d.ts +2 -0
- package/lib/secure-tunneling/secure-tunneling.test.d.ts.map +1 -0
- package/lib/secure-tunneling/secure-tunneling.test.js +1070 -0
- package/lib/secure-tunneling/secure-tunneling.test.js.map +1 -0
- package/lib/secure-tunneling/spawner-detached.d.ts +6 -0
- package/lib/secure-tunneling/spawner-detached.d.ts.map +1 -0
- package/lib/secure-tunneling/spawner-detached.js +107 -0
- package/lib/secure-tunneling/spawner-detached.js.map +1 -0
- package/lib/subcommands/app/analytics.d.ts.map +1 -1
- package/lib/subcommands/app/analytics.js +9 -13
- package/lib/subcommands/app/analytics.js.map +1 -1
- package/lib/subcommands/app/env-vars.d.ts.map +1 -1
- package/lib/subcommands/app/env-vars.js +11 -16
- package/lib/subcommands/app/env-vars.js.map +1 -1
- package/lib/subcommands/app/models.d.ts.map +1 -1
- package/lib/subcommands/app/models.js +12 -16
- package/lib/subcommands/app/models.js.map +1 -1
- package/lib/subcommands/device/clean.d.ts.map +1 -1
- package/lib/subcommands/device/clean.js +8 -6
- package/lib/subcommands/device/clean.js.map +1 -1
- package/lib/subcommands/device/get-info.d.ts +2 -0
- package/lib/subcommands/device/get-info.d.ts.map +1 -0
- package/lib/subcommands/device/get-info.js +36 -0
- package/lib/subcommands/device/get-info.js.map +1 -0
- package/lib/subcommands/device/index.d.ts.map +1 -1
- package/lib/subcommands/device/index.js +11 -2
- package/lib/subcommands/device/index.js.map +1 -1
- package/lib/subcommands/device/init.d.ts +5 -0
- package/lib/subcommands/device/init.d.ts.map +1 -0
- package/lib/subcommands/device/{device.js → init.js} +5 -36
- package/lib/subcommands/device/init.js.map +1 -0
- package/lib/subcommands/device/refresh.d.ts +2 -0
- package/lib/subcommands/device/refresh.d.ts.map +1 -0
- package/lib/subcommands/device/refresh.js +24 -0
- package/lib/subcommands/device/refresh.js.map +1 -0
- package/lib/subcommands/device/restart.d.ts +2 -0
- package/lib/subcommands/device/restart.d.ts.map +1 -0
- package/lib/subcommands/device/restart.js +14 -0
- package/lib/subcommands/device/restart.js.map +1 -0
- package/lib/util/check-for-updates.d.ts +3 -0
- package/lib/util/check-for-updates.d.ts.map +1 -0
- package/lib/util/check-for-updates.js +69 -0
- package/lib/util/check-for-updates.js.map +1 -0
- package/lib/util/cloud-mode-ready.d.ts +1 -0
- package/lib/util/cloud-mode-ready.d.ts.map +1 -1
- package/lib/util/cloud-mode-ready.js +36 -1
- package/lib/util/cloud-mode-ready.js.map +1 -1
- package/lib/util/file.d.ts +7 -0
- package/lib/util/file.d.ts.map +1 -0
- package/lib/util/file.js +66 -0
- package/lib/util/file.js.map +1 -0
- package/lib/util/file.test.d.ts +2 -0
- package/lib/util/file.test.d.ts.map +1 -0
- package/lib/util/file.test.js +87 -0
- package/lib/util/file.test.js.map +1 -0
- package/package.json +8 -7
- package/readme.md +3 -3
- package/src/application-control/config.ts +1 -1
- package/src/application-control/environment-variables.test.ts +1 -1
- package/src/application-control/environment-variables.ts +9 -6
- package/src/application-control/install.ts +8 -3
- package/src/application-control/models.ts +47 -19
- package/src/application-control/status.ts +16 -14
- package/src/application-control/utils.ts +1 -1
- package/src/cloud-connection/device-agent-cloud-connection.ts +202 -148
- package/src/cloud-connection/live-updates-handler.test.ts +161 -20
- package/src/cloud-connection/live-updates-handler.ts +63 -31
- package/src/cloud-connection/messages.ts +3 -4
- package/src/cloud-connection/passthrough-handler.ts +98 -76
- package/src/cloud-connection/shadow-handler.test.ts +101 -84
- package/src/cloud-connection/shadow-handler.ts +287 -133
- package/src/cloud-connection/transaction-manager.test.ts +124 -0
- package/src/cloud-connection/transaction-manager.ts +15 -0
- package/src/device-control/device-control.ts +125 -23
- package/src/docker/docker-compose.ts +60 -0
- package/src/index.ts +2 -6
- package/src/infrastructure/agent-config.test.ts +3 -0
- package/src/infrastructure/agent-config.ts +38 -40
- package/src/local-connection/rabbitmq-connection.ts +8 -8
- package/src/secure-tunneling/secure-tunneling.test.ts +1239 -0
- package/src/secure-tunneling/secure-tunneling.ts +599 -0
- package/src/secure-tunneling/spawner-detached.ts +123 -0
- package/src/subcommands/app/analytics.ts +16 -13
- package/src/subcommands/app/env-vars.ts +18 -16
- package/src/subcommands/app/models.ts +20 -16
- package/src/subcommands/device/clean.ts +5 -2
- package/src/subcommands/device/get-info.ts +49 -0
- package/src/subcommands/device/index.ts +11 -2
- package/src/subcommands/device/{device.ts → init.ts} +5 -47
- package/src/subcommands/device/refresh.ts +22 -0
- package/src/subcommands/device/restart.ts +11 -0
- package/src/util/check-for-updates.ts +69 -0
- package/src/util/cloud-mode-ready.ts +36 -0
- package/src/util/file.test.ts +90 -0
- package/src/util/file.ts +76 -0
- package/lib/docker/docker-compose-cmd.d.ts +0 -5
- package/lib/docker/docker-compose-cmd.d.ts.map +0 -1
- package/lib/docker/docker-compose-cmd.js +0 -16
- package/lib/docker/docker-compose-cmd.js.map +0 -1
- package/lib/secure-tunneling/index.d.ts +0 -5
- package/lib/secure-tunneling/index.d.ts.map +0 -1
- package/lib/secure-tunneling/index.js +0 -64
- package/lib/secure-tunneling/index.js.map +0 -1
- package/lib/subcommands/device/device.d.ts +0 -7
- package/lib/subcommands/device/device.d.ts.map +0 -1
- package/lib/subcommands/device/device.js.map +0 -1
- package/lib/util/safe-rimraf.d.ts +0 -2
- package/lib/util/safe-rimraf.d.ts.map +0 -1
- package/lib/util/safe-rimraf.js +0 -16
- package/lib/util/safe-rimraf.js.map +0 -1
- package/src/docker/docker-compose-cmd.ts +0 -15
- package/src/secure-tunneling/index.ts +0 -74
- package/src/util/safe-rimraf.ts +0 -14
|
@@ -9,7 +9,7 @@ const messages_1 = require("./messages");
|
|
|
9
9
|
const environment_1 = require("../environment");
|
|
10
10
|
const LIVE_UPDATES_TIMEOUT = environment_1.ALWAYSAI_LIVE_UPDATES_TIMEOUT_MS
|
|
11
11
|
? parseInt(environment_1.ALWAYSAI_LIVE_UPDATES_TIMEOUT_MS)
|
|
12
|
-
:
|
|
12
|
+
: 80000;
|
|
13
13
|
class LiveUpdatesHandler {
|
|
14
14
|
/*=================================================================
|
|
15
15
|
Public interface
|
|
@@ -33,13 +33,31 @@ class LiveUpdatesHandler {
|
|
|
33
33
|
this.clientId = clientId;
|
|
34
34
|
logger_1.logger.debug(`Toggle live updates timeout set to ${LIVE_UPDATES_TIMEOUT} ms`);
|
|
35
35
|
}
|
|
36
|
+
async getAppLogsWithRetry(projectId) {
|
|
37
|
+
// Retry starting logs until it starts successfully or is terminated
|
|
38
|
+
while (this.appLogStreams.has(projectId)) {
|
|
39
|
+
try {
|
|
40
|
+
return await (0, application_control_1.getAppLogs)({
|
|
41
|
+
projectId,
|
|
42
|
+
args: ['--tail', '100', '--no-log-prefix']
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
catch (e) {
|
|
46
|
+
logger_1.logger.info(`Failed to start app logs, retrying in 1 second. Error: ${e}`);
|
|
47
|
+
await (0, sleep_1.default)(1000);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
// Case where logs were disabled prior to connecting
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
36
53
|
async startAppLogStream(projectId, txId) {
|
|
37
54
|
logger_1.logger.info(`Starting log stream for ${projectId}`);
|
|
38
55
|
this.appLogStreams.add(projectId);
|
|
39
|
-
const readable = await (
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
56
|
+
const readable = await this.getAppLogsWithRetry(projectId);
|
|
57
|
+
if (readable === null) {
|
|
58
|
+
logger_1.logger.info(`App log stream terminated for project ${projectId} prior to starting`);
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
43
61
|
readable.on('data', async (chunk) => {
|
|
44
62
|
if (!this.appLogStreams.has(projectId)) {
|
|
45
63
|
// why doesn't typescript know about this function?
|
|
@@ -87,44 +105,42 @@ class LiveUpdatesHandler {
|
|
|
87
105
|
logger_1.logger.error(`Unrecognized live updates flag ${flag}`);
|
|
88
106
|
return -1;
|
|
89
107
|
}
|
|
90
|
-
setLiveUpdates(toggles) {
|
|
91
|
-
if (toggles.deviceStats !== undefined) {
|
|
92
|
-
this.liveUpdatesAlive.device_stats = toggles.deviceStats;
|
|
93
|
-
}
|
|
94
|
-
if (toggles.appState !== undefined) {
|
|
95
|
-
this.liveUpdatesAlive.app_state = toggles.appState;
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
108
|
restartLiveUpdatesTimeout() {
|
|
99
109
|
clearTimeout(this.liveUpdatesTimeout);
|
|
100
110
|
this.liveUpdatesTimeout = setTimeout(() => {
|
|
101
|
-
this.
|
|
102
|
-
|
|
103
|
-
appState: false
|
|
104
|
-
});
|
|
111
|
+
this.disableAppStateLiveUpdates();
|
|
112
|
+
this.disableDeviceStatsLiveUpdates();
|
|
105
113
|
this.appLogStreams.clear();
|
|
106
114
|
}, LIVE_UPDATES_TIMEOUT);
|
|
107
115
|
}
|
|
108
116
|
async startPublishingLiveUpdates(messageType, getMessage, txId) {
|
|
109
117
|
logger_1.logger.info(`Turned on live updates for ${messageType}`);
|
|
110
|
-
|
|
111
|
-
|
|
118
|
+
while (this.continuePublishing(messageType, txId)) {
|
|
119
|
+
try {
|
|
112
120
|
const message = await getMessage();
|
|
113
121
|
this.publisher.publishToClient(message, logger_1.logger.silly);
|
|
114
122
|
await (0, sleep_1.default)(this.getLiveUpdatesInterval(messageType));
|
|
115
123
|
}
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
124
|
+
catch (e) {
|
|
125
|
+
logger_1.logger.error(`Error publishing live updates for ${messageType}: ${e.message}`);
|
|
126
|
+
}
|
|
119
127
|
}
|
|
120
128
|
logger_1.logger.info(`Turned off live updates for ${messageType}`);
|
|
121
129
|
}
|
|
122
130
|
getDeviceStatsLiveUpdates() {
|
|
123
131
|
return this.liveUpdatesAlive.device_stats;
|
|
124
132
|
}
|
|
133
|
+
disableDeviceStatsLiveUpdates() {
|
|
134
|
+
logger_1.logger.info('Disabled live updates for device_stats');
|
|
135
|
+
this.liveUpdatesAlive.device_stats = false;
|
|
136
|
+
}
|
|
125
137
|
getAppStateLiveUpdates() {
|
|
126
138
|
return this.liveUpdatesAlive.app_state;
|
|
127
139
|
}
|
|
140
|
+
disableAppStateLiveUpdates() {
|
|
141
|
+
logger_1.logger.info('Disabled live updates for app_state');
|
|
142
|
+
this.liveUpdatesAlive.app_state = false;
|
|
143
|
+
}
|
|
128
144
|
getAppLogsLiveUpdates() {
|
|
129
145
|
return this.liveUpdatesAlive.app_logs;
|
|
130
146
|
}
|
|
@@ -152,15 +168,17 @@ class LiveUpdatesHandler {
|
|
|
152
168
|
async handleToggles(toggles, txId) {
|
|
153
169
|
const { deviceStats, appState, appLogs } = toggles;
|
|
154
170
|
this.restartLiveUpdatesTimeout();
|
|
171
|
+
const promises = [];
|
|
155
172
|
if (deviceStats !== undefined) {
|
|
156
173
|
const currentDeviceStats = this.getDeviceStatsLiveUpdates();
|
|
157
174
|
this.liveUpdatesAlive.device_stats = deviceStats;
|
|
158
175
|
if (deviceStats && currentDeviceStats !== true) {
|
|
159
176
|
// Don't wait for this call to finish since it loops until disabled
|
|
160
|
-
|
|
177
|
+
const deviceStatsPromise = this.startPublishingLiveUpdates(device_agent_schemas_1.keyMirrors.toClientMessageType.device_stats, async () => {
|
|
161
178
|
const payload = await (0, messages_1.getDeviceStatsPayload)();
|
|
162
179
|
return (0, device_agent_schemas_1.buildDeviceStatsMessage)(this.clientId, payload, txId);
|
|
163
180
|
}, txId);
|
|
181
|
+
promises.push(deviceStatsPromise);
|
|
164
182
|
}
|
|
165
183
|
}
|
|
166
184
|
if (appState !== undefined) {
|
|
@@ -168,22 +186,25 @@ class LiveUpdatesHandler {
|
|
|
168
186
|
this.liveUpdatesAlive.app_state = appState;
|
|
169
187
|
if (appState && currentAppState !== true) {
|
|
170
188
|
// Don't wait for this call to finish since it loops until disabled
|
|
171
|
-
|
|
189
|
+
const appStatePromise = this.startPublishingLiveUpdates(device_agent_schemas_1.keyMirrors.toClientMessageType.app_state, async () => {
|
|
172
190
|
const payload = await (0, messages_1.getAppStatePayload)();
|
|
173
191
|
return (0, device_agent_schemas_1.buildAppStateMessage)(this.clientId, payload, txId);
|
|
174
192
|
}, txId);
|
|
193
|
+
promises.push(appStatePromise);
|
|
175
194
|
}
|
|
176
195
|
}
|
|
177
196
|
if (appLogs !== undefined) {
|
|
178
197
|
const currentAppLogs = this.getAppLogsLiveUpdates();
|
|
179
198
|
if (appLogs.toggle && currentAppLogs !== true) {
|
|
180
199
|
// Don't wait for this call to finish since it loops until disabled
|
|
181
|
-
|
|
200
|
+
const appLogPromise = this.startAppLogStream(appLogs.projectId, txId);
|
|
201
|
+
promises.push(appLogPromise);
|
|
182
202
|
}
|
|
183
203
|
else {
|
|
184
204
|
this.appLogStreams.delete(appLogs.projectId);
|
|
185
205
|
}
|
|
186
206
|
}
|
|
207
|
+
return promises;
|
|
187
208
|
}
|
|
188
209
|
}
|
|
189
210
|
exports.LiveUpdatesHandler = LiveUpdatesHandler;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"live-updates-handler.js","sourceRoot":"","sources":["../../src/cloud-connection/live-updates-handler.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"live-updates-handler.js","sourceRoot":"","sources":["../../src/cloud-connection/live-updates-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,6 +2,11 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const live_updates_handler_1 = require("./live-updates-handler");
|
|
4
4
|
const publisher_1 = require("./publisher");
|
|
5
|
+
const sleep_1 = require("../util/sleep");
|
|
6
|
+
const messages_1 = require("./messages");
|
|
7
|
+
jest.mock('../util/sleep');
|
|
8
|
+
jest.mock('./messages');
|
|
9
|
+
jest.mocked(messages_1.getDeviceStatsPayload).mockResolvedValue({});
|
|
5
10
|
global.setTimeout = jest.fn();
|
|
6
11
|
// https://github.com/facebook/react-native/issues/35701
|
|
7
12
|
Object.defineProperty(global, 'performance', {
|
|
@@ -15,52 +20,134 @@ const testFalseToggles = {
|
|
|
15
20
|
deviceStats: false,
|
|
16
21
|
appState: false
|
|
17
22
|
};
|
|
18
|
-
const mockClient =
|
|
23
|
+
const mockClient = {
|
|
24
|
+
publish: jest.fn()
|
|
25
|
+
};
|
|
19
26
|
const clientId = 'test-client';
|
|
20
27
|
const emptyTxId = '';
|
|
21
|
-
// NOTE: this was the way I found to mock private class functions
|
|
22
|
-
const mockStartPublishingLiveUpdates = jest.spyOn(live_updates_handler_1.LiveUpdatesHandler.prototype, 'startPublishingLiveUpdates');
|
|
23
|
-
mockStartPublishingLiveUpdates.mockResolvedValue(null);
|
|
24
28
|
describe('Test Live Updates Handler', () => {
|
|
25
29
|
let liveUpdatesHandler;
|
|
26
30
|
let publisher;
|
|
27
31
|
beforeEach(() => {
|
|
32
|
+
mockClient.publish = jest.fn();
|
|
33
|
+
jest.mocked(sleep_1.default).mockImplementation(async () => {
|
|
34
|
+
return;
|
|
35
|
+
});
|
|
28
36
|
publisher = new publisher_1.Publisher(mockClient, clientId);
|
|
29
37
|
liveUpdatesHandler = new live_updates_handler_1.LiveUpdatesHandler(publisher, clientId);
|
|
30
38
|
jest.clearAllMocks();
|
|
31
39
|
});
|
|
40
|
+
test('enable device stats', async () => {
|
|
41
|
+
mockClient.publish = jest.fn().mockImplementation(async () => {
|
|
42
|
+
liveUpdatesHandler.disableDeviceStatsLiveUpdates();
|
|
43
|
+
});
|
|
44
|
+
const enable = { deviceStats: true };
|
|
45
|
+
const promises = await liveUpdatesHandler.handleToggles(enable, emptyTxId);
|
|
46
|
+
await Promise.all(promises);
|
|
47
|
+
expect(jest.mocked(setTimeout)).toBeCalledTimes(1);
|
|
48
|
+
expect(mockClient.publish).toBeCalledTimes(1);
|
|
49
|
+
expect(jest.mocked(sleep_1.default)).toBeCalledTimes(1);
|
|
50
|
+
});
|
|
51
|
+
test('enable app state', async () => {
|
|
52
|
+
mockClient.publish = jest.fn().mockImplementation(async () => {
|
|
53
|
+
liveUpdatesHandler.disableAppStateLiveUpdates();
|
|
54
|
+
});
|
|
55
|
+
const enable = { appState: true };
|
|
56
|
+
const promises = await liveUpdatesHandler.handleToggles(enable, emptyTxId);
|
|
57
|
+
await Promise.all(promises);
|
|
58
|
+
expect(jest.mocked(setTimeout)).toBeCalledTimes(1);
|
|
59
|
+
expect(mockClient.publish).toBeCalledTimes(1);
|
|
60
|
+
expect(jest.mocked(sleep_1.default)).toBeCalledTimes(1);
|
|
61
|
+
});
|
|
32
62
|
test('ignore subsequent enables', async () => {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
63
|
+
// Block on the first sleep call
|
|
64
|
+
let doneWaiting;
|
|
65
|
+
const waitPromise = new Promise(function (resolve) {
|
|
66
|
+
doneWaiting = resolve;
|
|
67
|
+
});
|
|
68
|
+
let startSleeping;
|
|
69
|
+
const sleepPromise = new Promise(function (resolve) {
|
|
70
|
+
startSleeping = resolve;
|
|
71
|
+
});
|
|
72
|
+
jest.mocked(sleep_1.default).mockImplementation(async () => {
|
|
73
|
+
startSleeping();
|
|
74
|
+
await waitPromise;
|
|
75
|
+
});
|
|
76
|
+
const enable = { deviceStats: true };
|
|
77
|
+
await liveUpdatesHandler.handleToggles(enable, emptyTxId);
|
|
78
|
+
await sleepPromise;
|
|
37
79
|
expect(jest.mocked(setTimeout)).toBeCalledTimes(1);
|
|
38
|
-
|
|
80
|
+
expect(mockClient.publish).toBeCalledTimes(1);
|
|
81
|
+
expect(jest.mocked(sleep_1.default)).toBeCalledTimes(1);
|
|
82
|
+
// Second call
|
|
39
83
|
jest.clearAllMocks();
|
|
40
|
-
|
|
41
|
-
expect(mockStartPublishingLiveUpdates).toBeCalledTimes(0);
|
|
84
|
+
await liveUpdatesHandler.handleToggles(enable, emptyTxId);
|
|
42
85
|
expect(jest.mocked(setTimeout)).toHaveBeenCalledTimes(1);
|
|
86
|
+
expect(mockClient.publish).toBeCalledTimes(0);
|
|
87
|
+
expect(jest.mocked(sleep_1.default)).toBeCalledTimes(0);
|
|
88
|
+
// Disable and clean up
|
|
89
|
+
liveUpdatesHandler.disableDeviceStatsLiveUpdates();
|
|
90
|
+
doneWaiting();
|
|
43
91
|
});
|
|
44
92
|
test('test disable live updates', async () => {
|
|
93
|
+
let doneWaiting;
|
|
94
|
+
const waitPromise = new Promise(function (resolve) {
|
|
95
|
+
doneWaiting = resolve;
|
|
96
|
+
});
|
|
97
|
+
let startSleeping;
|
|
98
|
+
const sleepPromise = new Promise(function (resolve) {
|
|
99
|
+
startSleeping = resolve;
|
|
100
|
+
});
|
|
101
|
+
// Wait for two sleep calls, one for Device Stats and one for App State
|
|
102
|
+
jest
|
|
103
|
+
.mocked(sleep_1.default)
|
|
104
|
+
.mockImplementationOnce(async () => {
|
|
105
|
+
await waitPromise;
|
|
106
|
+
})
|
|
107
|
+
.mockImplementationOnce(async () => {
|
|
108
|
+
startSleeping();
|
|
109
|
+
await waitPromise;
|
|
110
|
+
});
|
|
45
111
|
// Test calling handleToggles one time, enabling it
|
|
46
|
-
|
|
47
|
-
|
|
112
|
+
await liveUpdatesHandler.handleToggles(testTrueToggles, emptyTxId);
|
|
113
|
+
await sleepPromise;
|
|
48
114
|
expect(jest.mocked(setTimeout)).toHaveBeenCalledTimes(1);
|
|
115
|
+
expect(jest.mocked(sleep_1.default)).toBeCalledTimes(2);
|
|
49
116
|
expect(liveUpdatesHandler.getDeviceStatsLiveUpdates()).toBe(true);
|
|
50
117
|
expect(liveUpdatesHandler.getAppStateLiveUpdates()).toBe(true);
|
|
51
118
|
expect(liveUpdatesHandler.getAppLogsLiveUpdates()).toBe(false);
|
|
52
119
|
// Check to see that attributes are properly set to false when disabled
|
|
53
120
|
jest.clearAllMocks();
|
|
54
|
-
|
|
55
|
-
expect(mockStartPublishingLiveUpdates).toBeCalledTimes(0);
|
|
121
|
+
await liveUpdatesHandler.handleToggles(testFalseToggles, emptyTxId);
|
|
56
122
|
expect(jest.mocked(setTimeout)).toHaveBeenCalledTimes(1);
|
|
123
|
+
expect(jest.mocked(sleep_1.default)).toBeCalledTimes(0);
|
|
57
124
|
expect(liveUpdatesHandler.getDeviceStatsLiveUpdates()).toBe(false);
|
|
58
125
|
expect(liveUpdatesHandler.getAppStateLiveUpdates()).toBe(false);
|
|
59
126
|
expect(liveUpdatesHandler.getAppLogsLiveUpdates()).toBe(false);
|
|
127
|
+
doneWaiting();
|
|
60
128
|
});
|
|
61
129
|
test('timeout turns off live updates', async () => {
|
|
62
130
|
jest.useFakeTimers({ legacyFakeTimers: true });
|
|
63
|
-
|
|
131
|
+
let doneWaiting;
|
|
132
|
+
const waitPromise = new Promise(function (resolve) {
|
|
133
|
+
doneWaiting = resolve;
|
|
134
|
+
});
|
|
135
|
+
let startSleeping;
|
|
136
|
+
const sleepPromise = new Promise(function (resolve) {
|
|
137
|
+
startSleeping = resolve;
|
|
138
|
+
});
|
|
139
|
+
// Wait for two sleep calls, one for Device Stats and one for App State
|
|
140
|
+
jest
|
|
141
|
+
.mocked(sleep_1.default)
|
|
142
|
+
.mockImplementationOnce(async () => {
|
|
143
|
+
await waitPromise;
|
|
144
|
+
})
|
|
145
|
+
.mockImplementationOnce(async () => {
|
|
146
|
+
startSleeping();
|
|
147
|
+
await waitPromise;
|
|
148
|
+
});
|
|
149
|
+
await liveUpdatesHandler.handleToggles(testTrueToggles, emptyTxId);
|
|
150
|
+
await sleepPromise;
|
|
64
151
|
expect(liveUpdatesHandler.getDeviceStatsLiveUpdates()).toBe(true);
|
|
65
152
|
expect(liveUpdatesHandler.getAppStateLiveUpdates()).toBe(true);
|
|
66
153
|
expect(liveUpdatesHandler.getAppLogsLiveUpdates()).toBe(false);
|
|
@@ -68,6 +155,35 @@ describe('Test Live Updates Handler', () => {
|
|
|
68
155
|
expect(liveUpdatesHandler.getDeviceStatsLiveUpdates()).toBe(false);
|
|
69
156
|
expect(liveUpdatesHandler.getAppStateLiveUpdates()).toBe(false);
|
|
70
157
|
expect(liveUpdatesHandler.getAppLogsLiveUpdates()).toBe(false);
|
|
158
|
+
doneWaiting();
|
|
159
|
+
});
|
|
160
|
+
test("failure doesn't kill publish loop", async () => {
|
|
161
|
+
// Block on the first sleep call
|
|
162
|
+
let doneWaiting;
|
|
163
|
+
const waitPromise = new Promise(function (resolve) {
|
|
164
|
+
doneWaiting = resolve;
|
|
165
|
+
});
|
|
166
|
+
let startSleeping;
|
|
167
|
+
const sleepPromise = new Promise(function (resolve) {
|
|
168
|
+
startSleeping = resolve;
|
|
169
|
+
});
|
|
170
|
+
jest
|
|
171
|
+
.mocked(sleep_1.default)
|
|
172
|
+
.mockImplementationOnce(async () => {
|
|
173
|
+
throw new Error('Test error!');
|
|
174
|
+
})
|
|
175
|
+
.mockImplementationOnce(async () => {
|
|
176
|
+
startSleeping();
|
|
177
|
+
await waitPromise;
|
|
178
|
+
});
|
|
179
|
+
const enable = { deviceStats: true };
|
|
180
|
+
await liveUpdatesHandler.handleToggles(enable, emptyTxId);
|
|
181
|
+
await sleepPromise;
|
|
182
|
+
expect(jest.mocked(setTimeout)).toBeCalledTimes(1);
|
|
183
|
+
expect(mockClient.publish).toBeCalledTimes(2);
|
|
184
|
+
expect(jest.mocked(sleep_1.default)).toBeCalledTimes(2);
|
|
185
|
+
liveUpdatesHandler.disableDeviceStatsLiveUpdates();
|
|
186
|
+
doneWaiting();
|
|
71
187
|
});
|
|
72
188
|
});
|
|
73
189
|
//# sourceMappingURL=live-updates-handler.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"live-updates-handler.test.js","sourceRoot":"","sources":["../../src/cloud-connection/live-updates-handler.test.ts"],"names":[],"mappings":";;AAAA,iEAA4D;AAC5D,2CAAwC;
|
|
1
|
+
{"version":3,"file":"live-updates-handler.test.js","sourceRoot":"","sources":["../../src/cloud-connection/live-updates-handler.test.ts"],"names":[],"mappings":";;AAAA,iEAA4D;AAC5D,2CAAwC;AACxC,yCAAkC;AAClC,yCAAmD;AAEnD,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;AAC3B,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AAExB,IAAI,CAAC,MAAM,CAAC,gCAAqB,CAAC,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;AAEzD,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,EAAkC,CAAC;AAE9D,wDAAwD;AACxD,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,aAAa,EAAE;IAC3C,QAAQ,EAAE,IAAI;CACf,CAAC,CAAC;AAEH,MAAM,eAAe,GAAG;IACtB,WAAW,EAAE,IAAI;IACjB,QAAQ,EAAE,IAAI;CACf,CAAC;AAEF,MAAM,gBAAgB,GAAG;IACvB,WAAW,EAAE,KAAK;IAClB,QAAQ,EAAE,KAAK;CAChB,CAAC;AAEF,MAAM,UAAU,GAAG;IACjB,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE;CACnB,CAAC;AACF,MAAM,QAAQ,GAAG,aAAa,CAAC;AAC/B,MAAM,SAAS,GAAG,EAAE,CAAC;AAErB,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,IAAI,kBAAsC,CAAC;IAC3C,IAAI,SAAoB,CAAC;IAEzB,UAAU,CAAC,GAAG,EAAE;QACd,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;QAC/B,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,kBAAkB,CAAC,KAAK,IAAI,EAAE;YAC/C,OAAO;QACT,CAAC,CAAC,CAAC;QACH,SAAS,GAAG,IAAI,qBAAS,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QAChD,kBAAkB,GAAG,IAAI,yCAAkB,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QACjE,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,qBAAqB,EAAE,KAAK,IAAI,EAAE;QACrC,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK,IAAI,EAAE;YAC3D,kBAAkB,CAAC,6BAA6B,EAAE,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;QACrC,MAAM,QAAQ,GAAG,MAAM,kBAAkB,CAAC,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC3E,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAE5B,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACnD,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kBAAkB,EAAE,KAAK,IAAI,EAAE;QAClC,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK,IAAI,EAAE;YAC3D,kBAAkB,CAAC,0BAA0B,EAAE,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,MAAM,kBAAkB,CAAC,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC3E,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAE5B,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACnD,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QAC3C,gCAAgC;QAChC,IAAI,WAAW,CAAC;QAChB,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC,UAAU,OAAO;YAC/C,WAAW,GAAG,OAAO,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,IAAI,aAAa,CAAC;QAClB,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC,UAAU,OAAO;YAChD,aAAa,GAAG,OAAO,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,kBAAkB,CAAC,KAAK,IAAI,EAAE;YAC/C,aAAa,EAAE,CAAC;YAChB,MAAM,WAAW,CAAC;QACpB,CAAC,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;QACrC,MAAM,kBAAkB,CAAC,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC1D,MAAM,YAAY,CAAC;QAEnB,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACnD,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAE9C,cAAc;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,MAAM,kBAAkB,CAAC,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAE1D,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAE9C,uBAAuB;QACvB,kBAAkB,CAAC,6BAA6B,EAAE,CAAC;QACnD,WAAW,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QAC3C,IAAI,WAAW,CAAC;QAChB,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC,UAAU,OAAO;YAC/C,WAAW,GAAG,OAAO,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,IAAI,aAAa,CAAC;QAClB,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC,UAAU,OAAO;YAChD,aAAa,GAAG,OAAO,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,uEAAuE;QACvE,IAAI;aACD,MAAM,CAAC,eAAK,CAAC;aACb,sBAAsB,CAAC,KAAK,IAAI,EAAE;YACjC,MAAM,WAAW,CAAC;QACpB,CAAC,CAAC;aACD,sBAAsB,CAAC,KAAK,IAAI,EAAE;YACjC,aAAa,EAAE,CAAC;YAChB,MAAM,WAAW,CAAC;QACpB,CAAC,CAAC,CAAC;QAEL,mDAAmD;QACnD,MAAM,kBAAkB,CAAC,aAAa,CAAC,eAAe,EAAE,SAAS,CAAC,CAAC;QACnE,MAAM,YAAY,CAAC;QAEnB,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,kBAAkB,CAAC,yBAAyB,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClE,MAAM,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/D,MAAM,CAAC,kBAAkB,CAAC,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/D,uEAAuE;QACvE,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,kBAAkB,CAAC,aAAa,CAAC,gBAAgB,EAAE,SAAS,CAAC,CAAC;QAEpE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,kBAAkB,CAAC,yBAAyB,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnE,MAAM,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChE,MAAM,CAAC,kBAAkB,CAAC,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/D,WAAW,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAChD,IAAI,CAAC,aAAa,CAAC,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAC,CAAC;QAC/C,IAAI,WAAW,CAAC;QAChB,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC,UAAU,OAAO;YAC/C,WAAW,GAAG,OAAO,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,IAAI,aAAa,CAAC;QAClB,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC,UAAU,OAAO;YAChD,aAAa,GAAG,OAAO,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,uEAAuE;QACvE,IAAI;aACD,MAAM,CAAC,eAAK,CAAC;aACb,sBAAsB,CAAC,KAAK,IAAI,EAAE;YACjC,MAAM,WAAW,CAAC;QACpB,CAAC,CAAC;aACD,sBAAsB,CAAC,KAAK,IAAI,EAAE;YACjC,aAAa,EAAE,CAAC;YAChB,MAAM,WAAW,CAAC;QACpB,CAAC,CAAC,CAAC;QAEL,MAAM,kBAAkB,CAAC,aAAa,CAAC,eAAe,EAAE,SAAS,CAAC,CAAC;QACnE,MAAM,YAAY,CAAC;QAEnB,MAAM,CAAC,kBAAkB,CAAC,yBAAyB,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClE,MAAM,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/D,MAAM,CAAC,kBAAkB,CAAC,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/D,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,MAAM,CAAC,kBAAkB,CAAC,yBAAyB,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnE,MAAM,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChE,MAAM,CAAC,kBAAkB,CAAC,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/D,WAAW,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;QACnD,gCAAgC;QAChC,IAAI,WAAW,CAAC;QAChB,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC,UAAU,OAAO;YAC/C,WAAW,GAAG,OAAO,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,IAAI,aAAa,CAAC;QAClB,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC,UAAU,OAAO;YAChD,aAAa,GAAG,OAAO,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,IAAI;aACD,MAAM,CAAC,eAAK,CAAC;aACb,sBAAsB,CAAC,KAAK,IAAI,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,aAAa,CAAC,CAAC;QACjC,CAAC,CAAC;aACD,sBAAsB,CAAC,KAAK,IAAI,EAAE;YACjC,aAAa,EAAE,CAAC;YAChB,MAAM,WAAW,CAAC;QACpB,CAAC,CAAC,CAAC;QAEL,MAAM,MAAM,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;QACrC,MAAM,kBAAkB,CAAC,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC1D,MAAM,YAAY,CAAC;QAEnB,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACnD,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,eAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAE9C,kBAAkB,CAAC,6BAA6B,EAAE,CAAC;QACnD,WAAW,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"messages.d.ts","sourceRoot":"","sources":["../../src/cloud-connection/messages.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,eAAe,EACf,kBAAkB,EACnB,MAAM,gCAAgC,CAAC;AASxC,wBAAsB,kBAAkB,IAAI,OAAO,CAAC,eAAe,CAAC,
|
|
1
|
+
{"version":3,"file":"messages.d.ts","sourceRoot":"","sources":["../../src/cloud-connection/messages.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,eAAe,EACf,kBAAkB,EACnB,MAAM,gCAAgC,CAAC;AASxC,wBAAsB,kBAAkB,IAAI,OAAO,CAAC,eAAe,CAAC,CAWnE;AAED,wBAAsB,qBAAqB,IAAI,OAAO,CAAC,kBAAkB,CAAC,CAWzE"}
|
|
@@ -5,15 +5,14 @@ const application_control_1 = require("../application-control");
|
|
|
5
5
|
const device_control_1 = require("../device-control/device-control");
|
|
6
6
|
const agent_config_1 = require("../infrastructure/agent-config");
|
|
7
7
|
async function getAppStatePayload() {
|
|
8
|
-
const
|
|
8
|
+
const appStatePromises = [];
|
|
9
9
|
const apps = await (0, agent_config_1.AgentConfigFile)().getApps();
|
|
10
10
|
for (const app of apps) {
|
|
11
11
|
const projectId = app.projectId;
|
|
12
|
-
|
|
13
|
-
appState.push(status);
|
|
12
|
+
appStatePromises.push((0, application_control_1.getAppState)({ projectId }));
|
|
14
13
|
}
|
|
15
14
|
const appStatePayload = {
|
|
16
|
-
appState:
|
|
15
|
+
appState: await Promise.all(appStatePromises)
|
|
17
16
|
};
|
|
18
17
|
return appStatePayload;
|
|
19
18
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../src/cloud-connection/messages.ts"],"names":[],"mappings":";;;AAKA,gEAAqD;AACrD,qEAI0C;AAC1C,iEAAiE;AAE1D,KAAK,UAAU,kBAAkB;IACtC,MAAM,
|
|
1
|
+
{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../src/cloud-connection/messages.ts"],"names":[],"mappings":";;;AAKA,gEAAqD;AACrD,qEAI0C;AAC1C,iEAAiE;AAE1D,KAAK,UAAU,kBAAkB;IACtC,MAAM,gBAAgB,GAAwB,EAAE,CAAC;IACjD,MAAM,IAAI,GAAG,MAAM,IAAA,8BAAe,GAAE,CAAC,OAAO,EAAE,CAAC;IAC/C,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;QACtB,MAAM,SAAS,GAAG,GAAG,CAAC,SAAS,CAAC;QAChC,gBAAgB,CAAC,IAAI,CAAC,IAAA,iCAAW,EAAC,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;KACnD;IACD,MAAM,eAAe,GAAG;QACtB,QAAQ,EAAE,MAAM,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC;KAC9C,CAAC;IACF,OAAO,eAAe,CAAC;AACzB,CAAC;AAXD,gDAWC;AAEM,KAAK,UAAU,qBAAqB;IACzC,MAAM,UAAU,GAAG,MAAM,IAAA,8BAAa,GAAE,CAAC;IACzC,MAAM,WAAW,GAAG,MAAM,IAAA,+BAAc,GAAE,CAAC;IAC3C,MAAM,UAAU,GAAG,MAAM,IAAA,8BAAa,GAAE,CAAC;IAEzC,MAAM,kBAAkB,GAAuB;QAC7C,UAAU;QACV,WAAW;QACX,UAAU;KACX,CAAC;IACF,OAAO,kBAAkB,CAAC;AAC5B,CAAC;AAXD,sDAWC"}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
|
+
import * as amqp from 'amqplib';
|
|
1
2
|
import { Publisher } from './publisher';
|
|
2
3
|
export declare class PassthroughHandler {
|
|
3
4
|
publisher: Publisher;
|
|
4
|
-
connection:
|
|
5
|
-
channel:
|
|
5
|
+
connection: amqp.Connection | undefined;
|
|
6
|
+
channel: amqp.Channel;
|
|
6
7
|
packetQueue: any;
|
|
7
8
|
constructor(publisher: Publisher);
|
|
9
|
+
runChannel: () => Promise<void>;
|
|
10
|
+
establishLocalConnection(): Promise<void>;
|
|
8
11
|
setup(): Promise<void>;
|
|
9
12
|
}
|
|
10
|
-
export declare function runChannel(passthroughHandler: PassthroughHandler): Promise<void>;
|
|
11
13
|
//# sourceMappingURL=passthrough-handler.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"passthrough-handler.d.ts","sourceRoot":"","sources":["../../src/cloud-connection/passthrough-handler.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"passthrough-handler.d.ts","sourceRoot":"","sources":["../../src/cloud-connection/passthrough-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,SAAS,CAAC;AAYhC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAMxC,qBAAa,kBAAkB;IACtB,SAAS,EAAE,SAAS,CAAC;IACrB,UAAU,EAAE,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IACxC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC;IACtB,WAAW,MAAC;gBAEP,SAAS,EAAE,SAAS;IAIhC,UAAU,sBAgER;IAEI,wBAAwB,IAAI,OAAO,CAAC,IAAI,CAAC;IA8ClC,KAAK;CAiBnB"}
|