@tellescope/sdk 1.201.0 → 1.203.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.
@@ -17,5 +17,7 @@ export declare const switch_to_related_contacts_tests: () => Promise<[void, void
17
17
  export declare const formsort_tests: () => Promise<void>;
18
18
  export declare const enduser_orders_tests: () => Promise<void[]>;
19
19
  export declare const form_conditional_logic_tests: () => Promise<void>;
20
+ export declare const enduser_conditional_logic_tests: () => Promise<void>;
21
+ export declare const cancel_upcoming_appointments_journey_action_test: () => Promise<void>;
20
22
  export declare const ticket_reminder_tests: () => Promise<void>;
21
23
  //# sourceMappingURL=tests.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"tests.d.ts","sourceRoot":"","sources":["../../../src/tests/tests.ts"],"names":[],"mappings":"AAwxEA,eAAO,MAAM,kCAAkC,qBAgJ9C,CAAA;AAED,eAAO,MAAM,mCAAmC,qBA2K/C,CAAA;AAGD,eAAO,MAAM,oBAAoB,qBAoHhC,CAAA;AAED,eAAO,MAAM,+BAA+B,qBAsF3C,CAAA;AAID,eAAO,MAAM,0BAA0B,qBAqCtC,CAAA;AA22CD,eAAO,MAAM,cAAc,qBAqC1B,CAAA;AAqmBD,eAAO,MAAM,6BAA6B,qBAgCzC,CAAA;AAED,eAAO,MAAM,0BAA0B,qBAmFtC,CAAA;AAqED,eAAO,MAAM,eAAe,qBAgD3B,CAAA;AAED,eAAO,MAAM,oBAAoB,6BAsBhC,CAAA;AAED,eAAO,MAAM,oCAAoC,qBA2ahD,CAAA;AAED,eAAO,MAAM,mCAAmC,qBAkE/C,CAAA;AAgyCD,eAAO,MAAM,yBAAyB,qBA0DrC,CAAA;AAED,eAAO,MAAM,kBAAkB,qBAmK9B,CAAA;AAED,eAAO,MAAM,sBAAsB,qBA0BlC,CAAA;AAED,eAAO,MAAM,gCAAgC,mCA2C5C,CAAA;AAED,eAAO,MAAM,cAAc,qBAyO1B,CAAA;AAGD,eAAO,MAAM,oBAAoB,uBAuBhC,CAAA;AA0oBD,eAAO,MAAM,4BAA4B,qBAoExC,CAAA;AAED,eAAO,MAAM,qBAAqB,qBAwIjC,CAAA"}
1
+ {"version":3,"file":"tests.d.ts","sourceRoot":"","sources":["../../../src/tests/tests.ts"],"names":[],"mappings":"AAwxEA,eAAO,MAAM,kCAAkC,qBAgJ9C,CAAA;AAED,eAAO,MAAM,mCAAmC,qBA2K/C,CAAA;AAGD,eAAO,MAAM,oBAAoB,qBAoHhC,CAAA;AAED,eAAO,MAAM,+BAA+B,qBAsF3C,CAAA;AAID,eAAO,MAAM,0BAA0B,qBAqCtC,CAAA;AA22CD,eAAO,MAAM,cAAc,qBAqC1B,CAAA;AAqmBD,eAAO,MAAM,6BAA6B,qBAgCzC,CAAA;AAED,eAAO,MAAM,0BAA0B,qBAmFtC,CAAA;AAqED,eAAO,MAAM,eAAe,qBAgD3B,CAAA;AAED,eAAO,MAAM,oBAAoB,6BAsBhC,CAAA;AAED,eAAO,MAAM,oCAAoC,qBA2ahD,CAAA;AAED,eAAO,MAAM,mCAAmC,qBAkE/C,CAAA;AAgyCD,eAAO,MAAM,yBAAyB,qBA0DrC,CAAA;AAED,eAAO,MAAM,kBAAkB,qBAmK9B,CAAA;AAED,eAAO,MAAM,sBAAsB,qBA0BlC,CAAA;AAED,eAAO,MAAM,gCAAgC,mCA2C5C,CAAA;AAED,eAAO,MAAM,cAAc,qBAiQ1B,CAAA;AAGD,eAAO,MAAM,oBAAoB,uBAuBhC,CAAA;AA0oBD,eAAO,MAAM,4BAA4B,qBAoExC,CAAA;AAED,eAAO,MAAM,+BAA+B,qBA0F3C,CAAA;AAED,eAAO,MAAM,gDAAgD,qBAwC5D,CAAA;AAED,eAAO,MAAM,qBAAqB,qBAwIjC,CAAA"}
@@ -93,7 +93,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
93
93
  return (mod && mod.__esModule) ? mod : { "default": mod };
94
94
  };
95
95
  Object.defineProperty(exports, "__esModule", { value: true });
