@tellescope/sdk 1.247.0 → 1.249.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.
Files changed (126) hide show
  1. package/.env +3 -0
  2. package/lib/cjs/sdk.d.ts +7 -1
  3. package/lib/cjs/sdk.d.ts.map +1 -1
  4. package/lib/cjs/sdk.js +3 -0
  5. package/lib/cjs/sdk.js.map +1 -1
  6. package/lib/cjs/tests/api_tests/chats_analytics.test.d.ts +6 -0
  7. package/lib/cjs/tests/api_tests/chats_analytics.test.d.ts.map +1 -0
  8. package/lib/cjs/tests/api_tests/chats_analytics.test.js +256 -0
  9. package/lib/cjs/tests/api_tests/chats_analytics.test.js.map +1 -0
  10. package/lib/cjs/tests/api_tests/cross_org_api_key.test.d.ts +6 -0
  11. package/lib/cjs/tests/api_tests/cross_org_api_key.test.d.ts.map +1 -0
  12. package/lib/cjs/tests/api_tests/cross_org_api_key.test.js +748 -0
  13. package/lib/cjs/tests/api_tests/cross_org_api_key.test.js.map +1 -0
  14. package/lib/cjs/tests/api_tests/date_string_validation.test.d.ts +6 -0
  15. package/lib/cjs/tests/api_tests/date_string_validation.test.d.ts.map +1 -0
  16. package/lib/cjs/tests/api_tests/date_string_validation.test.js +142 -0
  17. package/lib/cjs/tests/api_tests/date_string_validation.test.js.map +1 -0
  18. package/lib/cjs/tests/api_tests/enduser_session_invalidation.test.d.ts +6 -0
  19. package/lib/cjs/tests/api_tests/enduser_session_invalidation.test.d.ts.map +1 -0
  20. package/lib/cjs/tests/api_tests/enduser_session_invalidation.test.js +667 -0
  21. package/lib/cjs/tests/api_tests/enduser_session_invalidation.test.js.map +1 -0
  22. package/lib/cjs/tests/api_tests/eom_billing_codes.test.d.ts +6 -0
  23. package/lib/cjs/tests/api_tests/eom_billing_codes.test.d.ts.map +1 -0
  24. package/lib/cjs/tests/api_tests/eom_billing_codes.test.js +162 -0
  25. package/lib/cjs/tests/api_tests/eom_billing_codes.test.js.map +1 -0
  26. package/lib/cjs/tests/api_tests/eom_procedure_codes.test.d.ts +6 -0
  27. package/lib/cjs/tests/api_tests/eom_procedure_codes.test.d.ts.map +1 -0
  28. package/lib/cjs/tests/api_tests/eom_procedure_codes.test.js +339 -0
  29. package/lib/cjs/tests/api_tests/eom_procedure_codes.test.js.map +1 -0
  30. package/lib/cjs/tests/api_tests/field_redaction.test.d.ts +13 -0
  31. package/lib/cjs/tests/api_tests/field_redaction.test.d.ts.map +1 -0
  32. package/lib/cjs/tests/api_tests/field_redaction.test.js +818 -0
  33. package/lib/cjs/tests/api_tests/field_redaction.test.js.map +1 -0
  34. package/lib/cjs/tests/api_tests/form_submitted_trigger.test.d.ts +6 -0
  35. package/lib/cjs/tests/api_tests/form_submitted_trigger.test.d.ts.map +1 -0
  36. package/lib/cjs/tests/api_tests/form_submitted_trigger.test.js +429 -0
  37. package/lib/cjs/tests/api_tests/form_submitted_trigger.test.js.map +1 -0
  38. package/lib/cjs/tests/api_tests/integrations_redacted.test.d.ts +6 -0
  39. package/lib/cjs/tests/api_tests/integrations_redacted.test.d.ts.map +1 -0
  40. package/lib/cjs/tests/api_tests/integrations_redacted.test.js +273 -0
  41. package/lib/cjs/tests/api_tests/integrations_redacted.test.js.map +1 -0
  42. package/lib/cjs/tests/api_tests/managed_content_file_access.test.d.ts +13 -0
  43. package/lib/cjs/tests/api_tests/managed_content_file_access.test.d.ts.map +1 -0
  44. package/lib/cjs/tests/api_tests/managed_content_file_access.test.js +385 -0
  45. package/lib/cjs/tests/api_tests/managed_content_file_access.test.js.map +1 -0
  46. package/lib/cjs/tests/api_tests/openloop_webhooks.test.d.ts.map +1 -1
  47. package/lib/cjs/tests/api_tests/openloop_webhooks.test.js +108 -24
  48. package/lib/cjs/tests/api_tests/openloop_webhooks.test.js.map +1 -1
  49. package/lib/cjs/tests/api_tests/organization_settings_duplicates.test.d.ts.map +1 -1
  50. package/lib/cjs/tests/api_tests/organization_settings_duplicates.test.js +25 -2
  51. package/lib/cjs/tests/api_tests/organization_settings_duplicates.test.js.map +1 -1
  52. package/lib/cjs/tests/tests.d.ts.map +1 -1
  53. package/lib/cjs/tests/tests.js +310 -183
  54. package/lib/cjs/tests/tests.js.map +1 -1
  55. package/lib/esm/sdk.d.ts +9 -3
  56. package/lib/esm/sdk.d.ts.map +1 -1
  57. package/lib/esm/sdk.js +3 -0
  58. package/lib/esm/sdk.js.map +1 -1
  59. package/lib/esm/session.d.ts +1 -0
  60. package/lib/esm/session.d.ts.map +1 -1
  61. package/lib/esm/tests/api_tests/chats_analytics.test.d.ts +6 -0
  62. package/lib/esm/tests/api_tests/chats_analytics.test.d.ts.map +1 -0
  63. package/lib/esm/tests/api_tests/chats_analytics.test.js +252 -0
  64. package/lib/esm/tests/api_tests/chats_analytics.test.js.map +1 -0
  65. package/lib/esm/tests/api_tests/cross_org_api_key.test.d.ts +6 -0
  66. package/lib/esm/tests/api_tests/cross_org_api_key.test.d.ts.map +1 -0
  67. package/lib/esm/tests/api_tests/cross_org_api_key.test.js +744 -0
  68. package/lib/esm/tests/api_tests/cross_org_api_key.test.js.map +1 -0
  69. package/lib/esm/tests/api_tests/date_string_validation.test.d.ts +6 -0
  70. package/lib/esm/tests/api_tests/date_string_validation.test.d.ts.map +1 -0
  71. package/lib/esm/tests/api_tests/date_string_validation.test.js +138 -0
  72. package/lib/esm/tests/api_tests/date_string_validation.test.js.map +1 -0
  73. package/lib/esm/tests/api_tests/enduser_session_invalidation.test.d.ts +6 -0
  74. package/lib/esm/tests/api_tests/enduser_session_invalidation.test.d.ts.map +1 -0
  75. package/lib/esm/tests/api_tests/enduser_session_invalidation.test.js +663 -0
  76. package/lib/esm/tests/api_tests/enduser_session_invalidation.test.js.map +1 -0
  77. package/lib/esm/tests/api_tests/eom_billing_codes.test.d.ts +6 -0
  78. package/lib/esm/tests/api_tests/eom_billing_codes.test.d.ts.map +1 -0
  79. package/lib/esm/tests/api_tests/eom_billing_codes.test.js +158 -0
  80. package/lib/esm/tests/api_tests/eom_billing_codes.test.js.map +1 -0
  81. package/lib/esm/tests/api_tests/eom_procedure_codes.test.d.ts +6 -0
  82. package/lib/esm/tests/api_tests/eom_procedure_codes.test.d.ts.map +1 -0
  83. package/lib/esm/tests/api_tests/eom_procedure_codes.test.js +335 -0
  84. package/lib/esm/tests/api_tests/eom_procedure_codes.test.js.map +1 -0
  85. package/lib/esm/tests/api_tests/field_redaction.test.d.ts +13 -0
  86. package/lib/esm/tests/api_tests/field_redaction.test.d.ts.map +1 -0
  87. package/lib/esm/tests/api_tests/field_redaction.test.js +814 -0
  88. package/lib/esm/tests/api_tests/field_redaction.test.js.map +1 -0
  89. package/lib/esm/tests/api_tests/form_submitted_trigger.test.d.ts +6 -0
  90. package/lib/esm/tests/api_tests/form_submitted_trigger.test.d.ts.map +1 -0
  91. package/lib/esm/tests/api_tests/form_submitted_trigger.test.js +425 -0
  92. package/lib/esm/tests/api_tests/form_submitted_trigger.test.js.map +1 -0
  93. package/lib/esm/tests/api_tests/integrations_redacted.test.d.ts +6 -0
  94. package/lib/esm/tests/api_tests/integrations_redacted.test.d.ts.map +1 -0
  95. package/lib/esm/tests/api_tests/integrations_redacted.test.js +269 -0
  96. package/lib/esm/tests/api_tests/integrations_redacted.test.js.map +1 -0
  97. package/lib/esm/tests/api_tests/managed_content_file_access.test.d.ts +13 -0
  98. package/lib/esm/tests/api_tests/managed_content_file_access.test.d.ts.map +1 -0
  99. package/lib/esm/tests/api_tests/managed_content_file_access.test.js +358 -0
  100. package/lib/esm/tests/api_tests/managed_content_file_access.test.js.map +1 -0
  101. package/lib/esm/tests/api_tests/openloop_webhooks.test.d.ts.map +1 -1
  102. package/lib/esm/tests/api_tests/openloop_webhooks.test.js +108 -24
  103. package/lib/esm/tests/api_tests/openloop_webhooks.test.js.map +1 -1
  104. package/lib/esm/tests/api_tests/organization_settings_duplicates.test.d.ts.map +1 -1
  105. package/lib/esm/tests/api_tests/organization_settings_duplicates.test.js +25 -2
  106. package/lib/esm/tests/api_tests/organization_settings_duplicates.test.js.map +1 -1
  107. package/lib/esm/tests/tests.d.ts.map +1 -1
  108. package/lib/esm/tests/tests.js +310 -183
  109. package/lib/esm/tests/tests.js.map +1 -1
  110. package/lib/tsconfig.tsbuildinfo +1 -1
  111. package/package.json +10 -10
  112. package/src/sdk.ts +14 -0
  113. package/src/tests/api_tests/chats_analytics.test.ts +182 -0
  114. package/src/tests/api_tests/cross_org_api_key.test.ts +665 -0
  115. package/src/tests/api_tests/date_string_validation.test.ts +107 -0
  116. package/src/tests/api_tests/enduser_session_invalidation.test.ts +361 -0
  117. package/src/tests/api_tests/eom_procedure_codes.test.ts +296 -0
  118. package/src/tests/api_tests/field_redaction.test.ts +669 -0
  119. package/src/tests/api_tests/form_started_trigger.test.ts +1 -1
  120. package/src/tests/api_tests/form_submitted_trigger.test.ts +281 -0
  121. package/src/tests/api_tests/integrations_redacted.test.ts +245 -0
  122. package/src/tests/api_tests/managed_content_file_access.test.ts +214 -0
  123. package/src/tests/api_tests/openloop_webhooks.test.ts +64 -0
  124. package/src/tests/api_tests/organization_settings_duplicates.test.ts +14 -0
  125. package/src/tests/tests.ts +95 -7
  126. package/test_generated.pdf +0 -0
