@dronedeploy/rocos-js-sdk 3.0.1-alpha.11 → 3.0.1-alpha.14

Sign up to get free protection for your applications and to get access to all the features.
Files changed (121) hide show
  1. package/cjs/RocosSDK.d.ts +3 -1
  2. package/cjs/RocosSDK.js +1 -0
  3. package/cjs/api/streams/caller/CallerStream.js +5 -2
  4. package/cjs/api/streams/caller/CallerStreamNode.js +2 -1
  5. package/cjs/api/streams/command/CommandStream.js +5 -2
  6. package/cjs/api/streams/command/CommandStreamNode.js +2 -1
  7. package/cjs/api/streams/control/ControlStream.js +5 -2
  8. package/cjs/api/streams/control/ControlStreamAbstract.d.ts +1 -1
  9. package/cjs/api/streams/control/ControlStreamNode.js +2 -1
  10. package/cjs/api/streams/fileAccessor/FileAccessorStream.js +4 -1
  11. package/cjs/api/streams/fileAccessor/FileAccessorStreamNode.js +3 -1
  12. package/cjs/api/streams/search/SearchStream.js +5 -2
  13. package/cjs/api/streams/search/SearchStreamNode.js +2 -1
  14. package/cjs/api/streams/telemetry/TelemetryStream.js +4 -1
  15. package/cjs/api/streams/telemetry/TelemetryStreamAbstract.d.ts +1 -1
  16. package/cjs/api/streams/telemetry/TelemetryStreamNode.js +2 -1
  17. package/cjs/api/streams/webRTCSignalling/WebRTCSignallingStream.js +5 -2
  18. package/cjs/constants/api.d.ts +2 -0
  19. package/cjs/constants/api.js +4 -2
  20. package/cjs/helpers/getUniqueConfigKey.d.ts +6 -2
  21. package/cjs/helpers/getUniqueConfigKey.js +7 -2
  22. package/cjs/services/ProfileService.d.ts +23 -0
  23. package/cjs/services/ProfileService.js +28 -0
  24. package/cjs/services/RTPWebRTCService.d.ts +1 -1
  25. package/cjs/services/RTPWebRTCService.js +4 -2
  26. package/cjs/store/RocosStore.d.ts +1 -2
  27. package/esm/RocosSDK.d.ts +3 -1
  28. package/esm/RocosSDK.js +1 -0
  29. package/esm/api/streams/caller/CallerStream.js +5 -2
  30. package/esm/api/streams/caller/CallerStreamNode.js +2 -1
  31. package/esm/api/streams/command/CommandStream.js +5 -2
  32. package/esm/api/streams/command/CommandStreamNode.js +2 -1
  33. package/esm/api/streams/control/ControlStream.js +5 -2
  34. package/esm/api/streams/control/ControlStreamAbstract.d.ts +1 -1
  35. package/esm/api/streams/control/ControlStreamNode.js +2 -1
  36. package/esm/api/streams/fileAccessor/FileAccessorStream.js +4 -1
  37. package/esm/api/streams/fileAccessor/FileAccessorStreamNode.js +3 -1
  38. package/esm/api/streams/search/SearchStream.js +5 -2
  39. package/esm/api/streams/search/SearchStreamNode.js +2 -1
  40. package/esm/api/streams/telemetry/TelemetryStream.js +4 -1
  41. package/esm/api/streams/telemetry/TelemetryStreamAbstract.d.ts +1 -1
  42. package/esm/api/streams/telemetry/TelemetryStreamNode.js +2 -1
  43. package/esm/api/streams/webRTCSignalling/WebRTCSignallingStream.js +5 -2
  44. package/esm/constants/api.d.ts +2 -0
  45. package/esm/constants/api.js +2 -0
  46. package/esm/helpers/getUniqueConfigKey.d.ts +6 -2
  47. package/esm/helpers/getUniqueConfigKey.js +7 -2
  48. package/esm/services/ProfileService.d.ts +23 -0
  49. package/esm/services/ProfileService.js +29 -1
  50. package/esm/services/RTPWebRTCService.d.ts +1 -1
  51. package/esm/services/RTPWebRTCService.js +4 -2
  52. package/esm/store/RocosStore.d.ts +1 -2
  53. package/package.json +1 -1
  54. package/cjs/helpers/cleanObject.spec.d.ts +0 -1
  55. package/cjs/helpers/cleanObject.spec.js +0 -55
  56. package/cjs/helpers/flattenObject.spec.d.ts +0 -1
  57. package/cjs/helpers/flattenObject.spec.js +0 -31
  58. package/cjs/helpers/flattenOneOf.spec.d.ts +0 -1
  59. package/cjs/helpers/flattenOneOf.spec.js +0 -159
  60. package/cjs/helpers/formatServiceUrl.spec.d.ts +0 -1
  61. package/cjs/helpers/formatServiceUrl.spec.js +0 -18
  62. package/cjs/helpers/getSha256Hex.spec.d.ts +0 -1
  63. package/cjs/helpers/getSha256Hex.spec.js +0 -19
  64. package/cjs/helpers/getSha256HexNode.spec.d.ts +0 -1
  65. package/cjs/helpers/getSha256HexNode.spec.js +0 -10
  66. package/cjs/helpers/getURLSearchParams.spec.d.ts +0 -1
  67. package/cjs/helpers/getURLSearchParams.spec.js +0 -21
  68. package/cjs/helpers/nanosecondToMillisecond.spec.d.ts +0 -1
  69. package/cjs/helpers/nanosecondToMillisecond.spec.js +0 -22
  70. package/cjs/helpers/splitRobotTopic.spec.d.ts +0 -1
  71. package/cjs/helpers/splitRobotTopic.spec.js +0 -53
  72. package/cjs/helpers/standardDeviation.spec.d.ts +0 -1
  73. package/cjs/helpers/standardDeviation.spec.js +0 -13
  74. package/cjs/helpers/websandbox/frame/worker/manager.spec.d.ts +0 -4
  75. package/cjs/helpers/websandbox/frame/worker/manager.spec.js +0 -132
  76. package/cjs/models/Token.spec.d.ts +0 -1
  77. package/cjs/models/Token.spec.js +0 -110
  78. package/cjs/services/AuthService.spec.d.ts +0 -1
  79. package/cjs/services/AuthService.spec.js +0 -165
  80. package/cjs/services/CallerService.spec.d.ts +0 -1
  81. package/cjs/services/CallerService.spec.js +0 -229
  82. package/cjs/services/PlatformTimeService.spec.d.ts +0 -1
  83. package/cjs/services/PlatformTimeService.spec.js +0 -182
  84. package/cjs/services/RTPWebRTCService.spec.d.ts +0 -4
  85. package/cjs/services/RTPWebRTCService.spec.js +0 -171
  86. package/cjs/services/TelemetryService.spec.d.ts +0 -1
  87. package/cjs/services/TelemetryService.spec.js +0 -39
  88. package/esm/helpers/cleanObject.spec.d.ts +0 -1
  89. package/esm/helpers/cleanObject.spec.js +0 -53
  90. package/esm/helpers/flattenObject.spec.d.ts +0 -1
  91. package/esm/helpers/flattenObject.spec.js +0 -29
  92. package/esm/helpers/flattenOneOf.spec.d.ts +0 -1
  93. package/esm/helpers/flattenOneOf.spec.js +0 -157
  94. package/esm/helpers/formatServiceUrl.spec.d.ts +0 -1
  95. package/esm/helpers/formatServiceUrl.spec.js +0 -16
  96. package/esm/helpers/getSha256Hex.spec.d.ts +0 -1
  97. package/esm/helpers/getSha256Hex.spec.js +0 -14
  98. package/esm/helpers/getSha256HexNode.spec.d.ts +0 -1
  99. package/esm/helpers/getSha256HexNode.spec.js +0 -8
  100. package/esm/helpers/getURLSearchParams.spec.d.ts +0 -1
  101. package/esm/helpers/getURLSearchParams.spec.js +0 -19
  102. package/esm/helpers/nanosecondToMillisecond.spec.d.ts +0 -1
  103. package/esm/helpers/nanosecondToMillisecond.spec.js +0 -20
  104. package/esm/helpers/splitRobotTopic.spec.d.ts +0 -1
  105. package/esm/helpers/splitRobotTopic.spec.js +0 -51
  106. package/esm/helpers/standardDeviation.spec.d.ts +0 -1
  107. package/esm/helpers/standardDeviation.spec.js +0 -11
  108. package/esm/helpers/websandbox/frame/worker/manager.spec.d.ts +0 -4
  109. package/esm/helpers/websandbox/frame/worker/manager.spec.js +0 -127
  110. package/esm/models/Token.spec.d.ts +0 -1
  111. package/esm/models/Token.spec.js +0 -108
  112. package/esm/services/AuthService.spec.d.ts +0 -1
  113. package/esm/services/AuthService.spec.js +0 -163
  114. package/esm/services/CallerService.spec.d.ts +0 -1
  115. package/esm/services/CallerService.spec.js +0 -227
  116. package/esm/services/PlatformTimeService.spec.d.ts +0 -1
  117. package/esm/services/PlatformTimeService.spec.js +0 -180
  118. package/esm/services/RTPWebRTCService.spec.d.ts +0 -4
  119. package/esm/services/RTPWebRTCService.spec.js +0 -169
  120. package/esm/services/TelemetryService.spec.d.ts +0 -1
  121. package/esm/services/TelemetryService.spec.js +0 -37