96
- exports.ticket_reminder_tests = exports.form_conditional_logic_tests = exports.enduser_orders_tests = exports.formsort_tests = exports.switch_to_related_contacts_tests = exports.alternate_phones_tests = exports.ticket_queue_tests = exports.no_chained_triggers_tests = exports.role_based_access_permissions_tests = exports.self_serve_appointment_booking_tests = exports.filter_by_date_tests = exports.databases_tests = exports.calendar_event_RSVPs_tests = exports.managed_content_records_tests = exports.meetings_tests = exports.automationSameJourneyTests = exports.formsSubmittedNoUnsubmittedTest = exports.formsUnsubmittedTest = exports.formsUnsubmittedCancelConditionTest = exports.formUnsubmittedCancelConditionTest = void 0;
96
+ exports.ticket_reminder_tests = exports.cancel_upcoming_appointments_journey_action_test = exports.enduser_conditional_logic_tests = exports.form_conditional_logic_tests = exports.enduser_orders_tests = exports.formsort_tests = exports.switch_to_related_contacts_tests = exports.alternate_phones_tests = exports.ticket_queue_tests = exports.no_chained_triggers_tests = exports.role_based_access_permissions_tests = exports.self_serve_appointment_booking_tests = exports.filter_by_date_tests = exports.databases_tests = exports.calendar_event_RSVPs_tests = exports.managed_content_records_tests = exports.meetings_tests = exports.automationSameJourneyTests = exports.formsSubmittedNoUnsubmittedTest = exports.formsUnsubmittedTest = exports.formsUnsubmittedCancelConditionTest = exports.formUnsubmittedCancelConditionTest = void 0;
97
97
  require('source-map-support').install();
98
98
  var axios_1 = __importDefault(require("axios"));
99
99
  var crypto_1 = __importDefault(require("crypto"));