@@ -72,6 +72,7 @@ import * as buffer from "buffer"; // only node >=15.7.0
72
72
  import { fieldsToValidationOld, mongoIdStringRequired, } from "@tellescope/validation";
73
73
  import { Session, EnduserSession } from "../sdk";
74
74
  import { enduser_observations_acknowledge_tests } from "./api_tests/enduser_observations_acknowledge.test";
75
+ import { integrations_redacted_tests } from "./api_tests/integrations_redacted.test";
75
76
  import { get_some_projection_tests } from "./api_tests/get_some_projection.test";
76
77
  import { mdb_sort_tests } from "./api_tests/mdb_sort.test";
77
78
  import { create_user_notifications_trigger_tests } from "./api_tests/create_user_notifications_trigger.test";
@@ -92,26 +93,34 @@ import { assert, async_test, handleAnyError, log_header, passOnAnyResult, wait,
92
93
  import { objects_equivalent, url_safe_path, } from "@tellescope/utilities";
93
94
  import fs from "fs";
94
95
  import { load_inbox_data_tests } from "./api_tests/load_inbox_data.test";
96
+ import { eom_procedure_codes_tests } from "./api_tests/eom_procedure_codes.test";
97
+ import { cross_org_api_key_tests } from "./api_tests/cross_org_api_key.test";
95
98
  import { custom_dashboards_tests } from "./api_tests/custom_dashboards.test";
96
99
  import { message_assignment_trigger_tests } from "./api_tests/message_assignment_trigger.test";
97
100
  import { time_tracks_tests, time_tracks_historical_tests, time_tracks_correction_tests, time_tracks_review_tests, time_tracks_lock_tests, time_tracks_edge_case_tests } from "./api_tests/time_tracks.test";
98
101
  import { monthly_availability_restrictions_tests } from "./api_tests/monthly_availability_restrictions.test";
99
102
  import { calendar_event_limits_tests } from "./api_tests/calendar_event_limits.test";
100
103
  import { custom_aggregation_tests } from "./api_tests/custom_aggregation.test";
104
+ import { chats_analytics_tests } from "./api_tests/chats_analytics.test";
101
105
  import { no_access_permission_checks_tests } from "./api_tests/no_access_permission_checks.test";
106
+ import { field_redaction_tests } from "./api_tests/field_redaction.test";
102
107
  import { bulk_assignment_tests } from "./api_tests/bulk_assignment.test";
103
108
  import { managed_content_enduser_access_tests } from "./api_tests/managed_content_enduser_access.test";
109
+ import { managed_content_file_access_tests } from "./api_tests/managed_content_file_access.test";
104
110
  import { auto_merge_form_submission_tests } from "./api_tests/auto_merge_form_submission.test";
105
111
  import { database_cascade_delete_tests } from "./api_tests/database_cascade_delete.test";
106
112
  import { ai_conversations_tests } from "./api_tests/ai_conversations.test";
107
113
  import { load_team_chat_tests } from "./api_tests/load_team_chat.test";
108
114
  import { form_started_trigger_tests } from "./api_tests/form_started_trigger.test";
115
+ import { form_submitted_trigger_tests } from "./api_tests/form_submitted_trigger.test";
109
116
  import { medication_added_trigger_tests } from "./api_tests/medication_added_trigger.test";
110
117
  import { elation_user_id_tests } from "./api_tests/elation_user_id.test";
111
118
  import { organization_settings_duplicates_tests } from "./api_tests/organization_settings_duplicates.test";
112
119
  import { calendar_events_bulk_update_tests } from "./api_tests/calendar_events_bulk_update.test";
113
120
  import { openloop_webhooks_tests } from "./api_tests/openloop_webhooks.test";
114
121
  import { beluga_pharmacy_mappings_tests } from "./api_tests/beluga_pharmacy_mappings.test";
122
+ import { date_string_validation_tests } from "./api_tests/date_string_validation.test";
123
+ import { enduser_session_invalidation_tests } from "./api_tests/enduser_session_invalidation.test";
115
124
  var UniquenessViolationMessage = 'Uniqueness Violation';
116
125
  var host = process.env.API_URL || 'http://localhost:8080';
117
126
  var _a = [process.env.TEST_EMAIL, process.env.TEST_PASSWORD], email = _a[0], password = _a[1];
@@ -4086,7 +4095,7 @@ var order_created_tests = function () { return __awaiter(void 0, void 0, void 0,
4086
4095
  });
4087
4096
  }); };