@@ -1,182 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const PlatformTimeService_1 = require("./PlatformTimeService");
4
- const TimeSyncerService_1 = require("./TimeSyncerService");
5
- const helpers_1 = require("../helpers");
6
- // Subclass PlatformTimeService so that we can test the protected methods
7
- class PlatformtimeServicePublic extends PlatformTimeService_1.PlatFormTimeService {
8
- constructor(timeSyncerService) {
9
- super(timeSyncerService);
10
- }
11
- isReliableServerTime(platformTimeMeasurement) {
12
- return super.isReliableServerTime(platformTimeMeasurement);
13
- }
14
- calculateOffset(platformTimeMeasurement) {
15
- return super.calculateOffset(platformTimeMeasurement);
16
- }
17
- removeLongestAndShortest(platformTimeMeasurement) {
18
- return super.removeLongestAndShortest(platformTimeMeasurement);
19
- }
20
- static getInstance(timeSyncerService) {
21
- const instance = super.getInstance(timeSyncerService);
22
- return instance;
23
- }
24
- }
25
- describe('platformTimeService', () => {
26
- it('should calculate standard deviation correctly', () => {
27
- let numbers = [10, 12, 23, 23, 16, 23, 21, 16];
28
- let stdDev = (0, helpers_1.standardDeviation)(numbers);
29
- expect(Math.abs(stdDev - 4.8989794855664)).toBeLessThan(0.000001);
30
- numbers = [100, 12, 23, 23, 116, 23, 21, 162];
31
- stdDev = (0, helpers_1.standardDeviation)(numbers);
32
- expect(Math.abs(stdDev - 53.702886328394)).toBeLessThan(0.000001);
33
- });
34
- it('should be able to tell reliable server time response', () => {
35
- jest.useFakeTimers();
36
- const p = PlatformtimeServicePublic.getInstance(new TimeSyncerService_1.TimeSyncerService({}));
37
- const mock = {
38
- clientTimeStampEnd: 100,
39
- clientTimeStampStart: 20,
40
- serverTime: {
41
- now: 0,
42
- duration: 0,
43
- },
44
- };
45
- const mocks = [];
46
- mocks.push(mock);
47
- let isReliableServerTime = p.isReliableServerTime(mocks);
48
- expect(isReliableServerTime).toBeTruthy();
49
- for (let i = 0; i < 4; i++) {
50
- mocks.push({ ...mock });
51
- isReliableServerTime = p.isReliableServerTime(mocks);
52
- expect(isReliableServerTime).toBeTruthy();
53
- }
54
- });
55
- it('should be able to tell unreliable server time response', () => {
56
- jest.useFakeTimers();
57
- const p = PlatformtimeServicePublic.getInstance(new TimeSyncerService_1.TimeSyncerService({}));
58
- const mock = {
59
- clientTimeStampEnd: 100,
60
- clientTimeStampStart: 0,
61
- serverTime: {
62
- now: 0,
63
- duration: 0,
64
- },
65
- };
66
- const mocks = [];
67
- let isReliableServerTime = false;
68
- for (let i = 0; i < 5; i++) {
69
- const mockClone = { ...mock };
70
- mockClone.clientTimeStampEnd += i * 60;
71
- mocks.push(mockClone);
72
- }
73
- isReliableServerTime = p.isReliableServerTime(mocks);
74
- expect(isReliableServerTime).toBeTruthy();
75
- for (let i = 0; i < 5; i++) {
76
- const mockClone = { ...mock };
77
- mockClone.clientTimeStampEnd += i * 70;
78
- mocks.push(mockClone);
79
- }
80
- isReliableServerTime = p.isReliableServerTime(mocks);
81
- expect(isReliableServerTime).toBeTruthy();
82
- for (let i = 0; i < 5; i++) {
83
- const mockClone = { ...mock };
84
- mockClone.clientTimeStampEnd += i * 80;
85
- mocks.push(mockClone);
86
- }
87
- isReliableServerTime = p.isReliableServerTime(mocks);
88
- // std dev = 113.13708498985
89
- expect(isReliableServerTime).toBeFalsy();
90
- for (let i = 0; i < 5; i++) {
91
- const mockClone = { ...mock };
92
- mockClone.clientTimeStampEnd += i * 100;
93
- mocks.push(mockClone);
94
- }
95
- isReliableServerTime = p.isReliableServerTime(mocks);
96
- expect(isReliableServerTime).toBeFalsy();
97
- });
98
- it('should be able to remove shortest and longest correctly', () => {
99
- jest.useFakeTimers();
100
- const p = PlatformtimeServicePublic.getInstance(new TimeSyncerService_1.TimeSyncerService({}));
101
- const mock = {
102
- clientTimeStampEnd: 100,
103
- clientTimeStampStart: 0,
104
- serverTime: {
105
- now: 0,
106
- duration: 0,
107
- },
108
- };
109
- const mocks = [];
110
- let mockClone = { ...mock };
111
- mockClone.clientTimeStampEnd = 100;
112
- mocks.push(mockClone);
113
- mockClone = { ...mock };
114
- mockClone.clientTimeStampEnd = 200;
115
- mocks.push(mockClone);
116
- mockClone = { ...mock };
117
- mockClone.clientTimeStampEnd = 500;
118
- mocks.push(mockClone);
119
- mockClone = { ...mock };
120
- mockClone.clientTimeStampEnd = 400;
121
- mocks.push(mockClone);
122
- mockClone = { ...mock };
123
- mockClone.clientTimeStampEnd = 300;
124
- mocks.push(mockClone);
125
- const platformTimeMeasurement = p.removeLongestAndShortest(mocks);
126
- platformTimeMeasurement.forEach((p) => {
127
- expect(p.clientTimeStampEnd).not.toEqual(100);
128
- expect(p.clientTimeStampEnd).not.toEqual(500);
129
- });
130
- });
131
- it('should be able to calculate the offset correctly', () => {
132
- jest.useFakeTimers();
133
- const p = PlatformtimeServicePublic.getInstance(new TimeSyncerService_1.TimeSyncerService({}));
134
- const mock = {
135
- clientTimeStampEnd: 100,
136
- clientTimeStampStart: 0,
137
- serverTime: {
138
- now: 0,
139
- duration: 0,
140
- },
141
- };
142
- const mocks = [];
143
- let mockClone = { ...mock };
144
- mockClone.clientTimeStampEnd = 200;
145
- mocks.push(mockClone);
146
- mockClone = { ...mock };
147
- mockClone.clientTimeStampEnd = 500;
148
- mocks.push(mockClone);
149
- mockClone = { ...mock };
150
- mockClone.clientTimeStampEnd = 400;
151
- mocks.push(mockClone);
152
- const offset = p.calculateOffset(mocks);
153
- // (200-(200)/2 + 500 - (500)/2 + 400 - (400)/2)/3 = 183.333333333, round to 183
154
- expect(offset).toEqual(183);
155
- });
156
- it('should be able to filter where service time is not provided', () => {
157
- jest.useFakeTimers();
158
- const p = PlatformtimeServicePublic.getInstance(new TimeSyncerService_1.TimeSyncerService({}));
159
- const mock = {
160
- clientTimeStampEnd: 100,
161
- clientTimeStampStart: 0,
162
- serverTime: {
163
- now: 0,
164
- duration: 0,
165
- },
166
- };
167
- const mocks = [];
168
- let mockClone = { ...mock };
169
- mockClone.clientTimeStampEnd = 200;
170
- mockClone.serverTime = undefined;
171
- mocks.push(mockClone);
172
- mockClone = { ...mock };
173
- mockClone.clientTimeStampEnd = 500;
174
- mocks.push(mockClone);
175
- mockClone = { ...mock };
176
- mockClone.clientTimeStampEnd = 400;
177
- mocks.push(mockClone);
178
- const offset = p.calculateOffset(mocks);
179
- // (500 - (500)/2 + 400 - (400)/2)/2 = 225
180
- expect(offset).toEqual(225);
181
- });
182
- });
@@ -1,4 +0,0 @@
1
- /**
2
- * @jest-environment jsdom
3
- */
4
- export {};
@@ -1,171 +0,0 @@
1
- "use strict";
2
- /**
3
- * @jest-environment jsdom
4
- */
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const rxjs_1 = require("rxjs");
7
- const RTPWebRTCService_1 = require("./RTPWebRTCService");
8
- class WebRTCMockHelper {
9
- constructor() {
10
- this.dataChannel = {
11
- label: 'submanager',
12
- onopen: () => void 0,
13
- onclose: () => void 0,
14
- onmessage: (e) => void 0,
15
- send: this.sendMessage.bind(this),
16
- close: this.close.bind(this),
17
- };
18
- this.connection = {
19
- ontrack: (event) => void 0,
20
- oniceconnectionstatechange: () => void 0,
21
- onicecandidate: async (event) => void 0,
22
- setRemoteDescription: jest.fn(),
23
- iceConnectionState: 'new',
24
- localDescription: null,
25
- createDataChannel: jest.fn().mockReturnValue(this.dataChannel),
26
- addTransceiver: jest.fn(),
27
- createOffer: this.createOffer.bind(this),
28
- setLocalDescription: jest.fn(),
29
- close: this.close.bind(this),
30
- };
31
- this.streams = [];
32
- }
33
- installMocks() {
34
- ;
35
- global.RTCPeerConnection = jest.fn().mockReturnValue(this.connection);
36
- global.RTCSessionDescription = jest.fn();
37
- this.mockFetch();
38
- }
39
- async createOffer() {
40
- await this.connection.onicecandidate({
41
- candidate: null,
42
- });
43
- this.connection.iceConnectionState = 'checking';
44
- this.connection.oniceconnectionstatechange();
45
- this.addTrack('my-stream-1');
46
- this.addTrack('my-stream-2');
47
- this.connection.iceConnectionState = 'connected';
48
- this.connection.oniceconnectionstatechange();
49
- this.dataChannel.onopen();
50
- return {
51
- sdp: 'my-sdp',
52
- type: 'offer',
53
- };
54
- }
55
- addTrack(name) {
56
- const stream = { name, active: true };
57
- this.streams.push(stream);
58
- this.connection.ontrack({
59
- streams: [stream],
60
- });
61
- }
62
- close() {
63
- this.streams.forEach((stream) => {
64
- stream.active = false;
65
- });
66
- this.dataChannel.onclose();
67
- this.connection.iceConnectionState = 'closed';
68
- this.connection.oniceconnectionstatechange();
69
- }
70
- sendMessage(message) {
71
- const { logLevel } = JSON.parse(message);
72
- if (logLevel === 'trace') {
73
- this.dataChannel.onmessage({
74
- data: message,
75
- });
76
- }
77
- }
78
- mockFetch() {
79
- global.fetch = jest.fn().mockImplementation((url) => {
80
- switch (url) {
81
- case 'https://localhost:0/sdp/configs':
82
- return Promise.resolve({
83
- json: () => ({
84
- iceServers: [
85
- {
86
- urls: ['stun:turn.localhost:443'],
87
- },
88
- ],
89
- }),
90
- });
91
- case 'https://localhost:0/sdp':
92
- return Promise.resolve({
93
- json: () => ({
94
- answer: btoa('null'),
95
- }),
96
- });
97
- default:
98
- throw new Error(`Unexpected URL: ${url}`);
99
- }
100
- });
101
- }
102
- }
103
- describe('RTPWebRTCService', () => {
104
- let service;
105
- beforeEach(() => {
106
- service = new RTPWebRTCService_1.RTPWebRTCService({
107
- url: 'localhost',
108
- port: 0,
109
- token: 'test',
110
- });
111
- });
112
- describe('streams$', () => {
113
- it('should emit a stream when a new stream is added', async () => {
114
- // Arrange
115
- new WebRTCMockHelper().installMocks();
116
- const connection = service.createPeerConnection({
117
- projectId: 'my-project',
118
- callsign: 'my-callsign',
119
- logLevel: 'trace',
120
- });
121
- // Act
122
- const streams = await (0, rxjs_1.lastValueFrom)(connection.streams$.pipe((0, rxjs_1.takeUntil)(connection.connect()), (0, rxjs_1.toArray)()));
123
- // Assert
124
- expect(streams).toEqual([
125
- [
126
- {
127
- name: 'my-stream-1',
128
- active: true,
129
- },
130
- ],
131
- [
132
- {
133
- name: 'my-stream-1',
134
- active: true,
135
- },
136
- {
137
- name: 'my-stream-2',
138
- active: true,
139
- },
140
- ],
141
- ]);
142
- });
143
- it('should reset the streams when the connection is disconnected and the streams become inactive', async () => {
144
- // Arrange
145
- new WebRTCMockHelper().installMocks();
146
- const connection = service.createPeerConnection({
147
- projectId: 'my-project',
148
- callsign: 'my-callsign',
149
- logLevel: 'trace',
150
- });
151
- // Act
152
- const streams = await (0, rxjs_1.lastValueFrom)(connection.streams$.pipe((0, rxjs_1.takeUntil)((async () => {
153
- await connection.connect();
154
- connection.disconnect();
155
- await connection.connect();
156
- })()), (0, rxjs_1.toArray)()));
157
- expect(streams).toEqual([
158
- [{ name: 'my-stream-1', active: false }],
159
- [
160
- { name: 'my-stream-1', active: false },
161
- { name: 'my-stream-2', active: false },
162
- ],
163
- [{ name: 'my-stream-1', active: true }],
164
- [
165
- { name: 'my-stream-1', active: true },
166
- { name: 'my-stream-2', active: true },
167
- ],
168
- ]);
169
- });
170
- });
171
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,39 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const models_1 = require("../models");
4
- const rxjs_1 = require("rxjs");
5
- const TelemetryService_1 = require("./TelemetryService");
6
- describe('TelemetryService', () => {
7
- describe('getRobotStatusChanges', () => {
8
- it('should emit unknown to begin with', async () => {
9
- const service = new TelemetryService_1.TelemetryService({ url: '', token: '' });
10
- // Mock 5 heartbeat messages
11
- jest.spyOn(service, 'subscribe').mockReturnValue(rxjs_1.NEVER);
12
- const lastValue = await (0, rxjs_1.lastValueFrom)(service.getRobotStatusChanges('project', 'callsign').pipe((0, rxjs_1.take)(1)));
13
- expect(lastValue).toEqual(models_1.CallsignStatus.UNKNOWN);
14
- });
15
- it('should emit online if the robot emits a heartbeat', async () => {
16
- const service = new TelemetryService_1.TelemetryService({ url: '', token: '' });
17
- // Mock 5 heartbeat messages
18
- jest
19
- .spyOn(service, 'subscribe')
20
- .mockReturnValue((0, rxjs_1.from)([0, 1, 2, 3, 4]).pipe((0, rxjs_1.delay)(100)));
21
- const lastValue = await (0, rxjs_1.lastValueFrom)(service.getRobotStatusChanges('project', 'callsign', 1000, 10).pipe((0, rxjs_1.take)(2)));
22
- expect(lastValue).toEqual(models_1.CallsignStatus.ONLINE);
23
- }, 10000);
24
- it('should emit offline if the robot never emits', async () => {
25
- const service = new TelemetryService_1.TelemetryService({ url: '', token: '' });
26
- // Mock 5 heartbeat messages
27
- jest.spyOn(service, 'subscribe').mockReturnValue(rxjs_1.NEVER);
28
- const lastValue = await (0, rxjs_1.lastValueFrom)(service.getRobotStatusChanges('project', 'callsign', 100, 10).pipe((0, rxjs_1.take)(2)));
29
- expect(lastValue).toEqual(models_1.CallsignStatus.OFFLINE);
30
- });
31
- it('should emit an error if the telemetry errors', async () => {
32
- const service = new TelemetryService_1.TelemetryService({ url: '', token: '' });
33
- // Mock 5 heartbeat messages
34
- jest.spyOn(service, 'subscribe').mockReturnValue((0, rxjs_1.throwError)(() => new Error('test')));
35
- const lastValue = await (0, rxjs_1.lastValueFrom)(service.getRobotStatusChanges('project', 'callsign', 100, 10).pipe((0, rxjs_1.take)(2)));
36
- expect(lastValue).toEqual(models_1.CallsignStatus.ERROR);
37
- });
38
- });
39
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,53 +0,0 @@
1
- import { cleanObject } from "./cleanObject";
2
- describe('cleanObject', () => {
3
- const testObject = {
4
- test1: 'test1',
5
- test2: 'test2',
6
- test3: () => 'test3',
7
- test4: {
8
- test1: 'test1.1',
9
- test5: 'test5',
10
- test6: {
11
- test7: 'test7',
12
- test1: 'test1.2',
13
- test2: 'test2.1',
14
- test8: () => 'test8',
15
- },
16
- test8: () => 'test8',
17
- },
18
- test9: ['test9.1', 'test9.2', () => 'test8'],
19
- test10: [
20
- {
21
- test7: 'test7',
22
- test1: 'test1.2',
23
- test2: 'test2.1',
24
- test8: () => 'test8',
25
- },
26
- {
27
- test8: () => 'test8',
28
- },
29
- ],
30
- };
31
- it('should clean object to values only', () => {
32
- const newObject = cleanObject(testObject);
33
- expect(newObject?.test3).toBeUndefined();
34
- expect(newObject?.test4?.test8).toBeUndefined();
35
- expect(newObject?.test4?.test6?.test8).toBeUndefined();
36
- expect(newObject?.test4?.test5).toEqual('test5');
37
- expect(newObject?.test5).toBeUndefined();
38
- expect(newObject?.test4?.test6?.test1).toEqual('test1.2');
39
- expect(newObject?.test4?.test6?.test2).toEqual('test2.1');
40
- expect(newObject?.test1).toEqual('test1');
41
- expect(newObject?.test2).toEqual('test2');
42
- expect(newObject?.test9).toEqual(expect.arrayContaining(['test9.1', 'test9.2']));
43
- expect(newObject?.test9).toEqual(expect.not.arrayContaining([() => 'test8']));
44
- expect(newObject?.test10).toEqual(expect.arrayContaining([
45
- {
46
- test7: 'test7',
47
- test1: 'test1.2',
48
- test2: 'test2.1',
49
- },
50
- {},
51
- ]));
52
- });
53
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,29 +0,0 @@
1
- import { flattenObject } from './flattenObject';
2
- describe('flattenObject', () => {
3
- const testObject = {
4
- test1: 'test1',
5
- test2: 'test2',
6
- test3: () => 'test3',
7
- test4: {
8
- test1: 'test1.1',
9
- test5: 'test5',
10
- test6: {
11
- test7: 'test7',
12
- test1: 'test1.2',
13
- test2: 'test2.1',
14
- test8: () => 'test8',
15
- },
16
- test8: () => 'test8',
17
- },
18
- };
19
- it('should flatten object to a single level', () => {
20
- const newObject = flattenObject(testObject);
21
- expect(newObject?.test3).toBeUndefined();
22
- expect(newObject?.test4?.test8).toBeUndefined();
23
- expect(newObject?.test4?.test6?.test8).toBeUndefined();
24
- expect(newObject?.test4?.test5).toBeUndefined();
25
- expect(newObject?.test5).toEqual('test5');
26
- expect(newObject?.test1).toEqual('test1.2');
27
- expect(newObject?.test2).toEqual('test2.1');
28
- });
29
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,157 +0,0 @@
1
- import { flattenOneOf, hasOneOfField } from './flattenOneOf';
2
- describe('flattenOneOf', () => {
3
- describe('hasOneOfField', () => {
4
- it('should return false for non-object', () => {
5
- expect(hasOneOfField(null)).toBe(false);
6
- expect(hasOneOfField(undefined)).toBe(false);
7
- expect(hasOneOfField(1)).toBe(false);
8
- expect(hasOneOfField('')).toBe(false);
9
- expect(hasOneOfField(true)).toBe(false);
10
- });
11
- it('should return false for null content', () => {
12
- expect(hasOneOfField({ content: null })).toBe(false);
13
- });
14
- it('should return false for non-object content', () => {
15
- expect(hasOneOfField({ content: 1 })).toBe(false);
16
- expect(hasOneOfField({ content: '' })).toBe(false);
17
- expect(hasOneOfField({ content: true })).toBe(false);
18
- });
19
- it('should return false for non-string oneofKind', () => {
20
- expect(hasOneOfField({ content: { oneofKind: 1 } })).toBe(false);
21
- expect(hasOneOfField({ content: { oneofKind: null } })).toBe(false);
22
- expect(hasOneOfField({ content: { oneofKind: true } })).toBe(false);
23
- expect(hasOneOfField({ content: { oneofKind: {} } })).toBe(false);
24
- });
25
- it('should return true for valid oneOfField', () => {
26
- expect(hasOneOfField({ content: { oneofKind: 'test' } })).toBe(true);
27
- });
28
- });
29
- describe('flattenOneOf', () => {
30
- it('should flatten a simple oneof type', () => {
31
- const a = {
32
- a: 'a',
33
- content: {
34
- oneofKind: 'b',
35
- b: true,
36
- },
37
- };
38
- expect(flattenOneOf(a)).toEqual({
39
- a: 'a',
40
- b: true,
41
- });
42
- });
43
- it('should flatten a nested oneof type, one level only', () => {
44
- const a = {
45
- b: {
46
- content: {
47
- oneofKind: 'c',
48
- c: true,
49
- },
50
- },
51
- content: {
52
- oneofKind: 'd',
53
- d: {
54
- content: {
55
- oneofKind: 'e',
56
- e: 5,
57
- },
58
- },
59
- },
60
- };
61
- expect(flattenOneOf(a)).toEqual({
62
- b: {
63
- content: {
64
- oneofKind: 'c',
65
- c: true,
66
- },
67
- },
68
- d: {
69
- content: {
70
- oneofKind: 'e',
71
- e: 5,
72
- },
73
- },
74
- });
75
- });
76
- it('should flatten to undefined if the referenced property does not exist', () => {
77
- const a = {
78
- content: {
79
- oneofKind: 'b',
80
- c: true,
81
- },
82
- };
83
- expect(flattenOneOf(a)).toEqual({
84
- b: undefined,
85
- });
86
- });
87
- it('should return the original object if it does not have a oneof field', () => {
88
- const a = {
89
- a: 'a',
90
- b: 'b',
91
- };
92
- expect(flattenOneOf(a)).toEqual(a);
93
- });
94
- });
95
- describe('flattenOneOf - deep', () => {
96
- it('should flatten a simple oneof type', () => {
97
- const a = {
98
- a: 'a',
99
- content: {
100
- oneofKind: 'b',
101
- b: {
102
- d: 4,
103
- },
104
- },
105
- };
106
- expect(flattenOneOf(a, true)).toEqual({
107
- a: 'a',
108
- b: { d: 4 },
109
- });
110
- });
111
- it('should flatten a nested oneof type, all levels', () => {
112
- const a = {
113
- b: {
114
- content: {
115
- oneofKind: 'c',
116
- c: true,
117
- },
118
- },
119
- content: {
120
- oneofKind: 'd',
121
- d: {
122
- content: {
123
- oneofKind: 'e',
124
- e: 5,
125
- },
126
- },
127
- },
128
- };
129
- expect(flattenOneOf(a, true)).toEqual({
130
- b: {
131
- c: true,
132
- },
133
- d: {
134
- e: 5,
135
- },
136
- });
137
- });
138
- it('should flatten to undefined if the referenced property does not exist', () => {
139
- const a = {
140
- content: {
141
- oneofKind: 'b',
142
- c: true,
143
- },
144
- };
145
- expect(flattenOneOf(a, true)).toEqual({
146
- b: undefined,
147
- });
148
- });
149
- it('should return the original object if it does not have a oneof field', () => {
150
- const a = {
151
- a: 'a',
152
- b: 'b',
153
- };
154
- expect(flattenOneOf(a, true)).toEqual(a);
155
- });
156
- });
157
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,16 +0,0 @@
1
- import { formatServiceUrl } from './formatServiceUrl';
2
- describe('formatServiceUrl', () => {
3
- const url = 'https://{url}/admin/users/{test}/invitations';
4
- it('should format url', () => {
5
- let newUrl = formatServiceUrl(url, { url: 'test.com', test: 'me' });
6
- expect(newUrl).toEqual('https://test.com/admin/users/me/invitations');
7
- newUrl = formatServiceUrl(url, { url: 'test2.com', test: 'me2' });
8
- expect(newUrl).toEqual('https://test2.com/admin/users/me2/invitations');
9
- });
10
- it('should format insecure url', () => {
11
- let newUrl = formatServiceUrl(url, { url: 'test.com', test: 'me' }, true);
12
- expect(newUrl).toEqual('http://test.com/admin/users/me/invitations');
13
- newUrl = formatServiceUrl(url, { url: 'test2.com', test: 'me2' }, true);
14
- expect(newUrl).toEqual('http://test2.com/admin/users/me2/invitations');
15
- });
16
- });
@@ -1 +0,0 @@
1
- export {};