tabletcommand-backend-models 7.0.13 → 7.0.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (327) hide show
  1. package/build/constants.js +43 -1
  2. package/build/constants.js.map +1 -1
  3. package/build/index.js +2 -1
  4. package/build/index.js.map +1 -1
  5. package/build/models/cad-incident-stream.js +2 -2
  6. package/build/models/cad-incident-stream.js.map +1 -1
  7. package/build/models/chart-device-stats.js +2 -2
  8. package/build/models/chart-device-stats.js.map +1 -1
  9. package/build/models/chart-incident.js +2 -2
  10. package/build/models/chart-incident.js.map +1 -1
  11. package/build/models/chart-managed-incident.js +2 -2
  12. package/build/models/chart-managed-incident.js.map +1 -1
  13. package/build/models/chart-user.js +2 -2
  14. package/build/models/chart-user.js.map +1 -1
  15. package/build/models/department.js +7 -2
  16. package/build/models/department.js.map +1 -1
  17. package/build/models/device-mapping.js +4 -0
  18. package/build/models/device-mapping.js.map +1 -1
  19. package/build/models/incident-event.js +2 -2
  20. package/build/models/incident-event.js.map +1 -1
  21. package/build/models/job-log.js +2 -2
  22. package/build/models/job-log.js.map +1 -1
  23. package/build/models/location.js +37 -2
  24. package/build/models/location.js.map +1 -1
  25. package/build/models/managed-incident.js +2 -2
  26. package/build/models/managed-incident.js.map +1 -1
  27. package/build/models/monitor.js +2 -2
  28. package/build/models/monitor.js.map +1 -1
  29. package/build/models/schema/cad-incident.js +2 -3
  30. package/build/models/schema/cad-incident.js.map +1 -1
  31. package/build/models/smtp-unhandled.js +2 -2
  32. package/build/models/smtp-unhandled.js.map +1 -1
  33. package/build/test/0index.js +72 -0
  34. package/build/test/0index.js.map +1 -0
  35. package/build/test/action-log.js +40 -0
  36. package/build/test/action-log.js.map +1 -0
  37. package/build/test/agency.js +41 -0
  38. package/build/test/agency.js.map +1 -0
  39. package/build/test/arcgis-group.js +48 -85
  40. package/build/test/arcgis-group.js.map +1 -1
  41. package/build/test/assignment.js +39 -0
  42. package/build/test/assignment.js.map +1 -0
  43. package/build/test/battalion.js +45 -0
  44. package/build/test/battalion.js.map +1 -0
  45. package/build/test/cad-incident-block.js +43 -0
  46. package/build/test/cad-incident-block.js.map +1 -0
  47. package/build/test/cad-incident.js +159 -0
  48. package/build/test/cad-incident.js.map +1 -0
  49. package/build/test/cad-simulation.js +32 -0
  50. package/build/test/cad-simulation.js.map +1 -0
  51. package/build/test/cad-status-map.js +41 -0
  52. package/build/test/cad-status-map.js.map +1 -0
  53. package/build/test/cad-status.js +57 -0
  54. package/build/test/cad-status.js.map +1 -0
  55. package/build/test/cad-vehicle-status-history.js +36 -0
  56. package/build/test/cad-vehicle-status-history.js.map +1 -0
  57. package/build/test/cad-vehicle-status.js +42 -0
  58. package/build/test/cad-vehicle-status.js.map +1 -0
  59. package/build/test/cad-vehicle.js +38 -0
  60. package/build/test/cad-vehicle.js.map +1 -0
  61. package/build/test/checklist-item.js +42 -0
  62. package/build/test/checklist-item.js.map +1 -0
  63. package/build/test/checklist.js +43 -0
  64. package/build/test/checklist.js.map +1 -0
  65. package/build/test/config.js +2 -1
  66. package/build/test/config.js.map +1 -1
  67. package/build/test/csv-import.js +44 -0
  68. package/build/test/csv-import.js.map +1 -0
  69. package/build/test/department.js +99 -0
  70. package/build/test/department.js.map +1 -0
  71. package/build/test/device-mapping.js +51 -0
  72. package/build/test/device-mapping.js.map +1 -0
  73. package/build/test/esri.js +67 -0
  74. package/build/test/esri.js.map +1 -0
  75. package/build/test/gst-mapping.js +37 -0
  76. package/build/test/gst-mapping.js.map +1 -0
  77. package/build/test/helpers.js +14 -0
  78. package/build/test/helpers.js.map +1 -0
  79. package/build/test/incident-event.js +52 -0
  80. package/build/test/incident-event.js.map +1 -0
  81. package/build/test/incident-notified.js +42 -0
  82. package/build/test/incident-notified.js.map +1 -0
  83. package/build/test/incident-takeover.js +38 -0
  84. package/build/test/incident-takeover.js.map +1 -0
  85. package/build/test/job-log.js +36 -0
  86. package/build/test/job-log.js.map +1 -0
  87. package/build/test/location.js +87 -0
  88. package/build/test/location.js.map +1 -0
  89. package/build/test/mail-log.js +52 -0
  90. package/build/test/mail-log.js.map +1 -0
  91. package/build/test/managed-incident.js +107 -0
  92. package/build/test/managed-incident.js.map +1 -0
  93. package/build/test/mark43-incident-retry.js +33 -0
  94. package/build/test/mark43-incident-retry.js.map +1 -0
  95. package/build/test/message.js +38 -0
  96. package/build/test/message.js.map +1 -0
  97. package/build/test/mock.js +1289 -910
  98. package/build/test/mock.js.map +1 -1
  99. package/build/test/monitor.js +34 -0
  100. package/build/test/monitor.js.map +1 -0
  101. package/build/test/personnel-import.js +55 -0
  102. package/build/test/personnel-import.js.map +1 -0
  103. package/build/test/rate-limit.js +32 -0
  104. package/build/test/rate-limit.js.map +1 -0
  105. package/build/test/release-note.js +34 -0
  106. package/build/test/release-note.js.map +1 -0
  107. package/build/test/session.js +42 -0
  108. package/build/test/session.js.map +1 -0
  109. package/build/test/template.js +43 -0
  110. package/build/test/template.js.map +1 -0
  111. package/build/test/user-device.js +69 -0
  112. package/build/test/user-device.js.map +1 -0
  113. package/build/test/user-registration.js +44 -0
  114. package/build/test/user-registration.js.map +1 -0
  115. package/build/test/user.js +51 -0
  116. package/build/test/user.js.map +1 -0
  117. package/build/test/validation-report.js +33 -0
  118. package/build/test/validation-report.js.map +1 -0
  119. package/cspell.json +11 -8
  120. package/definitions/constants.d.ts +12 -0
  121. package/definitions/constants.d.ts.map +1 -1
  122. package/definitions/index.d.ts +2 -2
  123. package/definitions/index.d.ts.map +1 -1
  124. package/definitions/models/department.d.ts.map +1 -1
  125. package/definitions/models/device-mapping.d.ts.map +1 -1
  126. package/definitions/models/location.d.ts +2 -0
  127. package/definitions/models/location.d.ts.map +1 -1
  128. package/definitions/models/schema/cad-incident.d.ts.map +1 -1
  129. package/definitions/test/0index.d.ts +2 -0
  130. package/definitions/test/0index.d.ts.map +1 -0
  131. package/definitions/test/action-log.d.ts +2 -0
  132. package/definitions/test/action-log.d.ts.map +1 -0
  133. package/definitions/test/agency.d.ts +2 -0
  134. package/definitions/test/agency.d.ts.map +1 -0
  135. package/definitions/test/arcgis-group.d.ts.map +1 -1
  136. package/definitions/test/assignment.d.ts +2 -0
  137. package/definitions/test/assignment.d.ts.map +1 -0
  138. package/definitions/test/battalion.d.ts +2 -0
  139. package/definitions/test/battalion.d.ts.map +1 -0
  140. package/definitions/test/cad-incident-block.d.ts +2 -0
  141. package/definitions/test/cad-incident-block.d.ts.map +1 -0
  142. package/definitions/test/cad-incident.d.ts +2 -0
  143. package/definitions/test/cad-incident.d.ts.map +1 -0
  144. package/definitions/test/cad-simulation.d.ts +2 -0
  145. package/definitions/test/cad-simulation.d.ts.map +1 -0
  146. package/definitions/test/cad-status-map.d.ts +2 -0
  147. package/definitions/test/cad-status-map.d.ts.map +1 -0
  148. package/definitions/test/cad-status.d.ts +2 -0
  149. package/definitions/test/cad-status.d.ts.map +1 -0
  150. package/definitions/test/cad-vehicle-status-history.d.ts +2 -0
  151. package/definitions/test/cad-vehicle-status-history.d.ts.map +1 -0
  152. package/definitions/test/cad-vehicle-status.d.ts +2 -0
  153. package/definitions/test/cad-vehicle-status.d.ts.map +1 -0
  154. package/definitions/test/cad-vehicle.d.ts +2 -0
  155. package/definitions/test/cad-vehicle.d.ts.map +1 -0
  156. package/definitions/test/checklist-item.d.ts +2 -0
  157. package/definitions/test/checklist-item.d.ts.map +1 -0
  158. package/definitions/test/checklist.d.ts +2 -0
  159. package/definitions/test/checklist.d.ts.map +1 -0
  160. package/definitions/test/config.d.ts.map +1 -1
  161. package/definitions/test/csv-import.d.ts +2 -0
  162. package/definitions/test/csv-import.d.ts.map +1 -0
  163. package/definitions/test/department.d.ts +2 -0
  164. package/definitions/test/department.d.ts.map +1 -0
  165. package/definitions/test/device-mapping.d.ts +2 -0
  166. package/definitions/test/device-mapping.d.ts.map +1 -0
  167. package/definitions/test/esri.d.ts +2 -0
  168. package/definitions/test/esri.d.ts.map +1 -0
  169. package/definitions/test/gst-mapping.d.ts +2 -0
  170. package/definitions/test/gst-mapping.d.ts.map +1 -0
  171. package/definitions/test/helpers.d.ts +2 -0
  172. package/definitions/test/helpers.d.ts.map +1 -0
  173. package/definitions/test/incident-event.d.ts +2 -0
  174. package/definitions/test/incident-event.d.ts.map +1 -0
  175. package/definitions/test/incident-notified.d.ts +2 -0
  176. package/definitions/test/incident-notified.d.ts.map +1 -0
  177. package/definitions/test/incident-takeover.d.ts +2 -0
  178. package/definitions/test/incident-takeover.d.ts.map +1 -0
  179. package/definitions/test/job-log.d.ts +2 -0
  180. package/definitions/test/job-log.d.ts.map +1 -0
  181. package/definitions/test/location.d.ts +2 -0
  182. package/definitions/test/location.d.ts.map +1 -0
  183. package/definitions/test/mail-log.d.ts +2 -0
  184. package/definitions/test/mail-log.d.ts.map +1 -0
  185. package/definitions/test/managed-incident.d.ts +2 -0
  186. package/definitions/test/managed-incident.d.ts.map +1 -0
  187. package/definitions/test/mark43-incident-retry.d.ts +2 -0
  188. package/definitions/test/mark43-incident-retry.d.ts.map +1 -0
  189. package/definitions/test/message.d.ts +2 -0
  190. package/definitions/test/message.d.ts.map +1 -0
  191. package/definitions/test/mock.d.ts +1057 -3
  192. package/definitions/test/mock.d.ts.map +1 -1
  193. package/definitions/test/monitor.d.ts +2 -0
  194. package/definitions/test/monitor.d.ts.map +1 -0
  195. package/definitions/test/personnel-import.d.ts +2 -0
  196. package/definitions/test/personnel-import.d.ts.map +1 -0
  197. package/definitions/test/rate-limit.d.ts +2 -0
  198. package/definitions/test/rate-limit.d.ts.map +1 -0
  199. package/definitions/test/release-note.d.ts +2 -0
  200. package/definitions/test/release-note.d.ts.map +1 -0
  201. package/definitions/test/session.d.ts +2 -0
  202. package/definitions/test/session.d.ts.map +1 -0
  203. package/definitions/test/template.d.ts +2 -0
  204. package/definitions/test/template.d.ts.map +1 -0
  205. package/definitions/test/user-device.d.ts +2 -0
  206. package/definitions/test/user-device.d.ts.map +1 -0
  207. package/definitions/test/user-registration.d.ts +2 -0
  208. package/definitions/test/user-registration.d.ts.map +1 -0
  209. package/definitions/test/user.d.ts +2 -0
  210. package/definitions/test/user.d.ts.map +1 -0
  211. package/definitions/test/validation-report.d.ts +2 -0
  212. package/definitions/test/validation-report.d.ts.map +1 -0
  213. package/definitions/types/cad.d.ts +2 -2
  214. package/definitions/types/cad.d.ts.map +1 -1
  215. package/definitions/types/department.d.ts +1 -0
  216. package/definitions/types/department.d.ts.map +1 -1
  217. package/definitions/types/location.d.ts +24 -23
  218. package/definitions/types/location.d.ts.map +1 -1
  219. package/package.json +6 -6
  220. package/src/constants.ts +43 -0
  221. package/src/index.ts +2 -0
  222. package/src/models/cad-incident-stream.ts +1 -1
  223. package/src/models/chart-device-stats.ts +1 -1
  224. package/src/models/chart-incident.ts +1 -1
  225. package/src/models/chart-managed-incident.ts +1 -1
  226. package/src/models/chart-user.ts +1 -1
  227. package/src/models/department.ts +7 -1
  228. package/src/models/device-mapping.ts +4 -0
  229. package/src/models/incident-event.ts +1 -1
  230. package/src/models/job-log.ts +1 -1
  231. package/src/models/location.ts +41 -2
  232. package/src/models/managed-incident.ts +1 -1
  233. package/src/models/monitor.ts +1 -1
  234. package/src/models/schema/cad-incident.ts +1 -3
  235. package/src/models/smtp-unhandled.ts +1 -1
  236. package/src/mongoose-lean-virtuals.d.ts +4 -2
  237. package/src/test/0index.ts +71 -0
  238. package/src/test/action-log.ts +41 -0
  239. package/src/test/agency.ts +41 -0
  240. package/src/test/arcgis-group.ts +25 -63
  241. package/src/test/assignment.ts +41 -0
  242. package/src/test/battalion.ts +45 -0
  243. package/src/test/cad-incident-block.ts +44 -0
  244. package/src/test/cad-incident.ts +168 -0
  245. package/src/test/cad-simulation.ts +33 -0
  246. package/src/test/cad-status-map.ts +41 -0
  247. package/src/test/cad-status.ts +57 -0
  248. package/src/test/cad-vehicle-status-history.ts +37 -0
  249. package/src/test/cad-vehicle-status.ts +43 -0
  250. package/src/test/cad-vehicle.ts +38 -0
  251. package/src/test/checklist-item.ts +43 -0
  252. package/src/test/checklist.ts +44 -0
  253. package/src/test/config.ts +3 -3
  254. package/src/test/csv-import.ts +44 -0
  255. package/src/test/department.ts +95 -0
  256. package/src/test/device-mapping.ts +53 -0
  257. package/src/test/esri.ts +69 -0
  258. package/src/test/gst-mapping.ts +38 -0
  259. package/src/test/helpers.ts +15 -0
  260. package/src/test/incident-event.ts +53 -0
  261. package/src/test/incident-notified.ts +41 -0
  262. package/src/test/incident-takeover.ts +39 -0
  263. package/src/test/job-log.ts +37 -0
  264. package/src/test/location.ts +93 -0
  265. package/src/test/mail-log.ts +51 -0
  266. package/src/test/managed-incident.ts +116 -0
  267. package/src/test/mark43-incident-retry.ts +34 -0
  268. package/src/test/message.ts +39 -0
  269. package/src/test/mock.ts +599 -163
  270. package/src/test/monitor.ts +35 -0
  271. package/src/test/personnel-import.ts +55 -0
  272. package/src/test/rate-limit.ts +33 -0
  273. package/src/test/release-note.ts +36 -0
  274. package/src/test/session.ts +43 -0
  275. package/src/test/template.ts +44 -0
  276. package/src/test/user-device.ts +66 -0
  277. package/src/test/user-registration.ts +45 -0
  278. package/src/test/user.ts +51 -0
  279. package/src/test/validation-report.ts +33 -0
  280. package/src/tsconfig.json +6 -3
  281. package/src/types/cad.ts +2 -2
  282. package/src/types/department.ts +1 -0
  283. package/src/types/location.ts +22 -24
  284. package/tslint.json +0 -28
  285. /package/{test → test-legacy}/0index.js +0 -0
  286. /package/{test → test-legacy}/action-log.js +0 -0
  287. /package/{test → test-legacy}/agency.js +0 -0
  288. /package/{test → test-legacy}/arcgis-group.js +0 -0
  289. /package/{test → test-legacy}/assignment.js +0 -0
  290. /package/{test → test-legacy}/battalion.js +0 -0
  291. /package/{test → test-legacy}/cad-incident-block.js +0 -0
  292. /package/{test → test-legacy}/cad-incident.js +0 -0
  293. /package/{test → test-legacy}/cad-simulation.js +0 -0
  294. /package/{test → test-legacy}/cad-status-map.js +0 -0
  295. /package/{test → test-legacy}/cad-status.js +0 -0
  296. /package/{test → test-legacy}/cad-vehicle-status-history.js +0 -0
  297. /package/{test → test-legacy}/cad-vehicle-status.js +0 -0
  298. /package/{test → test-legacy}/cad-vehicle.js +0 -0
  299. /package/{test → test-legacy}/checklist-item.js +0 -0
  300. /package/{test → test-legacy}/checklist.js +0 -0
  301. /package/{test → test-legacy}/config.js +0 -0
  302. /package/{test → test-legacy}/csv-import.js +0 -0
  303. /package/{test → test-legacy}/department.js +0 -0
  304. /package/{test → test-legacy}/device-mapping.js +0 -0
  305. /package/{test → test-legacy}/esri.js +0 -0
  306. /package/{test → test-legacy}/gst-mapping.js +0 -0
  307. /package/{test → test-legacy}/helpers.js +0 -0
  308. /package/{test → test-legacy}/incident-event.js +0 -0
  309. /package/{test → test-legacy}/incident-notified.js +0 -0
  310. /package/{test → test-legacy}/incident-takeover.js +0 -0
  311. /package/{test → test-legacy}/job-log.js +0 -0
  312. /package/{test → test-legacy}/location.js +0 -0
  313. /package/{test → test-legacy}/mail-log.js +0 -0
  314. /package/{test → test-legacy}/managed-incident.js +0 -0
  315. /package/{test → test-legacy}/mark43-incident-retry.js +0 -0
  316. /package/{test → test-legacy}/message.js +0 -0
  317. /package/{test → test-legacy}/mock.js +0 -0
  318. /package/{test → test-legacy}/monitor.js +0 -0
  319. /package/{test → test-legacy}/personnel-import.js +0 -0
  320. /package/{test → test-legacy}/rate-limit.js +0 -0
  321. /package/{test → test-legacy}/release-note.js +0 -0
  322. /package/{test → test-legacy}/session.js +0 -0
  323. /package/{test → test-legacy}/template.js +0 -0
  324. /package/{test → test-legacy}/user-device.js +0 -0
  325. /package/{test → test-legacy}/user-registration.js +0 -0
  326. /package/{test → test-legacy}/user.js +0 -0
  327. /package/{test → test-legacy}/validation-report.js +0 -0