4088
4097
  var order_status_equals_tests = function () { return __awaiter(void 0, void 0, void 0, function () {
4089
- var t1, t2, t3, t4, t5, t6, t7, t8, e, u;
4098
+ var t1, t2, t3, t4, t5, t6, t7, t8, t9, e, u;
4090
4099
  return __generator(this, function (_a) {
4091
4100
  switch (_a.label) {
4092
4101
  case 0:
@@ -4155,45 +4164,53 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4155
4164
  })];
4156
4165
  case 8:
4157
4166
  t8 = _a.sent();
4158
- return [4 /*yield*/, sdk.api.endusers.createOne({})];
4167
+ return [4 /*yield*/, sdk.api.automation_triggers.createOne({
4168
+ event: { type: 'Order Status Equals', info: { source: 'Source', status: "Update", protocols: ['Protocol-A'] } },
4169
+ action: { type: 'Add Tags', info: { tags: ['Protocol Match'] } },
4170
+ status: 'Active',
4171
+ title: "Protocol Condition"
4172
+ })];
4159
4173
  case 9:
4174
+ t9 = _a.sent();
4175
+ return [4 /*yield*/, sdk.api.endusers.createOne({})];
4176
+ case 10:
4160
4177
  e = _a.sent();
4161
4178
  return [4 /*yield*/, sdk.api.enduser_orders.createOne({ status: 'Nooo', source: 'Source', title: 'nomatch', externalId: '1', enduserId: e.id })];
4162
- case 10:
4179
+ case 11:
4163
4180
  _a.sent();
4164
4181
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4165
- case 11:
4182
+ case 12:
4166
4183
  _a.sent(); // allow triggers to happen
4167
4184
  return [4 /*yield*/, async_test("No tag is added (no fill)", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) { var _a; return !((_a = e.tags) === null || _a === void 0 ? void 0 : _a.length); } })];
4168
- case 12:
4185
+ case 13:
4169
4186
  _a.sent();
4170
4187
  return [4 /*yield*/, sdk.api.enduser_orders.createOne({ status: 'Filled', source: 'Source', title: 'nomatch', externalId: '2', enduserId: e.id, fill: 'nomatch' })];
4171
- case 13:
4188
+ case 14:
4172
4189
  _a.sent();
4173
4190
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4174
- case 14:
4191
+ case 15:
4175
4192
  _a.sent(); // allow triggers to happen
4176
4193
  return [4 /*yield*/, async_test("No tag is added (fill mistmatch)", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) { var _a; return !((_a = e.tags) === null || _a === void 0 ? void 0 : _a.length); } })];
4177
- case 15:
4194
+ case 16:
4178
4195
  _a.sent();
4179
4196
  return [4 /*yield*/, sdk.api.enduser_orders.createOne({ status: 'Status', source: 'Source', externalId: '3', enduserId: e.id, title: "Title" })];
4180
- case 16:
4197
+ case 17:
4181
4198
  _a.sent();
4182
4199
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4183
- case 17:
4200
+ case 18:
4184
4201
  _a.sent(); // allow triggers to happen
4185
4202
  return [4 /*yield*/, async_test("First tag is added", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4186
4203
  var _a, _b;
4187
4204
  return !!(((_a = e.tags) === null || _a === void 0 ? void 0 : _a.length) === 1
4188
4205
  && ((_b = e.tags) === null || _b === void 0 ? void 0 : _b.includes('Source')));
4189
4206
  } })];
4190
- case 18:
4207
+ case 19:
4191
4208
  _a.sent();
4192
4209
  return [4 /*yield*/, sdk.api.enduser_orders.createOne({ status: 'Status', source: 'Source', externalId: '4', enduserId: e.id, title: "Title", fill: '1' })];
4193
- case 19:
4210
+ case 20:
4194
4211
  _a.sent();
4195
4212
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4196
- case 20:
4213
+ case 21:
4197
4214
  _a.sent(); // allow triggers to happen
4198
4215
  return [4 /*yield*/, async_test("Fill tag not added yet (mismatch)", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4199
4216
  var _a, _b, _c;
@@ -4201,13 +4218,13 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4201
4218
  && ((_b = e.tags) === null || _b === void 0 ? void 0 : _b.includes('Source'))
4202
4219
  && !((_c = e.tags) === null || _c === void 0 ? void 0 : _c.includes('Fill')));
4203
4220
  } })];
4204
- case 21:
4221
+ case 22:
4205
4222
  _a.sent();
4206
4223
  return [4 /*yield*/, sdk.api.enduser_orders.createOne({ status: 'Filled', source: 'Source', externalId: '5', enduserId: e.id, title: "Title", fill: "Fill" })];
4207
- case 22:
4224
+ case 23:
4208
4225
  _a.sent();
4209
4226
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4210
- case 23:
4227
+ case 24:
4211
4228
  _a.sent(); // allow triggers to happen
4212
4229
  return [4 /*yield*/, async_test("Fill tag added", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4213
4230
  var _a, _b, _c;
@@ -4215,16 +4232,16 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4215
4232
  && ((_b = e.tags) === null || _b === void 0 ? void 0 : _b.includes('Source'))
4216
4233
  && ((_c = e.tags) === null || _c === void 0 ? void 0 : _c.includes('Fill')));
4217
4234
  } })];
4218
- case 24:
4235
+ case 25:
4219
4236
  _a.sent();
4220
4237
  return [4 /*yield*/, sdk.api.enduser_orders.createOne({ status: 'Status', source: 'Source', externalId: '6', enduserId: e.id, title: "Title" })];
4221
- case 25:
4238
+ case 26:
4222
4239
  u = _a.sent();
4223
4240
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Update' })];
4224
- case 26:
4241
+ case 27:
4225
4242
  _a.sent();
4226
4243
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4227
- case 27:
4244
+ case 28:
4228
4245
  _a.sent(); // allow triggers to happen
4229
4246
  return [4 /*yield*/, async_test("Status update tag added", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4230
4247
  var _a, _b, _c, _d;
@@ -4235,18 +4252,18 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4235
4252
  } })
4236
4253
  // duplicate updates get rate limited, so we need to make each update unique
4237
4254
  ];
4238
- case 28:
4255
+ case 29:
4239
4256
  _a.sent();
4240
4257
  // duplicate updates get rate limited, so we need to make each update unique
4241
4258
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle' })];
4242
- case 29:
4259
+ case 30:
4243
4260
  // duplicate updates get rate limited, so we need to make each update unique
4244
4261
  _a.sent();
4245
4262
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", fill: 'Update', externalId: 'avoid rate limiting' })];
4246
- case 30:
4263
+ case 31:
4247
4264
  _a.sent();
4248
4265
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4249
- case 31:
4266
+ case 32:
4250
4267
  _a.sent(); // allow triggers to happen
4251
4268
  return [4 /*yield*/, async_test("Fill update tag added", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4252
4269
  var _a, _b, _c, _d, _f;
@@ -4256,16 +4273,16 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4256
4273
  && ((_d = e.tags) === null || _d === void 0 ? void 0 : _d.includes('Status Update'))
4257
4274
  && ((_f = e.tags) === null || _f === void 0 ? void 0 : _f.includes('Fill Update')));
4258
4275
  } })];
4259
- case 32:
4276
+ case 33:
4260
4277
  _a.sent();
4261
4278
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle', externalId: "also avoid rate limit 1" })];
4262
- case 33:
4279
+ case 34:
4263
4280
  _a.sent();
4264
4281
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", sku: 'SK', externalId: 'avoid rate limiting 2' })];
4265
- case 34:
4282
+ case 35:
4266
4283
  _a.sent();