@@ -8584,23 +8584,23 @@ var formsort_tests = function () { return __awaiter(void 0, void 0, void 0, func
8584
8584
  case 1:
8585
8585
  form = _a.sent();
8586
8586
  postToFormsort = function (_a) { return __awaiter(void 0, void 0, void 0, function () {
8587
- var _b = _a.matchByName, matchByName = _b === void 0 ? false : _b, o = __rest(_a, ["matchByName"]);
8588
- return __generator(this, function (_c) {
8589
- switch (_c.label) {
8590
- case 0: return [4 /*yield*/, axios_1.default.post("".concat(host, "/v1/webhooks/formsort/9d4f9dff00f60df2690a16da2cb848f289b447614ad9bef850e54af09a1fbf7a?formId=").concat(form.id, "&matchByName=").concat(matchByName), o)];
8587
+ var _b = _a.matchByName, matchByName = _b === void 0 ? false : _b, _c = _a.createNewEnduser, createNewEnduser = _c === void 0 ? false : _c, o = __rest(_a, ["matchByName", "createNewEnduser"]);
8588
+ return __generator(this, function (_d) {
8589
+ switch (_d.label) {
8590
+ case 0: return [4 /*yield*/, axios_1.default.post("".concat(host, "/v1/webhooks/formsort/9d4f9dff00f60df2690a16da2cb848f289b447614ad9bef850e54af09a1fbf7a?formId=").concat(form.id, "&matchByName=").concat(matchByName, "&createNewEnduser=").concat(createNewEnduser), o)];
8591
8591
  case 1:
8592
- _c.sent();
8592
+ _d.sent();
8593
8593
  return [2 /*return*/];
8594
8594
  }
8595
8595
  });
8596
8596
  }); };
8597
8597
  postToFormsortGeneric = function (_a) { return __awaiter(void 0, void 0, void 0, function () {
8598
- var _b = _a.matchByName, matchByName = _b === void 0 ? false : _b, o = __rest(_a, ["matchByName"]);
8599
- return __generator(this, function (_c) {
8600
- switch (_c.label) {
8601
- case 0: return [4 /*yield*/, axios_1.default.post("".concat(host, "/v1/webhooks/form-ingestion/9d4f9dff00f60df2690a16da2cb848f289b447614ad9bef850e54af09a1fbf7a?formId=").concat(form.id, "&matchByName=").concat(matchByName), o)];
8598
+ var _b = _a.matchByName, matchByName = _b === void 0 ? false : _b, _c = _a.createNewEnduser, createNewEnduser = _c === void 0 ? false : _c, o = __rest(_a, ["matchByName", "createNewEnduser"]);
8599
+ return __generator(this, function (_d) {
8600
+ switch (_d.label) {
8601
+ case 0: return [4 /*yield*/, axios_1.default.post("".concat(host, "/v1/webhooks/form-ingestion/9d4f9dff00f60df2690a16da2cb848f289b447614ad9bef850e54af09a1fbf7a?formId=").concat(form.id, "&matchByName=").concat(matchByName, "&createNewEnduser=").concat(createNewEnduser), o)];
8602
8602
  case 1:
8603
- _c.sent();
8603
+ _d.sent();
8604
8604
  return [2 /*return*/];
8605
8605
  }
8606
8606
  });
@@ -9007,19 +9007,56 @@ var formsort_tests = function () { return __awaiter(void 0, void 0, void 0, func
9007
9007
  }
9008
9008
  return true;
9009
9009
  }
9010
+ })];
9011
+ case 35:
9012
+ // EXISTING ENDUSER FIELDS ARE CURRENTLY ONLY UPDATED ON SUBMISSION
9013
+ _a.sent();
9014
+ return [4 /*yield*/, postToFormsort({ answers: [emailAnswer], responder_uuid: "createNewEnduser", finalized: false, createNewEnduser: true })];
9015
+ case 36:
9016
+ _a.sent();
9017
+ return [4 /*yield*/, (0, testing_1.async_test)("new enduser and form response created (1)", sdk.api.form_responses.getSome, { onResult: function (r) { return r.length === 7; } })];
9018
+ case 37:
9019
+ _a.sent();
9020
+ return [4 /*yield*/, (0, testing_1.async_test)("new enduser and form response created (1)", sdk.api.endusers.getSome, { onResult: function (r) { return r.length === 5; } })];
9021
+ case 38:
9022
+ _a.sent();
9023
+ return [4 /*yield*/, postToFormsort({ answers: [emailAnswer], responder_uuid: "createNewEnduser", finalized: false, createNewEnduser: true })];
9024
+ case 39:
9025
+ _a.sent();
9026
+ return [4 /*yield*/, (0, testing_1.async_test)("new enduser and form response created (2)", sdk.api.form_responses.getSome, {
9027
+ onResult: function (r) { return r.length === 8 && r.filter(function (e) { return e.externalId === 'createNewEnduser'; }).length === 2; }
9028
+ })];
9029
+ case 40:
9030
+ _a.sent();
9031
+ return [4 /*yield*/, (0, testing_1.async_test)("new enduser and form response created (2)", sdk.api.endusers.getSome, {
9032
+ onResult: function (r) { return r.length === 6 && r.filter(function (e) { return e.externalId === 'createNewEnduser'; }).length === 2; }
9033
+ })];
9034
+ case 41:
9035
+ _a.sent();
9036
+ return [4 /*yield*/, postToFormsort({ answers: [emailAnswer], responder_uuid: "createNewEnduser", finalized: true, createNewEnduser: true })];
9037
+ case 42:
9038
+ _a.sent();
9039
+ return [4 /*yield*/, (0, testing_1.async_test)("new enduser and form response created (3, finalized)", sdk.api.form_responses.getSome, {
9040
+ onResult: function (r) { return r.length === 9 && r.filter(function (e) { return e.externalId === 'createNewEnduser'; }).length === 3; }
9041
+ })];
9042
+ case 43:
9043
+ _a.sent();
9044
+ return [4 /*yield*/, (0, testing_1.async_test)("new enduser and form response created (3, finalized)", sdk.api.endusers.getSome, {
9045
+ onResult: function (r) { return r.length === 7
9046
+ && r.filter(function (e) { return e.externalId === 'createNewEnduser'; }).length === 3
9047
+ && r.filter(function (e) { return e.externalId === 'createNewEnduser' && e.email === emailAnswer.value; }).length === 1; } // email set on finalized
9010
9048
  })
9011
9049
  // cleanup
9012
9050
  ];
9013
- case 35:
9014
- // EXISTING ENDUSER FIELDS ARE CURRENTLY ONLY UPDATED ON SUBMISSION
9051
+ case 44:
9015
9052
  _a.sent();
9016
9053
  return [4 /*yield*/, sdk.api.endusers.getSome()];
9017
- case 36:
9054
+ case 45:
9018
9055
  endusers = _a.sent();
9019
9056
  return [4 /*yield*/, Promise.all(__spreadArray([
9020
9057
  sdk.api.forms.deleteOne(form.id)
9021
9058
  ], endusers.map(function (e) { return sdk.api.endusers.deleteOne(e.id); }), true))];
9022
- case 37:
9059
+ case 46:
9023
9060
  _a.sent();
9024
9061
  return [2 /*return*/];
9025
9062
  }
@@ -9843,6 +9880,97 @@ var form_conditional_logic_tests = function () { return __awaiter(void 0, void 0
9843
9880
  });
9844
9881
  }); };
9845
9882
  exports.form_conditional_logic_tests = form_conditional_logic_tests;
9883
+ var enduser_conditional_logic_tests = function () { return __awaiter(void 0, void 0, void 0, function () {
9884
+ var requiredPlaceholders;
9885
+ return __generator(this, function (_a) {
9886
+ (0, testing_1.log_header)("Enduser Conditional Logic Tests");
9887
+ requiredPlaceholders = {
9888
+ businessId: '', creator: '', hashedPassword: '', lastActive: '', lastLogout: '', updatedAt: new Date(),
9889
+ };
9890
+ (0, testing_1.assert)((0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [] }), {}), 'Conditional logic error', 'blank upcoming events with blank condition');
9891
+ (0, testing_1.assert)((0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [] }), { "$and": [] }), 'Conditional logic error', 'blank upcoming events with empty and condition');
9892
+ (0, testing_1.assert)((0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [] }), {
9893
+ "$and": [{ "condition": { "__upcomingEvents__": { "$lt": "1", "$fromOffset": -3600000, "$toOffset": 3600000 } } }]
9894
+ }), 'Conditional logic error', 'blank upcoming events with less than 1 condition');
9895
+ (0, testing_1.assert)(!(0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [] }), {
9896
+ "$and": [{ "condition": { "__upcomingEvents__": { "$lt": "0", "$fromOffset": -3600000, "$toOffset": 3600000 } } }]
9897
+ }), 'Conditional logic error', 'blank upcoming events with less than 0 condition');
9898
+ (0, testing_1.assert)(!(0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [] }), {
9899
+ "$and": [{ "condition": { "__upcomingEvents__": { "$gt": "0", "$fromOffset": -3600000, "$toOffset": 3600000 } } }]
9900
+ }), 'Conditional logic error', 'blank upcoming events with greater than 0 condition');
9901
+ (0, testing_1.assert)(!(0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [{ startTimeInMS: Date.now() - 10000 }] }), {
9902
+ "$and": [{ "condition": { "__upcomingEvents__": { "$gt": "0" } } }]
9903
+ }), 'Conditional logic error', 'past events are ignored by default (no $fromOffset set)');
9904
+ (0, testing_1.assert)((0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [{ startTimeInMS: Date.now() + 10000 }] }), {
9905
+ "$and": [{ "condition": { "__upcomingEvents__": { "$gt": "0" } } }]
9906
+ }), 'Conditional logic error', 'future events are recognized by default (no $fromOffset set)');
9907
+ (0, testing_1.assert)(!(0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [{ startTimeInMS: Date.now() - 100000 }] }), {
9908
+ "$and": [{ "condition": { "__upcomingEvents__": { "$gt": "0", "$fromOffset": -10000, "$toOffset": 3600000 } } }]
9909
+ }), 'Conditional logic error', 'Past event outside of window');
9910
+ (0, testing_1.assert)((0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [{ startTimeInMS: Date.now() - 100 }] }), {
9911
+ "$and": [{ "condition": { "__upcomingEvents__": { "$gt": "0", "$fromOffset": -10000, "$toOffset": 3600000 } } }]
9912
+ }), 'Conditional logic error', 'Past event inside of window');
9913
+ (0, testing_1.assert)(!(0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [{ startTimeInMS: Date.now() + 1000000 }] }), {
9914
+ "$and": [{ "condition": { "__upcomingEvents__": { "$gt": "0", "$fromOffset": -10000, "$toOffset": 10000 } } }]
9915
+ }), 'Conditional logic error', 'Future event outside of window');
9916
+ (0, testing_1.assert)((0, utilities_1.evaluate_conditional_logic_for_enduser_fields)(__assign(__assign({}, requiredPlaceholders), { _upcomingEvents: [{ startTimeInMS: Date.now() + 100 }] }), {
9917
+ "$and": [{ "condition": { "__upcomingEvents__": { "$gt": "0", "$fromOffset": -10000, "$toOffset": 10000 } } }]
9918
+ }), 'Conditional logic error', 'Future event inside of window');
9919
+ return [2 /*return*/];
9920
+ });
9921
+ }); };
9922
+ exports.enduser_conditional_logic_tests = enduser_conditional_logic_tests;
9923
+ var cancel_upcoming_appointments_journey_action_test = function () { return __awaiter(void 0, void 0, void 0, function () {
9924
+ var enduser, e1, e2, e3, e4;
9925
+ return __generator(this, function (_a) {
9926
+ switch (_a.label) {
9927
+ case 0:
9928
+ (0, testing_1.log_header)("Cancel Upcoming Appointments Journey Action Test");
9929
+ return [4 /*yield*/, sdk.api.endusers.createOne({})];
9930
+ case 1:
9931
+ enduser = _a.sent();
9932
+ return [4 /*yield*/, sdk.api.calendar_events.createOne({ title: 'past', startTimeInMS: Date.now() - 100000, durationInMinutes: 60, attendees: [{ type: 'enduser', id: enduser.id }] })];
9933
+ case 2:
9934
+ e1 = _a.sent();
9935
+ return [4 /*yield*/, sdk.api.calendar_events.createOne({ title: 'future', startTimeInMS: Date.now() + 100000, durationInMinutes: 60, attendees: [{ type: 'enduser', id: enduser.id }] })];
9936
+ case 3:
9937
+ e2 = _a.sent();
9938
+ return [4 /*yield*/, sdk.api.calendar_events.createOne({ title: 'past, not enduser', startTimeInMS: Date.now() + 100000, durationInMinutes: 60 })];
9939
+ case 4:
9940
+ e3 = _a.sent();
9941
+ return [4 /*yield*/, sdk.api.calendar_events.createOne({ title: 'future, not enduser', startTimeInMS: Date.now() + 100000, durationInMinutes: 60 })];
9942
+ case 5:
9943
+ e4 = _a.sent();
9944
+ return [4 /*yield*/, sdk.api.automated_actions.createOne({
9945
+ automationStepId: constants_1.PLACEHOLDER_ID, journeyId: constants_1.PLACEHOLDER_ID,
9946
+ processAfter: 0, status: 'active',
9947
+ enduserId: enduser.id,
9948
+ event: { type: 'onJourneyStart', info: {} },
9949
+ action: { type: 'cancelFutureAppointments', info: {} },
9950
+ })];
9951
+ case 6:
9952
+ _a.sent();
9953
+ return [4 /*yield*/, (0, testing_1.async_test)("Upcoming event is cancelled, past appointment is not", function () { return pollForResults(sdk.api.calendar_events.getSome, function (es) { return (!!es.find(function (e) { return e.id === e1.id && !e.cancelledAt; }) // past event should not be cancelled
9954
+ && !!es.find(function (e) { return e.id === e2.id && !!e.cancelledAt; }) // future event should be cancelled
9955
+ && !!es.find(function (e) { return e.id === e3.id && !e.cancelledAt; }) // past event not enduser should not be cancelled
9956
+ && !!es.find(function (e) { return e.id === e4.id && !e.cancelledAt; }) // future event not enduser should not be cancelled
9957
+ ); }, 50, 100); }, passOnAnyResult)];
9958
+ case 7:
9959
+ _a.sent();
9960
+ return [4 /*yield*/, Promise.all([
9961
+ sdk.api.endusers.deleteOne(enduser.id),
9962
+ sdk.api.calendar_events.deleteOne(e1.id),
9963
+ sdk.api.calendar_events.deleteOne(e2.id),
9964
+ sdk.api.calendar_events.deleteOne(e3.id),
9965
+ sdk.api.calendar_events.deleteOne(e4.id),
9966
+ ])];
9967
+ case 8:
9968
+ _a.sent();
9969
+ return [2 /*return*/];
9970
+ }
9971
+ });
9972
+ }); };
9973
+ exports.cancel_upcoming_appointments_journey_action_test = cancel_upcoming_appointments_journey_action_test;
9846
9974
  var ticket_reminder_tests = function () { return __awaiter(void 0, void 0, void 0, function () {
9847
9975
  var toDelete, dueDateInMS, title, LEEWAY, withLeeway, tToUpdate, tToRemind;
9848
9976
  return __generator(this, function (_a) {
@@ -12943,7 +13071,7 @@ var inbox_loading_tests = function () { return __awaiter(void 0, void 0, void 0,
12943
13071
  _l.sent();
12944
13072
  _l.label = 2;
12945
13073
  case 2:
12946
- _l.trys.push([2, 74, , 75]);
13074
+ _l.trys.push([2, 76, , 77]);
12947
13075
  (0, exports.form_conditional_logic_tests)();
12948
13076
  return [4 /*yield*/, test_weighted_round_robin()];
12949
13077
  case 3:
@@ -13071,195 +13199,201 @@ var inbox_loading_tests = function () { return __awaiter(void 0, void 0, void 0,
13071
13199
  return [4 /*yield*/, (0, testing_1.async_test)("Support phone numbers from Gambia", function () { return sdk.api.endusers.createOne({ phone: "+2201231234" }); }, { onResult: (function (e) { return !!sdk.api.endusers.deleteOne(e.id); }) })];
13072
13200
  case 12:
13073
13201
  _l.sent();
13074
- return [4 /*yield*/, replace_enduser_template_values_tests()];
13202
+ return [4 /*yield*/, (0, exports.enduser_conditional_logic_tests)()];
13075
13203
  case 13:
13076
13204
  _l.sent();
13077
- return [4 /*yield*/, mfa_tests()];
13205
+ return [4 /*yield*/, replace_enduser_template_values_tests()];
13078
13206
  case 14:
13079
13207
  _l.sent();
13080
- return [4 /*yield*/, setup_tests()];
13208
+ return [4 /*yield*/, mfa_tests()];
13081
13209
  case 15:
13082
13210
  _l.sent();
13083
- return [4 /*yield*/, inbox_loading_tests()];
13211
+ return [4 /*yield*/, setup_tests()];
13084
13212
  case 16:
13085
13213
  _l.sent();
13086
- return [4 /*yield*/, multi_tenant_tests()]; // should come right after setup tests
13214
+ return [4 /*yield*/, (0, exports.formsort_tests)()];
13087
13215
  case 17:
13216
+ _l.sent();
13217
+ return [4 /*yield*/, inbox_loading_tests()];
13218
+ case 18:
13219
+ _l.sent();
13220
+ return [4 /*yield*/, (0, exports.cancel_upcoming_appointments_journey_action_test)()];
13221
+ case 19:
13222
+ _l.sent();
13223
+ return [4 /*yield*/, multi_tenant_tests()]; // should come right after setup tests
13224
+ case 20:
13088
13225
  _l.sent(); // should come right after setup tests
13089
13226
  return [4 /*yield*/, sync_tests_with_access_tags()]; // should come directly after setup to avoid extra sync values
13090
- case 18:
13227
+ case 21:
13091
13228
  _l.sent(); // should come directly after setup to avoid extra sync values
13092
13229
  return [4 /*yield*/, sync_tests()]; // should come directly after setup to avoid extra sync values
13093
- case 19:
13230
+ case 22:
13094
13231
  _l.sent(); // should come directly after setup to avoid extra sync values
13095
13232
  return [4 /*yield*/, get_templated_message_tests()];
13096
- case 20:
13233
+ case 23:
13097
13234
  _l.sent();
13098
13235
  return [4 /*yield*/, updatedAt_tests()];
13099
- case 21:
13236
+ case 24:
13100
13237
  _l.sent();
13101
13238
  return [4 /*yield*/, automation_trigger_tests()];
13102
- case 22:
13239
+ case 25:
13103
13240
  _l.sent();
13104
13241
  return [4 /*yield*/, file_source_tests()];
13105
- case 23:
13242
+ case 26:
13106
13243
  _l.sent();
13107
13244
  return [4 /*yield*/, enduser_access_tags_tests()];
13108
- case 24:
13245
+ case 27:
13109
13246
  _l.sent();
13110
13247
  return [4 /*yield*/, enduserAccessTests()];
13111
- case 25:
13248
+ case 28:
13112
13249
  _l.sent();
13113
13250
  return [4 /*yield*/, test_form_response_search()];
13114
- case 26:
13251
+ case 29:
13115
13252
  _l.sent();
13116
13253
  return [4 /*yield*/, date_parsing_tests()];
13117
- case 27:
13254
+ case 30:
13118
13255
  _l.sent();
13119
13256
  return [4 /*yield*/, fromEmailOverride_tests()];
13120
- case 28:
13257
+ case 31:
13121
13258
  _l.sent();
13122
13259
  return [4 /*yield*/, ticket_tests()];
13123
- case 29:
13260
+ case 32:
13124
13261
  _l.sent();
13125
13262
  return [4 /*yield*/, uniqueness_tests()];
13126
- case 30:
13263
+ case 33:
13127
13264
  _l.sent();
13128
13265
  return [4 /*yield*/, (0, exports.enduser_orders_tests)()];
13129
- case 31:
13266
+ case 34:
13130
13267
  _l.sent();
13131
13268
  return [4 /*yield*/, calendar_event_care_team_tests()];
13132
- case 32:
13269
+ case 35:
13133
13270
  _l.sent();
13134
13271
  return [4 /*yield*/, merge_enduser_tests()];
13135
- case 33:
13272
+ case 36:
13136
13273
  _l.sent();
13137
13274
  return [4 /*yield*/, input_modifier_tests()];
13138
- case 34:
13139
- _l.sent();
13140
- return [4 /*yield*/, (0, exports.formsort_tests)()];
13141
- case 35:
13275
+ case 37:
13142
13276
  _l.sent();
13143
13277
  return [4 /*yield*/, (0, exports.switch_to_related_contacts_tests)()];
13144
- case 36:
13278
+ case 38:
13145
13279
  _l.sent();
13146
13280
  return [4 /*yield*/, redaction_tests()];
13147
- case 37:
13281
+ case 39:
13148
13282
  _l.sent();
13149
13283
  return [4 /*yield*/, (0, exports.self_serve_appointment_booking_tests)()];
13150
- case 38:
13284
+ case 40:
13151
13285
  _l.sent();
13152
13286
  return [4 /*yield*/, (0, exports.no_chained_triggers_tests)()];
13153
- case 39:
13287
+ case 41:
13154
13288
  _l.sent();
13155
13289
  return [4 /*yield*/, rate_limit_tests()];
13156
- case 40:
13290
+ case 42:
13157
13291
  _l.sent();
13158
13292
  return [4 /*yield*/, mdb_filter_tests()];
13159
- case 41:
13293
+ case 43:
13160
13294
  _l.sent();
13161
13295
  return [4 /*yield*/, test_ticket_automation_assignment_and_optimization()];
13162
- case 42:
13296
+ case 44:
13163
13297
  _l.sent();
13164
13298
  return [4 /*yield*/, superadmin_tests()];
13165
- case 43:
13299
+ case 45:
13166
13300
  _l.sent();
13167
13301
  return [4 /*yield*/, (0, exports.ticket_queue_tests)()];
13168
- case 44:
13302
+ case 46:
13169
13303
  _l.sent();
13170
13304
  return [4 /*yield*/, vital_trigger_tests()];
13171
- case 45:
13305
+ case 47:
13172
13306
  _l.sent();
13173
13307
  return [4 /*yield*/, close_reasons_no_duplicates_tests()];
13174
- case 46:
13308
+ case 48:
13175
13309
  _l.sent();
13176
13310
  return [4 /*yield*/, register_as_enduser_tests()];
13177
- case 47:
13311
+ case 49:
13178
13312
  _l.sent();
13179
13313
  return [4 /*yield*/, lockout_tests()];
13180
- case 48:
13314
+ case 50:
13181
13315
  _l.sent();
13182
13316
  return [4 /*yield*/, delete_user_tests()
13183
13317
  // await test_send_with_template()
13184
13318
  ];
13185
- case 49:
13319
+ case 51:
13186
13320
  _l.sent();
13187
13321
  // await test_send_with_template()
13188
13322
  return [4 /*yield*/, bulk_read_tests()];
13189
- case 50:
13323
+ case 52:
13190
13324
  // await test_send_with_template()
13191
13325
  _l.sent();
13192
13326
  return [4 /*yield*/, (0, exports.ticket_reminder_tests)()];
13193
- case 51:
13327
+ case 53:
13194
13328
  _l.sent();
13195
13329
  return [4 /*yield*/, marketing_email_unsubscribe_tests()];
13196
- case 52:
13330
+ case 54:
13197
13331
  _l.sent();
13198
13332
  return [4 /*yield*/, unique_strings_tests()];
13199
- case 53:
13333
+ case 55:
13200
13334
  _l.sent();
13201
13335
  return [4 /*yield*/, (0, exports.alternate_phones_tests)()];
13202
- case 54:
13336
+ case 56:
13203
13337
  _l.sent();
13204
13338
  return [4 /*yield*/, field_equals_trigger_tests()];
13205
- case 55:
13339
+ case 57:
13206
13340
  _l.sent();
13207
13341
  return [4 /*yield*/, role_based_access_tests()];
13208
- case 56:
13342
+ case 58:
13209
13343
  _l.sent();
13210
13344
  return [4 /*yield*/, enduser_session_tests()];
13211
- case 57:
13345
+ case 59:
13212
13346
  _l.sent();
13213
13347
  return [4 /*yield*/, nextReminderInMS_tests()];
13214
- case 58:
13348
+ case 60:
13215
13349
  _l.sent();
13216
13350
  return [4 /*yield*/, search_tests()];
13217
- case 59:
13351
+ case 61:
13218
13352
  _l.sent();
13219
13353
  return [4 /*yield*/, wait_for_trigger_tests()];
13220
- case 60:
13354
+ case 62:
13221
13355
  _l.sent();
13222
13356
  return [4 /*yield*/, pdf_generation()];
13223
- case 61:
13357
+ case 63:
13224
13358
  _l.sent();
13225
13359
  return [4 /*yield*/, remove_from_journey_on_incoming_comms_tests().catch(console.error)]; // timing is unreliable, uncomment if changing logic
13226
- case 62:
13360
+ case 64:
13227
13361
  _l.sent(); // timing is unreliable, uncomment if changing logic
13228
13362
  return [4 /*yield*/, auto_reply_tests()];
13229
- case 63:
13363
+ case 65:
13230
13364
  _l.sent();
13231
13365
  return [4 /*yield*/, sub_organization_enduser_tests()];
13232
- case 64:
13366
+ case 66:
13233
13367
  _l.sent();
13234
13368
  return [4 /*yield*/, sub_organization_tests()];
13235
- case 65:
13369
+ case 67:
13236
13370
  _l.sent();
13237
13371
  return [4 /*yield*/, (0, exports.filter_by_date_tests)()];
13238
- case 66:
13372
+ case 68:
13239
13373
  _l.sent();
13240
13374
  return [4 /*yield*/, generate_user_auth_tests()];
13241
- case 67:
13375
+ case 69:
13242
13376
  _l.sent();
13243
13377
  return [4 /*yield*/, generateEnduserAuthTests()];
13244
- case 68:
13378
+ case 70:
13245
13379
  _l.sent();
13246
13380
  return [4 /*yield*/, public_form_tests()];
13247
- case 69:
13381
+ case 71:
13248
13382
  _l.sent();
13249
13383
  return [4 /*yield*/, badInputTests()];
13250
- case 70:
13384
+ case 72:
13251
13385
  _l.sent();
13252
13386
  return [4 /*yield*/, filterTests()];
13253
- case 71:
13387
+ case 73:
13254
13388
  _l.sent();
13255
13389
  return [4 /*yield*/, updatesTests()];
13256
- case 72:
13390
+ case 74:
13257
13391
  _l.sent();
13258
13392
  return [4 /*yield*/, threadKeyTests()];
13259
- case 73:
13393
+ case 75:
13260
13394
  _l.sent();
13261
- return [3 /*break*/, 75];
13262
- case 74:
13395
+ return [3 /*break*/, 77];
13396
+ case 76:
13263
13397
  err_1 = _l.sent();
13264
13398
  console.error("Failed during custom test");
13265
13399
  if (err_1.message && err_1.info) {
@@ -13269,18 +13403,18 @@ var inbox_loading_tests = function () { return __awaiter(void 0, void 0, void 0,
13269
13403
  console.error(err_1);
13270
13404
  }
13271
13405
  process.exit(1);
13272
- return [3 /*break*/, 75];
13273
- case 75:
13406
+ return [3 /*break*/, 77];
13407
+ case 77:
13274
13408
  _a = schema_1.schema;
13275
13409
  _b = [];
13276
13410
  for (_c in _a)
13277
13411
  _b.push(_c);
13278
13412
  _i = 0;
13279
- _l.label = 76;
13280
- case 76:
13281
- if (!(_i < _b.length)) return [3 /*break*/, 79];
13413
+ _l.label = 78;
13414
+ case 78:
13415
+ if (!(_i < _b.length)) return [3 /*break*/, 81];
13282
13416
  _c = _b[_i];
13283
- if (!(_c in _a)) return [3 /*break*/, 78];
13417
+ if (!(_c in _a)) return [3 /*break*/, 80];
13284
13418
  n = _c;
13285
13419
  returnValidation = (_k = (_j = schema_1.schema[n].customActions) === null || _j === void 0 ? void 0 : _j.create) === null || _k === void 0 ? void 0 : _k.returns;
13286
13420
  return [4 /*yield*/, run_generated_tests({
@@ -13291,41 +13425,41 @@ var inbox_loading_tests = function () { return __awaiter(void 0, void 0, void 0,
13291
13425
  create: returnValidation // ModelFields<ClientModel>,
13292
13426
  }
13293
13427
  })];
13294
- case 77:
13428
+ case 79:
13295
13429
  _l.sent();
13296
- _l.label = 78;
13297
- case 78:
13430
+ _l.label = 80;
13431
+ case 80:
13298
13432
  _i++;
13299
- return [3 /*break*/, 76];
13300
- case 79:
13433
+ return [3 /*break*/, 78];
13434
+ case 81:
13301
13435
  _d = tests;
13302
13436
  _f = [];
13303
13437
  for (_g in _d)
13304
13438
  _f.push(_g);
13305
13439
  _h = 0;
13306
- _l.label = 80;
13307
- case 80:
13308
- if (!(_h < _f.length)) return [3 /*break*/, 85];
13440
+ _l.label = 82;
13441
+ case 82:
13442
+ if (!(_h < _f.length)) return [3 /*break*/, 87];
13309
13443
  _g = _f[_h];
13310
- if (!(_g in _d)) return [3 /*break*/, 84];
13444
+ if (!(_g in _d)) return [3 /*break*/, 86];
13311
13445
  t = _g;
13312
- _l.label = 81;
13313
- case 81:
13314
- _l.trys.push([81, 83, , 84]);
13446
+ _l.label = 83;
13447
+ case 83:
13448
+ _l.trys.push([83, 85, , 86]);
13315
13449
  return [4 /*yield*/, tests[t]()];
13316
- case 82:
13450
+ case 84:
13317
13451
  _l.sent();
13318
- return [3 /*break*/, 84];
13319
- case 83:
13452
+ return [3 /*break*/, 86];
13453
+ case 85:
13320
13454
  err_2 = _l.sent();
13321
13455
  console.error("Error running test:");
13322
13456
  console.error(err_2);
13323
13457
  process.exit(1);
13324
- return [3 /*break*/, 84];
13325
- case 84:
13458
+ return [3 /*break*/, 86];
13459
+ case 86:
13326
13460
  _h++;
13327
- return [3 /*break*/, 80];
13328
- case 85:
13461
+ return [3 /*break*/, 82];
13462
+ case 87:
13329
13463
  process.exit();
13330
13464
  return [2 /*return*/];
13331
13465
  }