@@ -0,0 +1,41 @@
1
+ import { assert } from "chai";
2
+ import "mocha";
3
+ import * as m from "../index";
4
+ import * as config from "./config";
5
+ import mockModule from "./mock";
6
+
7
+ describe("IncidentNotified", function() {
8
+ let models: m.BackendModels, mongoose: m.MongooseModule;
9
+ let testItem: Partial<m.IncidentNotified>;
10
+ beforeEach(async function() {
11
+ const c = await m.connect(config.url);
12
+ models = c.models;
13
+ mongoose = c.mongoose;
14
+
15
+ const mock = mockModule({
16
+ mongoose
17
+ });
18
+ testItem = mock.incidentNotified;
19
+ });
20
+ afterEach(async function() {
21
+ await mongoose.disconnect();
22
+ });
23
+
24
+ it("is saved", async function() {
25
+ const item = new models.IncidentNotified(testItem);
26
+ const sut = await item.save();
27
+
28
+ assert.isNotNull(testItem._id);
29
+ assert.equal(testItem.departmentId, sut.departmentId);
30
+ assert.equal(testItem.IncidentNumber, sut.IncidentNumber);
31
+ assert.deepEqual(testItem.incidentTypes, sut.incidentTypes);
32
+ assert.deepEqual(testItem.units, sut.units);
33
+ if (testItem.unitsByDispatch?.length) {
34
+ assert.equal(testItem.unitsByDispatch[0]?.UnitID, sut.unitsByDispatch[0]?.UnitID);
35
+ assert.equal(testItem.unitsByDispatch[0]?.UnitDispatchNumber, sut.unitsByDispatch[0]?.UnitDispatchNumber);
36
+ } else {
37
+ assert.equal(testItem?.unitsByDispatch?.length, 1);
38
+ }
39
+ assert.equal(testItem.updated?.toISOString(), sut.updated.toISOString());
40
+ });
41
+ });
@@ -0,0 +1,39 @@
1
+ import { assert } from "chai";
2
+ import "mocha";
3
+ import * as m from "../index";
4
+ import * as config from "./config";
5
+ import mockModule from "./mock";
6
+
7
+ describe("IncidentTakeover", function() {
8
+ let models: m.BackendModels, mongoose: m.MongooseModule;
9
+ let testItem: Partial<m.IncidentTakeover>;
10
+ beforeEach(async function() {
11
+ const c = await m.connect(config.url);
12
+ models = c.models;
13
+ mongoose = c.mongoose;
14
+
15
+ const mock = mockModule({
16
+ mongoose
17
+ });
18
+ testItem = mock.incidentTakeover;
19
+ });
20
+ afterEach(async function() {
21
+ await mongoose.disconnect();
22
+ });
23
+
24
+ it("is saved", async function() {
25
+ const item = new models.IncidentTakeover(testItem);
26
+ const sut = await item.save();
27
+
28
+ assert.isNotNull(testItem._id);
29
+ assert.equal(testItem.departmentId, sut.departmentId);
30
+ assert.equal(testItem.incident_id, sut.incident_id);
31
+ assert.equal(testItem.incident_name, sut.incident_name);
32
+ assert.equal(testItem.incident_number, sut.incident_number);
33
+ assert.equal(testItem.old_owner, sut.old_owner);
34
+ assert.equal(testItem.new_owner, sut.new_owner);
35
+ assert.equal(testItem.status, sut.status);
36
+ assert.equal(testItem.request_time, sut.request_time);
37
+ assert.isTrue(sut.uuid !== "");
38
+ });
39
+ });
@@ -0,0 +1,37 @@
1
+ import { assert } from "chai";
2
+ import "mocha";
3
+ import * as m from "../index";
4
+ import * as config from "./config";
5
+ import mockModule from "./mock";
6
+
7
+ describe("JobLog", function() {
8
+ let models: m.BackendModels, mongoose: m.MongooseModule;
9
+ let testItem: Partial<m.JobLog>;
10
+ beforeEach(async function() {
11
+ const c = await m.connect(config.url);
12
+ models = c.models;
13
+ mongoose = c.mongoose;
14
+
15
+ const mock = mockModule({
16
+ mongoose
17
+ });
18
+ testItem = mock.jobLog;
19
+ });
20
+ afterEach(async function() {
21
+ await mongoose.disconnect();
22
+ });
23
+
24
+ it("is saved", async function() {
25
+ const item = new models.JobLog(testItem);
26
+ const sut = await item.save();
27
+
28
+ assert.isNotNull(testItem._id);
29
+ assert.equal(testItem.host, sut.host);
30
+ assert.equal(testItem.jobName, sut.jobName);
31
+ assert.equal(testItem.state, sut.state);
32
+ assert.equal(testItem.bidDate, sut.bidDate);
33
+ assert.equal(testItem.startDate, sut.startDate);
34
+ assert.equal(testItem.completedDate, sut.completedDate);
35
+ assert.equal(testItem.forceClosed, sut.forceClosed);
36
+ });
37
+ });
@@ -0,0 +1,93 @@
1
+ import { assert } from "chai";
2
+ import "mocha";
3
+ import * as m from "../index";
4
+ import * as config from "./config";
5
+ import mockModule from "./mock";
6
+ import { decodeLocationVisibility } from "../models/location";
7
+ import { LocationVisibility } from "../constants";
8
+
9
+ describe("Location", function() {
10
+ let models: m.BackendModels, mongoose: m.MongooseModule;
11
+ let testItem: Partial<m.Location>;
12
+ beforeEach(async function() {
13
+ const c = await m.connect(config.url);
14
+ models = c.models;
15
+ mongoose = c.mongoose;
16
+
17
+ const mock = mockModule({
18
+ mongoose
19
+ });
20
+ testItem = mock.location;
21
+ });
22
+ afterEach(async function() {
23
+ await mongoose.disconnect();
24
+ });
25
+
26
+ it("is saved", async function() {
27
+ const item = new models.Location(testItem);
28
+ const sut = await item.save();
29
+ assert.isNotNull(testItem._id);
30
+ assert.equal(testItem.departmentId, sut.departmentId);
31
+ assert.equal(testItem.userId, sut.userId);
32
+ assert.equal(testItem.uuid, sut.uuid);
33
+ assert.equal(testItem.username, sut.username);
34
+ assert.equal(testItem.device_type, sut.device_type);
35
+ assert.equal(testItem.session, sut.session);
36
+ assert.equal(testItem.active, sut.active);
37
+ assert.equal(testItem.heading, sut.heading);
38
+ assert.equal(testItem.locationGeoJSON?.coordinates[0], sut.location?.longitude);
39
+ assert.equal(testItem.locationGeoJSON?.coordinates[1], sut.location?.latitude);
40
+ assert.equal(testItem.locationGeoJSON?.type, "Point");
41
+ assert.equal(testItem.locationGeoJSON?.coordinates[0], sut.locationGeoJSON.coordinates[0]);
42
+ assert.equal(testItem.locationGeoJSON?.coordinates[1], sut.locationGeoJSON.coordinates[1]);
43
+ assert.equal(testItem.opAreaCode, sut.opAreaCode);
44
+ assert.equal(testItem.opAreaName, sut.opAreaName);
45
+ assert.equal(testItem.shared, sut.shared);
46
+ assert.equal(testItem.state, sut.state);
47
+ assert.equal(testItem.sendToCAD, sut.sendToCAD);
48
+ assert.equal(testItem.color?.text, sut.color.text);
49
+ assert.equal(testItem.color?.background, sut.color.background);
50
+ assert.isTrue(sut.uuid !== "");
51
+
52
+ const { longitude, latitude } = sut.location ?? { latitude: 0, longitude: 0 };
53
+ const maxDistance = 10000;
54
+ const geoQuery = {
55
+ locationGeoJSON: {
56
+ $nearSphere: {
57
+ $geometry: {
58
+ type: "Point",
59
+ coordinates: [longitude, latitude],
60
+ },
61
+ $maxDistance: maxDistance
62
+ }
63
+ }
64
+ };
65
+
66
+ try {
67
+ await models.Location.findOne(geoQuery);
68
+ assert.isFalse(true, "Expecting above to fail.");
69
+ } catch (error) {
70
+ assert.isNotNull(error, "Expecting above to fail");
71
+ }
72
+
73
+ await models.Location.createIndexes();
74
+
75
+ const found = await models.Location.findOne(geoQuery);
76
+ assert.isObject(found);
77
+
78
+ await models.Location.collection.dropIndexes();
79
+ });
80
+
81
+ it("decodes .visibility", async function() {
82
+ const item = new models.Location(testItem);
83
+ const sut = await item.save();
84
+
85
+ const sutVis = decodeLocationVisibility(sut.visibility);
86
+
87
+ assert.equal(sutVis.length, 4);
88
+ assert.notEqual(sutVis.indexOf(LocationVisibility.Hidden), -1);
89
+ assert.notEqual(sutVis.indexOf(LocationVisibility.Visible), -1);
90
+ assert.notEqual(sutVis.indexOf(LocationVisibility.CAD), -1);
91
+ assert.notEqual(sutVis.indexOf(LocationVisibility.Shared), -1);
92
+ });
93
+ });
@@ -0,0 +1,51 @@
1
+ import { assert } from "chai";
2
+ import "mocha";
3
+ import * as m from "../index";
4
+ import * as config from "./config";
5
+ import mockModule from "./mock";
6
+
7
+ describe("MailLog", function() {
8
+ let models: m.BackendModels, mongoose: m.MongooseModule;
9
+ let testItem: Partial<m.MailLog>;
10
+ beforeEach(async function() {
11
+ const c = await m.connect(config.url);
12
+ models = c.models;
13
+ mongoose = c.mongoose;
14
+
15
+ const mock = mockModule({
16
+ mongoose
17
+ });
18
+ testItem = mock.mailLog;
19
+ });
20
+ afterEach(async function() {
21
+ await mongoose.disconnect();
22
+ });
23
+
24
+ it("is saved", async function() {
25
+ const item = new models.MailLog(testItem);
26
+ const sut = await item.save();
27
+
28
+ assert.isNotNull(testItem._id);
29
+ assert.equal(testItem.mailId, sut.mailId);
30
+ assert.equal(testItem.event, sut.event);
31
+ assert.equal(testItem.timestamp, sut.timestamp);
32
+ assert.equal(testItem.recipient, sut.recipient);
33
+ assert.equal(testItem.recipientDomain, sut.recipientDomain);
34
+ if (testItem.tags?.length) {
35
+ assert.equal(testItem.tags[0], sut.tags[0]);
36
+ } else {
37
+ assert.equal(testItem.tags?.length, 1);
38
+ }
39
+ assert.equal(testItem.deliveryStatus, sut.deliveryStatus);
40
+ assert.equal(testItem.message, sut.message);
41
+ assert.equal(testItem.deliveryStatus, sut.deliveryStatus);
42
+ assert.equal(testItem.flags, sut.flags);
43
+ assert.equal(testItem.envelope, sut.envelope);
44
+ assert.equal(testItem.logLevel, sut.logLevel);
45
+ assert.equal(testItem.reason, sut.reason);
46
+ assert.equal(testItem.severity, sut.severity);
47
+ const expectedDate = new Date().valueOf() / 1000.0;
48
+ const timeDelta = expectedDate - sut.modified_unix_date;
49
+ assert.isTrue(timeDelta < 1);
50
+ });
51
+ });
@@ -0,0 +1,116 @@
1
+ import { assert } from "chai";
2
+ import "mocha";
3
+ import * as _ from "lodash";
4
+ import * as m from "../index";
5
+ import * as config from "./config";
6
+ import mockModule from "./mock";
7
+
8
+ describe("ManagedIncident", function() {
9
+ let models: m.BackendModels, mongoose: m.MongooseModule;
10
+ let testItem: Partial<m.ManagedIncident>;
11
+ beforeEach(async function() {
12
+ const c = await m.connect(config.url);
13
+ models = c.models;
14
+ mongoose = c.mongoose;
15
+
16
+ const mock = mockModule({
17
+ mongoose
18
+ });
19
+ testItem = mock.managedIncident;
20
+ });
21
+ afterEach(async function() {
22
+ await mongoose.disconnect();
23
+ });
24
+
25
+ it("is saved", async function() {
26
+ const item = new models.ManagedIncident(testItem);
27
+ const sut = await item.save();
28
+
29
+
30
+ assert.isNotNull(testItem._id);
31
+ assert.equal(sut.departmentId, testItem.departmentId);
32
+ assert.equal(sut.CallerNumber, testItem.CallerNumber);
33
+ assert.equal(sut.CommandChannel, testItem.CommandChannel);
34
+ assert.equal(sut.TacticalAltChannel, testItem.TacticalAltChannel);
35
+ assert.equal(sut.TacticalChannel, testItem.TacticalChannel);
36
+ assert.equal(sut.active, testItem.active);
37
+ assert.equal(sut.address, testItem.address);
38
+ assert.equal(sut.api_incident_number, testItem.api_incident_number);
39
+ assert.equal(sut.channel, testItem.channel);
40
+ assert.equal(sut.channel_owner, testItem.channel_owner);
41
+ assert.equal(sut.end_time, testItem.end_time);
42
+ assert.equal(sut.end_unix_time, testItem.end_unix_time);
43
+ assert.equal(sut.is_closed, testItem.is_closed);
44
+ assert.equal(sut.location, testItem.location);
45
+ assert.equal(sut.managed, testItem.managed);
46
+ assert.equal(sut.modified_date, testItem.modified_date);
47
+ assert.equal(sut.modified_unix_date, testItem.modified_unix_date);
48
+ assert.equal(sut.name, testItem.name);
49
+ assert.equal(sut.preference_location, testItem.preference_location);
50
+ assert.equal(sut.slave_map_changed, testItem.slave_map_changed);
51
+ assert.equal(sut.source, testItem.source);
52
+ assert.equal(sut.start_time, testItem.start_time);
53
+ assert.equal(sut.start_unix_time, testItem.start_unix_time);
54
+ assert.equal(sut.userId, testItem.userId);
55
+ assert.equal(sut.uuid, testItem.uuid);
56
+
57
+ assert.isTrue(sut.active);
58
+ assert.isTrue(sut.is_closed);
59
+
60
+ const unit = _.first(sut.units.filter((x) => x.UnitID === "M12"));
61
+ assert.equal(unit?.Personnel.length, 2);
62
+ const p1 = _.first(unit?.Personnel.filter((x) => x.PersonnelID === "X14"));
63
+ assert.equal(p1?.PersonnelName, "Mary Smith");
64
+ assert.equal(p1?.PersonnelNote, "X");
65
+ assert.equal(p1?.PersonnelRank, "Captain");
66
+ assert.equal(p1?.PersonnelWorkCode, "TRD");
67
+
68
+ // Share incident properties
69
+ assert.isArray(sut.ReportNumber);
70
+ assert.equal(sut.ReportNumber.length, 2);
71
+ const rna = _.first(sut.ReportNumber.filter((x) => x.name === "A"));
72
+ assert.isObject(rna);
73
+ assert.equal(rna?.number, "07-0351");
74
+ const rnb = _.first(sut.ReportNumber.filter((x) => x.name === "B"));
75
+ assert.isObject(rnb);
76
+ assert.equal(rnb?.number, "UM-02210");
77
+
78
+ assert.isArray(sut.radioChannels);
79
+ assert.equal(sut.radioChannels.length, 2);
80
+ const rca = _.first(sut.radioChannels.filter((x) => x.name === "CMD"));
81
+ assert.isObject(rca);
82
+ assert.equal(rca?.channel, "LOCAL Tone: 3");
83
+ assert.equal(rca?.url, "http://example.com/stream1");
84
+ const rcb = _.first(sut.radioChannels.filter((x) => x.name === "TAC"));
85
+ assert.isObject(rcb);
86
+ assert.equal(rcb?.channel, "CDF TAC 10");
87
+ assert.equal(rcb?.url, "http://example.com/stream2");
88
+
89
+ assert.isObject(sut.record);
90
+ assert.equal(sut.record.name, "John");
91
+ assert.equal(sut.record.value, "Smith");
92
+
93
+ assert.isObject(sut.sharedSource);
94
+ assert.equal(sut.sharedSource.isExternal, true);
95
+ assert.equal(sut.sharedSource.name, "Demo RTS Fire Department");
96
+ assert.isArray(sut.sharedSource.reasons);
97
+ assert.equal(sut.sharedSource.reasons.length, 1);
98
+ const ssr1 = _.first(sut.sharedSource.reasons);
99
+ assert.isObject(ssr1);
100
+ assert.equal(ssr1?.name, "Unit B10 assigned");
101
+ assert.equal(ssr1?.date.toISOString(), "2024-05-03T00:00:00.000Z");
102
+
103
+ assert.isArray(sut.sharedTo);
104
+ assert.equal(sut.sharedTo.length, 1);
105
+ const st1 = _.first(sut.sharedTo);
106
+ assert.equal(st1?.active, true);
107
+ assert.equal(st1?.departmentId, "5195426cc4e016a988000965");
108
+ assert.equal(st1?.expireAt.toISOString(), "2024-08-01T10:20:30.400Z");
109
+ assert.equal(st1?.name, "Test Fire Department");
110
+ assert.equal(st1?.startAt.toISOString(), "2024-05-01T01:02:03.040Z");
111
+ assert.equal(st1?.reasons.length, 1);
112
+ const str1 = _.first(st1?.reasons);
113
+ assert.equal(str1?.name, "Unit M10 assigned");
114
+ assert.equal(str1?.date.toISOString(), "2024-05-03T01:01:01.010Z");
115
+ });
116
+ });
@@ -0,0 +1,34 @@
1
+ import { assert } from "chai";
2
+ import "mocha";
3
+ import * as m from "../index";
4
+ import * as config from "./config";
5
+ import mockModule from "./mock";
6
+
7
+ describe("Mark43IncidentRetry", function() {
8
+ let models: m.BackendModels, mongoose: m.MongooseModule;
9
+ let testItem: Partial<m.Mark43IncidentRetry>;
10
+ beforeEach(async function() {
11
+ const c = await m.connect(config.url);
12
+ models = c.models;
13
+ mongoose = c.mongoose;
14
+
15
+ const mock = mockModule({
16
+ mongoose
17
+ });
18
+ testItem = mock.mark43IncidentRetry;
19
+ });
20
+ afterEach(async function() {
21
+ await mongoose.disconnect();
22
+ });
23
+
24
+ it("is saved", async function() {
25
+ const item = new models.Mark43IncidentRetry(testItem);
26
+ const sut = await item.save();
27
+
28
+ assert.isNotNull(sut._id);
29
+ assert.equal(testItem.departmentId, sut.departmentId);
30
+ assert.equal(testItem.active, sut.active);
31
+ assert.equal(testItem.mark43IncidentId, sut.mark43IncidentId);
32
+ assert.equal(JSON.stringify(testItem.retryPayload), JSON.stringify(sut.retryPayload));
33
+ });
34
+ });
@@ -0,0 +1,39 @@
1
+ import { assert } from "chai";
2
+ import "mocha";
3
+ import * as m from "../index";
4
+ import * as config from "./config";
5
+ import mockModule from "./mock";
6
+
7
+ describe("Message", function() {
8
+ let models: m.BackendModels, mongoose: m.MongooseModule;
9
+ let testItem: Partial<m.Message>;
10
+ beforeEach(async function() {
11
+ const c = await m.connect(config.url);
12
+ models = c.models;
13
+ mongoose = c.mongoose;
14
+
15
+ const mock = mockModule({
16
+ mongoose
17
+ });
18
+ testItem = mock.message;
19
+ });
20
+ afterEach(async function() {
21
+ await mongoose.disconnect();
22
+ });
23
+
24
+ it("is saved", async function() {
25
+ const item = new models.Message(testItem);
26
+ const sut = await item.save();
27
+
28
+ assert.isNotNull(testItem._id);
29
+ assert.equal(testItem.departmentId, sut.departmentId);
30
+ assert.equal(testItem.title, sut.title);
31
+ assert.equal(testItem.uuid, sut.uuid);
32
+ assert.equal(testItem.requestId, sut.requestId);
33
+ assert.equal(testItem.body, sut.body);
34
+ assert.equal(testItem.actionTitle, sut.actionTitle);
35
+ assert.equal(testItem.url, sut.url);
36
+ assert.equal(testItem.priority, sut.priority);
37
+ assert.equal(JSON.stringify(testItem.type), JSON.stringify(sut.type));
38
+ });
39
+ });