4267
4284
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4268
- case 35:
4285
+ case 36:
4269
4286
  _a.sent(); // allow triggers to happen
4270
4287
  return [4 /*yield*/, async_test("SKU update no match", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4271
4288
  var _a, _b, _c, _d, _f;
@@ -4275,16 +4292,16 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4275
4292
  && ((_d = e.tags) === null || _d === void 0 ? void 0 : _d.includes('Status Update'))
4276
4293
  && ((_f = e.tags) === null || _f === void 0 ? void 0 : _f.includes('Fill Update')));
4277
4294
  } })];
4278
- case 36:
4295
+ case 37:
4279
4296
  _a.sent();
4280
4297
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle', externalId: "also avoid rate limit 2" })];
4281
- case 37:
4298
+ case 38:
4282
4299
  _a.sent();
4283
4300
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", sku: 'SKU', externalId: 'avoid rate limiting 3' })];
4284
- case 38:
4301
+ case 39:
4285
4302
  _a.sent();
4286
4303
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4287
- case 39:
4304
+ case 40:
4288
4305
  _a.sent(); // allow triggers to happen
4289
4306
  return [4 /*yield*/, async_test("SKU update tag added", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4290
4307
  var _a, _b, _c, _d, _f, _g;
@@ -4295,16 +4312,16 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4295
4312
  && ((_f = e.tags) === null || _f === void 0 ? void 0 : _f.includes('Fill Update'))
4296
4313
  && ((_g = e.tags) === null || _g === void 0 ? void 0 : _g.includes('SKU Update')));
4297
4314
  } })];
4298
- case 40:
4315
+ case 41:
4299
4316
  _a.sent();
4300
4317
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle', externalId: "also avoid rate limit 3" })];
4301
- case 41:
4318
+ case 42:
4302
4319
  _a.sent();
4303
4320
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", sku: '___SKU-PARTIAL--_' })];
4304
- case 42:
4321
+ case 43:
4305
4322
  _a.sent();
4306
4323
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4307
- case 43:
4324
+ case 44:
4308
4325
  _a.sent(); // allow triggers to happen
4309
4326
  return [4 /*yield*/, async_test("SKU partial update tag added", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4310
4327
  var _a, _b, _c, _d, _f, _g, _h;
@@ -4316,16 +4333,16 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4316
4333
  && ((_g = e.tags) === null || _g === void 0 ? void 0 : _g.includes('SKU Update'))
4317
4334
  && ((_h = e.tags) === null || _h === void 0 ? void 0 : _h.includes('SKU Partial Update')));
4318
4335
  } })];
4319
- case 44:
4336
+ case 45:
4320
4337
  _a.sent();
4321
4338
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle', externalId: "also avoid rate limit 4" })];
4322
- case 45:
4339
+ case 46:
4323
4340
  _a.sent();
4324
4341
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", title: "TITLE-PARTIAL" })];
4325
- case 46:
4342
+ case 47:
4326
4343
  _a.sent();
4327
4344
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4328
- case 47:
4345
+ case 48:
4329
4346
  _a.sent(); // allow triggers to happen
4330
4347
  return [4 /*yield*/, async_test("Title partial update tag added", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4331
4348
  var _a, _b, _c, _d, _f, _g, _h, _j;
@@ -4338,32 +4355,32 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4338
4355
  && ((_h = e.tags) === null || _h === void 0 ? void 0 : _h.includes('SKU Partial Update'))
4339
4356
  && ((_j = e.tags) === null || _j === void 0 ? void 0 : _j.includes('Title Partial Update')));
4340
4357
  } })];
4341
- case 48:
4358
+ case 49:
4342
4359
  _a.sent();
4343
4360
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle', externalId: "also avoid rate limit 5" })];
4344
- case 49:
4361
+ case 50:
4345
4362
  _a.sent();
4346
4363
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", title: "PARTIAL-A only" })];
4347
- case 50:
4364
+ case 51:
4348
4365
  _a.sent();
4349
4366
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4350
- case 51:
4367
+ case 52:
4351
4368
  _a.sent(); // allow triggers to happen
4352
4369
  return [4 /*yield*/, async_test("Title partial AND no match (only one partial present)", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4353
4370
  var _a, _b;
4354
4371
  return !!(((_a = e.tags) === null || _a === void 0 ? void 0 : _a.length) === 7
4355
4372
  && !((_b = e.tags) === null || _b === void 0 ? void 0 : _b.includes('Title Partial And Update')));
4356
4373
  } })];
4357
- case 52:
4374
+ case 53:
4358
4375
  _a.sent();
4359
4376
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle', externalId: "also avoid rate limit 6" })];
4360
- case 53:
4377
+ case 54:
4361
4378
  _a.sent();
4362
4379
  return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", title: "PARTIAL-A and PARTIAL-B together" })];
4363
- case 54:
4380
+ case 55:
4364
4381
  _a.sent();
4365
4382
  return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4366
- case 55:
4383
+ case 56:
4367
4384
  _a.sent(); // allow triggers to happen
4368
4385
  return [4 /*yield*/, async_test("Title partial AND update tag added (both partials present)", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4369
4386
  var _a, _b, _c, _d, _f, _g, _h, _j, _k;
@@ -4377,7 +4394,47 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4377
4394
  && ((_j = e.tags) === null || _j === void 0 ? void 0 : _j.includes('Title Partial Update'))
4378
4395
  && ((_k = e.tags) === null || _k === void 0 ? void 0 : _k.includes('Title Partial And Update')));
4379
4396
  } })];
4380
- case 56:
4397
+ case 57:
4398
+ _a.sent();
4399
+ return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle', externalId: "also avoid rate limit 7" })];
4400
+ case 58:
4401
+ _a.sent();
4402
+ return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", protocol: 'Protocol-Mismatch', externalId: 'avoid rate limiting 7' })];
4403
+ case 59:
4404
+ _a.sent();
4405
+ return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4406
+ case 60:
4407
+ _a.sent(); // allow triggers to happen
4408
+ return [4 /*yield*/, async_test("Protocol no match (wrong protocol)", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4409
+ var _a, _b;
4410
+ return !!(((_a = e.tags) === null || _a === void 0 ? void 0 : _a.length) === 8
4411
+ && !((_b = e.tags) === null || _b === void 0 ? void 0 : _b.includes('Protocol Match')));
4412
+ } })];
4413
+ case 61:
4414
+ _a.sent();
4415
+ return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: 'Toggle', externalId: "also avoid rate limit 8" })];
4416
+ case 62:
4417
+ _a.sent();
4418
+ return [4 /*yield*/, sdk.api.enduser_orders.updateOne(u.id, { status: "Update", protocol: 'Protocol-A', externalId: 'avoid rate limiting 8' })];
4419
+ case 63:
4420
+ _a.sent();
4421
+ return [4 /*yield*/, wait(undefined, 500)]; // allow triggers to happen
4422
+ case 64:
4423
+ _a.sent(); // allow triggers to happen
4424
+ return [4 /*yield*/, async_test("Protocol match tag added", function () { return sdk.api.endusers.getOne(e.id); }, { onResult: function (e) {
4425
+ var _a, _b, _c, _d, _f, _g, _h, _j, _k, _l;
4426
+ return !!(((_a = e.tags) === null || _a === void 0 ? void 0 : _a.length) === 9
4427
+ && ((_b = e.tags) === null || _b === void 0 ? void 0 : _b.includes('Source'))
4428
+ && ((_c = e.tags) === null || _c === void 0 ? void 0 : _c.includes('Fill'))
4429
+ && ((_d = e.tags) === null || _d === void 0 ? void 0 : _d.includes('Status Update'))
4430
+ && ((_f = e.tags) === null || _f === void 0 ? void 0 : _f.includes('Fill Update'))
4431
+ && ((_g = e.tags) === null || _g === void 0 ? void 0 : _g.includes('SKU Update'))
4432
+ && ((_h = e.tags) === null || _h === void 0 ? void 0 : _h.includes('SKU Partial Update'))
4433
+ && ((_j = e.tags) === null || _j === void 0 ? void 0 : _j.includes('Title Partial Update'))
4434
+ && ((_k = e.tags) === null || _k === void 0 ? void 0 : _k.includes('Title Partial And Update'))
4435
+ && ((_l = e.tags) === null || _l === void 0 ? void 0 : _l.includes('Protocol Match')));
4436
+ } })];
4437
+ case 65:
4381
4438
  _a.sent();
4382
4439
  return [4 /*yield*/, Promise.all([
4383
4440
  sdk.api.automation_triggers.deleteOne(t1.id),
@@ -4388,9 +4445,10 @@ var order_status_equals_tests = function () { return __awaiter(void 0, void 0, v
4388
4445
  sdk.api.automation_triggers.deleteOne(t6.id),
4389
4446
  sdk.api.automation_triggers.deleteOne(t7.id),
4390
4447
  sdk.api.automation_triggers.deleteOne(t8.id),
4448
+ sdk.api.automation_triggers.deleteOne(t9.id),
4391
4449
  sdk.api.endusers.deleteOne(e.id),
4392
4450
  ])];
4393
- case 57:
4451
+ case 66:
4394
4452
  _a.sent();
4395
4453
  return [2 /*return*/];
4396
4454
  }
@@ -6090,10 +6148,10 @@ var automation_trigger_tests = function () { return __awaiter(void 0, void 0, vo
6090
6148
  switch (_a.label) {
6091
6149
  case 0:
6092
6150
  log_header("Automation Trigger Tests");
6093
- return [4 /*yield*/, medication_added_trigger_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
6151
+ return [4 /*yield*/, order_status_equals_tests()];
6094
6152
  case 1:
6095
6153
  _a.sent();
6096
- return [4 /*yield*/, order_status_equals_tests()];
6154
+ return [4 /*yield*/, medication_added_trigger_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
6097
6155
  case 2:
6098
6156
  _a.sent();
6099
6157
  return [4 /*yield*/, appointment_cancelled_tests()];
@@ -9941,7 +9999,7 @@ export var switch_to_related_contacts_tests = function () { return __awaiter(voi
9941
9999
  });
9942
10000
  }); };
9943
10001
  export var formsort_tests = function () { return __awaiter(void 0, void 0, void 0, function () {
9944
- var form, postToFormsort, postToFormsortGeneric, emailAnswer, nameAnswers, answersEmail, address, answers, submissionEnduser, validateResponse, specificEnduser, jsonResponseData, jsonData, combinedTestEnduser, combinedResponseData, combinedData, unfinalizedJsonResponse, invalidEnduserIdResponse, unfinalizedEnduserTest, endusers;
10002
+ var form, postToFormsort, postToFormsortGeneric, emailAnswer, nameAnswers, answersEmail, address, answers, submissionEnduser, validateResponse, specificEnduser, jsonResponseData, jsonData, combinedTestEnduser, combinedResponseData, combinedData, unfinalizedJsonResponse, invalidEnduserIdResponse, unfinalizedEnduserTest, validateFieldTitle, endusers;
9945
10003
  return __generator(this, function (_a) {
9946
10004
  switch (_a.label) {
9947
10005
  case 0:
@@ -10634,17 +10692,59 @@ export var formsort_tests = function () { return __awaiter(void 0, void 0, void
10634
10692
  return [4 /*yield*/, async_test("enduserId with finalized=true updates enduser fields", function () { return sdk.api.endusers.getOne(unfinalizedEnduserTest.id); }, {
10635
10693
  onResult: function (r) { return (r === null || r === void 0 ? void 0 : r.fname) === 'ChangedFirst' && (r === null || r === void 0 ? void 0 : r.lname) === 'ChangedLast'; }
10636
10694
  })
10637
- // cleanup
10695
+ // Test label as fieldTitle
10638
10696
  ];
10639
10697
  case 70:
10640
10698
  _a.sent();
10641
- return [4 /*yield*/, sdk.api.endusers.getSome()];
10699
+ validateFieldTitle = function (fr, key, expectedTitle) {
10700
+ var _a, _b;
10701
+ return ((_b = (_a = fr.responses) === null || _a === void 0 ? void 0 : _a.find(function (r) { return r.externalId === key; })) === null || _b === void 0 ? void 0 : _b.fieldTitle) === expectedTitle;
10702
+ };
10703
+ // Label provided: fieldTitle should use label, externalId should use key
10704
+ return [4 /*yield*/, postToFormsort({
10705
+ answers: [
10706
+ { key: 'email', value: 'label-test@tellescope.com' },
10707
+ { key: 'label_test_key', value: 'test_value', label: 'My Custom Label' },
10708
+ ],
10709
+ responder_uuid: "label-test",
10710
+ finalized: true,
10711
+ })];
10642
10712
  case 71:
10713
+ // Label provided: fieldTitle should use label, externalId should use key
10714
+ _a.sent();
10715
+ return [4 /*yield*/, async_test("label as fieldTitle", function () { return sdk.api.form_responses.getOne({ externalId: 'label-test' }); }, {
10716
+ onResult: function (r) { return validateFieldTitle(r, 'label_test_key', 'My Custom Label'); }
10717
+ })
10718
+ // No label: fieldTitle should fall back to key
10719
+ ];
10720
+ case 72:
10721
+ _a.sent();
10722
+ // No label: fieldTitle should fall back to key
10723
+ return [4 /*yield*/, postToFormsort({
10724
+ answers: [
10725
+ { key: 'email', value: 'no-label-test@tellescope.com' },
10726
+ { key: 'no_label_key', value: 'test_value' },
10727
+ ],
10728
+ responder_uuid: "no-label-test",
10729
+ finalized: true,
10730
+ })];
10731
+ case 73:
10732
+ // No label: fieldTitle should fall back to key
10733
+ _a.sent();
10734
+ return [4 /*yield*/, async_test("no label falls back to key as fieldTitle", function () { return sdk.api.form_responses.getOne({ externalId: 'no-label-test' }); }, {
10735
+ onResult: function (r) { return validateFieldTitle(r, 'no_label_key', 'no_label_key'); }
10736
+ })
10737
+ // cleanup
10738
+ ];
10739
+ case 74:
10740
+ _a.sent();
10741
+ return [4 /*yield*/, sdk.api.endusers.getSome()];
10742
+ case 75:
10643
10743
  endusers = _a.sent();
10644
10744
  return [4 /*yield*/, Promise.all(__spreadArray([
10645
10745
  sdk.api.forms.deleteOne(form.id)
10646
10746
  ], endusers.map(function (e) { return sdk.api.endusers.deleteOne(e.id); }), true))];
10647
- case 72:
10747
+ case 76:
10648
10748
  _a.sent();
10649
10749
  return [2 /*return*/];
10650
10750
  }
@@ -15849,7 +15949,7 @@ var ip_address_form_tests = function () { return __awaiter(void 0, void 0, void
15849
15949
  assert(truncate_string(null, { length: 4, showEllipsis: false }) === '', 'truncate doesnt work for non string', 'trucate works for non-string');
15850
15950
  _l.label = 2;
15851
15951
  case 2:
15852
- _l.trys.push([2, 116, , 117]);
15952
+ _l.trys.push([2, 125, , 126]);
15853
15953
  get_next_reminder_timestamp_tests();
15854
15954
  form_conditional_logic_tests();
15855
15955
  return [4 /*yield*/, test_weighted_round_robin()];
@@ -15990,309 +16090,336 @@ var ip_address_form_tests = function () { return __awaiter(void 0, void 0, void
15990
16090
  return [4 /*yield*/, setup_tests(sdk, sdkNonAdmin)];
15991
16091
  case 16:
15992
16092
  _l.sent();
15993
- return [4 /*yield*/, mdb_sort_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16093
+ return [4 /*yield*/, eom_procedure_codes_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
15994
16094
  case 17:
15995
16095
  _l.sent();
15996
- return [4 /*yield*/, organization_settings_duplicates_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16096
+ return [4 /*yield*/, cross_org_api_key_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
15997
16097
  case 18:
15998
16098
  _l.sent();
15999
- return [4 /*yield*/, search_tests()];
16099
+ return [4 /*yield*/, organization_settings_duplicates_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16000
16100
  case 19:
16001
16101
  _l.sent();
16002
- return [4 /*yield*/, time_tracks_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16102
+ return [4 /*yield*/, enduser_session_invalidation_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16003
16103
  case 20:
16004
16104
  _l.sent();
16005
- return [4 /*yield*/, time_tracks_historical_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16105
+ return [4 /*yield*/, chats_analytics_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16006
16106
  case 21:
16007
16107
  _l.sent();
16008
- return [4 /*yield*/, time_tracks_correction_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16108
+ return [4 /*yield*/, field_redaction_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16009
16109
  case 22:
16010
16110
  _l.sent();
16011
- return [4 /*yield*/, time_tracks_review_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16111
+ return [4 /*yield*/, form_submitted_trigger_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16012
16112
  case 23:
16013
16113
  _l.sent();
16014
- return [4 /*yield*/, time_tracks_lock_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16114
+ return [4 /*yield*/, date_string_validation_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16015
16115
  case 24:
16016
16116
  _l.sent();
16017
- return [4 /*yield*/, time_tracks_edge_case_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16117
+ return [4 /*yield*/, openloop_webhooks_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16018
16118
  case 25:
16019
16119
  _l.sent();
16020
- return [4 /*yield*/, calendar_event_limits_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16120
+ return [4 /*yield*/, automation_trigger_tests()];
16021
16121
  case 26:
16022
16122
  _l.sent();
16023
- return [4 /*yield*/, openloop_webhooks_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16123
+ return [4 /*yield*/, integrations_redacted_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16024
16124
  case 27:
16025
16125
  _l.sent();
16026
- return [4 /*yield*/, automation_trigger_tests()];
16126
+ return [4 /*yield*/, mdb_sort_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16027
16127
  case 28:
16028
16128
  _l.sent();
16029
- return [4 /*yield*/, get_some_projection_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16129
+ return [4 /*yield*/, search_tests()];
16030
16130
  case 29:
16031
16131
  _l.sent();
16032
- return [4 /*yield*/, elation_user_id_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16132
+ return [4 /*yield*/, time_tracks_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16033
16133
  case 30:
16034
16134
  _l.sent();
16035
- return [4 /*yield*/, custom_dashboards_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16135
+ return [4 /*yield*/, time_tracks_historical_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16036
16136
  case 31:
16037
16137
  _l.sent();
16038
- return [4 /*yield*/, concurrent_build_threads_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16138
+ return [4 /*yield*/, time_tracks_correction_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16039
16139
  case 32:
16040
16140
  _l.sent();
16041
- return [4 /*yield*/, custom_aggregation_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16141
+ return [4 /*yield*/, time_tracks_review_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16042
16142
  case 33:
16043
16143
  _l.sent();
16044
- return [4 /*yield*/, no_access_permission_checks_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16144
+ return [4 /*yield*/, time_tracks_lock_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16045
16145
  case 34:
16046
16146
  _l.sent();
16047
- return [4 /*yield*/, enduser_tests()];
16147
+ return [4 /*yield*/, time_tracks_edge_case_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16048
16148
  case 35:
16049
16149
  _l.sent();
16050
- return [4 /*yield*/, form_started_trigger_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16150
+ return [4 /*yield*/, calendar_event_limits_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16051
16151
  case 36:
16052
16152
  _l.sent();
16053
- return [4 /*yield*/, load_team_chat_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16153
+ return [4 /*yield*/, get_some_projection_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16054
16154
  case 37:
16055
16155
  _l.sent();
16056
- return [4 /*yield*/, ai_conversations_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16156
+ return [4 /*yield*/, elation_user_id_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16057
16157
  case 38:
16058
16158
  _l.sent();
16059
- return [4 /*yield*/, inbox_thread_assignment_updates_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16159
+ return [4 /*yield*/, custom_dashboards_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16060
16160
  case 39:
16061
16161
  _l.sent();
16062
- return [4 /*yield*/, inbox_thread_draft_scheduled_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16162
+ return [4 /*yield*/, concurrent_build_threads_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16063
16163
  case 40:
16064
16164
  _l.sent();
16065
- return [4 /*yield*/, load_threads_autobuild_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16165
+ return [4 /*yield*/, custom_aggregation_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16066
16166
  case 41:
16067
16167
  _l.sent();
16068
- return [4 /*yield*/, inbox_threads_new_fields_tests()];
16168
+ return [4 /*yield*/, no_access_permission_checks_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16069
16169
  case 42:
16070
16170
  _l.sent();
16071
- return [4 /*yield*/, auto_merge_form_submission_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16171
+ return [4 /*yield*/, enduser_tests()];
16072
16172
  case 43:
16073
16173
  _l.sent();
16074
- return [4 /*yield*/, beluga_pharmacy_mappings_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16174
+ return [4 /*yield*/, form_started_trigger_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16075
16175
  case 44:
16076
16176
  _l.sent();
16077
- return [4 /*yield*/, threadKeyTests()];
16177
+ return [4 /*yield*/, load_team_chat_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16078
16178
  case 45:
16079
16179
  _l.sent();
16080
- return [4 /*yield*/, managed_content_enduser_access_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16180
+ return [4 /*yield*/, ai_conversations_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16081
16181
  case 46:
16082
16182
  _l.sent();
16083
- return [4 /*yield*/, afteraction_day_of_month_delay_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16183
+ return [4 /*yield*/, inbox_thread_assignment_updates_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16084
16184
  case 47:
16085
16185
  _l.sent();
16086
- return [4 /*yield*/, bulk_assignment_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16186
+ return [4 /*yield*/, inbox_thread_draft_scheduled_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16087
16187
  case 48:
16088
16188
  _l.sent();
16089
- return [4 /*yield*/, formsort_tests()];
16189
+ return [4 /*yield*/, load_threads_autobuild_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16090
16190
  case 49:
16091
16191
  _l.sent();
16092
- return [4 /*yield*/, self_serve_appointment_booking_tests()];
16192
+ return [4 /*yield*/, inbox_threads_new_fields_tests()];
16093
16193
  case 50:
16094
16194
  _l.sent();
16095
- return [4 /*yield*/, test_ticket_automation_assignment_and_optimization()];
16195
+ return [4 /*yield*/, auto_merge_form_submission_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16096
16196
  case 51:
16097
16197
  _l.sent();
16098
- return [4 /*yield*/, monthly_availability_restrictions_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16198
+ return [4 /*yield*/, beluga_pharmacy_mappings_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16099
16199
  case 52:
16100
16200
  _l.sent();
16101
- return [4 /*yield*/, journey_error_branching_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16201
+ return [4 /*yield*/, threadKeyTests()];
16102
16202
  case 53:
16103
16203
  _l.sent();
16104
- return [4 /*yield*/, message_assignment_trigger_tests({ sdk: sdk })];
16204
+ return [4 /*yield*/, managed_content_enduser_access_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16105
16205
  case 54:
16106
16206
  _l.sent();
16107
- return [4 /*yield*/, inbox_threads_building_tests()];
16207
+ return [4 /*yield*/, managed_content_file_access_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16108
16208
  case 55:
16109
16209
  _l.sent();
16110
- return [4 /*yield*/, inbox_threads_loading_tests()];
16210
+ return [4 /*yield*/, afteraction_day_of_month_delay_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16111
16211
  case 56:
16112
16212
  _l.sent();
16113
- return [4 /*yield*/, load_inbox_data_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16213
+ return [4 /*yield*/, bulk_assignment_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16114
16214
  case 57:
16115
16215
  _l.sent();
16116
- return [4 /*yield*/, enduser_observations_acknowledge_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16216
+ return [4 /*yield*/, formsort_tests()];
16117
16217
  case 58:
16118
16218
  _l.sent();
16119
- return [4 /*yield*/, create_user_notifications_trigger_tests({ sdk: sdk })];
16219
+ return [4 /*yield*/, self_serve_appointment_booking_tests()];
16120
16220
  case 59:
16121
16221
  _l.sent();
16122
- return [4 /*yield*/, group_mms_active_tests()];
16222
+ return [4 /*yield*/, test_ticket_automation_assignment_and_optimization()];
16123
16223
  case 60:
16124
16224
  _l.sent();
16125
- return [4 /*yield*/, auto_reply_tests()];
16225
+ return [4 /*yield*/, monthly_availability_restrictions_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16126
16226
  case 61:
16127
16227
  _l.sent();
16128
- return [4 /*yield*/, relationships_tests()];
16228
+ return [4 /*yield*/, journey_error_branching_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16129
16229
  case 62:
16130
16230
  _l.sent();
16131
- return [4 /*yield*/, rate_limit_tests()];
16231
+ return [4 /*yield*/, message_assignment_trigger_tests({ sdk: sdk })];
16132
16232
  case 63:
16133
16233
  _l.sent();
16134
- return [4 /*yield*/, ip_address_form_tests()];
16234
+ return [4 /*yield*/, inbox_threads_building_tests()];
16135
16235
  case 64:
16136
16236
  _l.sent();
16137
- return [4 /*yield*/, bulk_update_tests()];
16237
+ return [4 /*yield*/, inbox_threads_loading_tests()];
16138
16238
  case 65:
16139
16239
  _l.sent();
16140
- return [4 /*yield*/, calendar_events_bulk_update_tests({ sdk: sdk })];
16240
+ return [4 /*yield*/, load_inbox_data_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16141
16241
  case 66:
16142
16242
  _l.sent();
16143
- return [4 /*yield*/, cancel_upcoming_appointments_journey_action_test()];
16243
+ return [4 /*yield*/, enduser_observations_acknowledge_tests({ sdk: sdk, sdkNonAdmin: sdkNonAdmin })];
16144
16244
  case 67:
16145
16245
  _l.sent();
16146
- return [4 /*yield*/, multi_tenant_tests()]; // should come right after setup tests
16246
+ return [4 /*yield*/, create_user_notifications_trigger_tests({ sdk: sdk })];
16147
16247
  case 68:
16248
+ _l.sent();
16249
+ return [4 /*yield*/, group_mms_active_tests()];
16250
+ case 69:
16251
+ _l.sent();
16252
+ return [4 /*yield*/, auto_reply_tests()];
16253
+ case 70:
16254
+ _l.sent();
16255
+ return [4 /*yield*/, relationships_tests()];
16256
+ case 71:
16257
+ _l.sent();
16258
+ return [4 /*yield*/, rate_limit_tests()];
16259
+ case 72:
16260
+ _l.sent();
16261
+ return [4 /*yield*/, ip_address_form_tests()];
16262
+ case 73:
16263
+ _l.sent();
16264
+ return [4 /*yield*/, bulk_update_tests()];
16265
+ case 74:
16266
+ _l.sent();
16267
+ return [4 /*yield*/, calendar_events_bulk_update_tests({ sdk: sdk })];
16268
+ case 75:
16269
+ _l.sent();
16270
+ return [4 /*yield*/, cancel_upcoming_appointments_journey_action_test()];
16271
+ case 76:
16272
+ _l.sent();
16273
+ return [4 /*yield*/, multi_tenant_tests()]; // should come right after setup tests
16274
+ case 77:
16148
16275
  _l.sent(); // should come right after setup tests
16149
16276
  return [4 /*yield*/, sync_tests_with_access_tags()]; // should come directly after setup to avoid extra sync values
16150
- case 69:
16277
+ case 78:
16151
16278
  _l.sent(); // should come directly after setup to avoid extra sync values
16152
16279
  return [4 /*yield*/, sync_tests()]; // should come directly after setup to avoid extra sync values
16153
- case 70:
16280
+ case 79:
16154
16281
  _l.sent(); // should come directly after setup to avoid extra sync values
16155
16282
  return [4 /*yield*/, get_templated_message_tests()];
16156
- case 71:
16283
+ case 80:
16157
16284
  _l.sent();
16158
16285
  return [4 /*yield*/, updatedAt_tests()];
16159
- case 72:
16286
+ case 81:
16160
16287
  _l.sent();
16161
16288
  return [4 /*yield*/, file_source_tests()];
16162
- case 73:
16289
+ case 82:
16163
16290
  _l.sent();
16164
16291
  return [4 /*yield*/, enduser_access_tags_tests()];
16165
- case 74:
16292
+ case 83:
16166
16293
  _l.sent();
16167
16294
  return [4 /*yield*/, enduserAccessTests()];
16168
- case 75:
16295
+ case 84:
16169
16296
  _l.sent();
16170
16297
  return [4 /*yield*/, test_form_response_search()];
16171
- case 76:
16298
+ case 85:
16172
16299
  _l.sent();
16173
16300
  return [4 /*yield*/, date_parsing_tests()];
16174
- case 77:
16301
+ case 86:
16175
16302
  _l.sent();
16176
16303
  return [4 /*yield*/, fromEmailOverride_tests()];
16177
- case 78:
16304
+ case 87:
16178
16305
  _l.sent();
16179
16306
  return [4 /*yield*/, ticket_tests()];
16180
- case 79:
16307
+ case 88:
16181
16308
  _l.sent();
16182
16309
  return [4 /*yield*/, uniqueness_tests()];
16183
- case 80:
16310
+ case 89:
16184
16311
  _l.sent();
16185
16312
  return [4 /*yield*/, enduser_orders_tests()];
16186
- case 81:
16313
+ case 90:
16187
16314
  _l.sent();
16188
16315
  return [4 /*yield*/, calendar_event_care_team_tests()];
16189
- case 82:
16316
+ case 91:
16190
16317
  _l.sent();
16191
16318
  return [4 /*yield*/, merge_enduser_tests()];
16192
- case 83:
16319
+ case 92:
16193
16320
  _l.sent();
16194
16321
  return [4 /*yield*/, input_modifier_tests()];
16195
- case 84:
16322
+ case 93:
16196
16323
  _l.sent();
16197
16324
  return [4 /*yield*/, switch_to_related_contacts_tests()];
16198
- case 85:
16325
+ case 94:
16199
16326
  _l.sent();
16200
16327
  return [4 /*yield*/, redaction_tests()];
16201
- case 86:
16328
+ case 95:
16202
16329
  _l.sent();
16203
16330
  return [4 /*yield*/, no_chained_triggers_tests()];
16204
- case 87:
16331
+ case 96:
16205
16332
  _l.sent();
16206
16333
  return [4 /*yield*/, mdb_filter_tests()];
16207
- case 88:
16334
+ case 97:
16208
16335
  _l.sent();
16209
16336
  return [4 /*yield*/, superadmin_tests()];
16210
- case 89:
16337
+ case 98:
16211
16338
  _l.sent();
16212
16339
  return [4 /*yield*/, ticket_queue_tests()];
16213
- case 90:
16340
+ case 99:
16214
16341
  _l.sent();
16215
16342
  return [4 /*yield*/, vital_trigger_tests()];
16216
- case 91:
16343
+ case 100:
16217
16344
  _l.sent();
16218
16345
  return [4 /*yield*/, close_reasons_no_duplicates_tests()];
16219
- case 92:
16346
+ case 101:
16220
16347
  _l.sent();
16221
16348
  return [4 /*yield*/, register_as_enduser_tests()];
16222
- case 93:
16349
+ case 102:
16223
16350
  _l.sent();
16224
16351
  return [4 /*yield*/, lockout_tests()];
16225
- case 94:
16352
+ case 103:
16226
16353
  _l.sent();
16227
16354
  return [4 /*yield*/, delete_user_tests()
16228
16355
  // await test_send_with_template()
16229
16356
  ];
16230
- case 95:
16357
+ case 104:
16231
16358
  _l.sent();
16232
16359
  // await test_send_with_template()
16233
16360
  return [4 /*yield*/, bulk_read_tests()];
16234
- case 96:
16361
+ case 105:
16235
16362
  // await test_send_with_template()
16236
16363
  _l.sent();
16237
16364
  return [4 /*yield*/, ticket_reminder_tests()];
16238
- case 97:
16365
+ case 106:
16239
16366
  _l.sent();
16240
16367
  return [4 /*yield*/, marketing_email_unsubscribe_tests()];
16241
- case 98:
16368
+ case 107:
16242
16369
  _l.sent();
16243
16370
  return [4 /*yield*/, unique_strings_tests()];
16244
- case 99:
16371
+ case 108:
16245
16372
  _l.sent();
16246
16373
  return [4 /*yield*/, alternate_phones_tests()];
16247
- case 100:
16374
+ case 109:
16248
16375
  _l.sent();
16249
16376
  return [4 /*yield*/, role_based_access_tests()];
16250
- case 101:
16377
+ case 110:
16251
16378
  _l.sent();
16252
16379
  return [4 /*yield*/, enduser_session_tests()];
16253
- case 102:
16380
+ case 111:
16254
16381
  _l.sent();
16255
16382
  return [4 /*yield*/, nextReminderInMS_tests()];
16256
- case 103:
16383
+ case 112:
16257
16384
  _l.sent();
16258
16385
  return [4 /*yield*/, wait_for_trigger_tests()];
16259
- case 104:
16386
+ case 113:
16260
16387
  _l.sent();
16261
16388
  return [4 /*yield*/, pdf_generation()];
16262
- case 105:
16389
+ case 114:
16263
16390
  _l.sent();
16264
16391
  return [4 /*yield*/, remove_from_journey_on_incoming_comms_tests().catch(console.error)]; // timing is unreliable, uncomment if changing logic
16265
- case 106:
16392
+ case 115:
16266
16393
  _l.sent(); // timing is unreliable, uncomment if changing logic
16267
16394
  return [4 /*yield*/, sub_organization_enduser_tests()];
16268
- case 107:
16395
+ case 116:
16269
16396
  _l.sent();
16270
16397
  return [4 /*yield*/, sub_organization_tests()];
16271
- case 108:
16398
+ case 117:
16272
16399
  _l.sent();
16273
16400
  return [4 /*yield*/, filter_by_date_tests()];
16274
- case 109:
16401
+ case 118:
16275
16402
  _l.sent();
16276
16403
  return [4 /*yield*/, generate_user_auth_tests()];
16277
- case 110:
16404
+ case 119:
16278
16405
  _l.sent();
16279
16406
  return [4 /*yield*/, generateEnduserAuthTests()];
16280
- case 111:
16407
+ case 120:
16281
16408
  _l.sent();
16282
16409
  return [4 /*yield*/, public_form_tests()];
16283
- case 112:
16410
+ case 121:
16284
16411
  _l.sent();
16285
16412
  return [4 /*yield*/, badInputTests()];
16286
- case 113:
16413
+ case 122:
16287
16414
  _l.sent();
16288
16415
  return [4 /*yield*/, filterTests()];
16289
- case 114:
16416
+ case 123:
16290
16417
  _l.sent();
16291
16418
  return [4 /*yield*/, updatesTests()];
16292
- case 115:
16419
+ case 124:
16293
16420
  _l.sent();
16294
- return [3 /*break*/, 117];
16295
- case 116:
16421
+ return [3 /*break*/, 126];
16422
+ case 125:
16296
16423
  err_1 = _l.sent();
16297
16424
  console.error("Failed during custom test");
16298
16425
  if (err_1.message && err_1.info) {
@@ -16302,18 +16429,18 @@ var ip_address_form_tests = function () { return __awaiter(void 0, void 0, void
16302
16429
  console.error(err_1);
16303
16430
  }
16304
16431
  process.exit(1);
16305
- return [3 /*break*/, 117];
16306
- case 117:
16432
+ return [3 /*break*/, 126];
16433
+ case 126:
16307
16434
  _a = schema;
16308
16435
  _b = [];
16309
16436
  for (_c in _a)
16310
16437
  _b.push(_c);
16311
16438
  _i = 0;
16312
- _l.label = 118;
16313
- case 118:
16314
- if (!(_i < _b.length)) return [3 /*break*/, 121];
16439
+ _l.label = 127;
16440
+ case 127:
16441
+ if (!(_i < _b.length)) return [3 /*break*/, 130];
16315
16442
  _c = _b[_i];
16316
- if (!(_c in _a)) return [3 /*break*/, 120];
16443
+ if (!(_c in _a)) return [3 /*break*/, 129];
16317
16444
  n = _c;
16318
16445
  returnValidation = (_k = (_j = schema[n].customActions) === null || _j === void 0 ? void 0 : _j.create) === null || _k === void 0 ? void 0 : _k.returns;
16319
16446
  return [4 /*yield*/, run_generated_tests({
@@ -16324,41 +16451,41 @@ var ip_address_form_tests = function () { return __awaiter(void 0, void 0, void
16324
16451
  create: returnValidation // ModelFields<ClientModel>,
16325
16452
  }
16326
16453
  })];
16327
- case 119:
16454
+ case 128:
16328
16455
  _l.sent();
16329
- _l.label = 120;
16330
- case 120:
16456
+ _l.label = 129;
16457
+ case 129:
16331
16458
  _i++;
16332
- return [3 /*break*/, 118];
16333
- case 121:
16459
+ return [3 /*break*/, 127];
16460
+ case 130:
16334
16461
  _d = tests;
16335
16462
  _f = [];
16336
16463
  for (_g in _d)
16337
16464
  _f.push(_g);
16338
16465
  _h = 0;
16339
- _l.label = 122;
16340
- case 122:
16341
- if (!(_h < _f.length)) return [3 /*break*/, 127];
16466
+ _l.label = 131;
16467
+ case 131:
16468
+ if (!(_h < _f.length)) return [3 /*break*/, 136];
16342
16469
  _g = _f[_h];
16343
- if (!(_g in _d)) return [3 /*break*/, 126];
16470
+ if (!(_g in _d)) return [3 /*break*/, 135];
16344
16471
  t = _g;
16345
- _l.label = 123;
16346
- case 123:
16347
- _l.trys.push([123, 125, , 126]);
16472
+ _l.label = 132;
16473
+ case 132:
16474
+ _l.trys.push([132, 134, , 135]);
16348
16475
  return [4 /*yield*/, tests[t]()];
16349
- case 124:
16476
+ case 133:
16350
16477
  _l.sent();
16351
- return [3 /*break*/, 126];
16352
- case 125:
16478
+ return [3 /*break*/, 135];
16479
+ case 134:
16353
16480
  err_2 = _l.sent();
16354
16481
  console.error("Error running test:");
16355
16482
  console.error(err_2);
16356
16483
  process.exit(1);
16357
- return [3 /*break*/, 126];
16358
- case 126:
16484
+ return [3 /*break*/, 135];
16485
+ case 135:
16359
16486
  _h++;
16360
- return [3 /*break*/, 122];
16361
- case 127:
16487
+ return [3 /*break*/, 131];
16488
+ case 136:
16362
16489
  process.exit();
16363
16490
  return [2 /*return*/];
16364
16491
  }