@oneuptime/common 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.dockerignore +56 -0
- package/AnalyticsModels/BaseModel.ts +456 -0
- package/AnalyticsModels/CommonModel.ts +250 -0
- package/AnalyticsModels/NestedModel.ts +8 -0
- package/Models/AccessControlModel.ts +12 -0
- package/Models/BaseModel.ts +736 -0
- package/Models/FileModel.ts +111 -0
- package/Models/GlobalConfig.ts +8 -0
- package/Models/TenantModel.ts +12 -0
- package/Models/UserModel.ts +12 -0
- package/ServiceRoute.ts +31 -0
- package/Tests/Types/API/ErrorResponse.test.ts +16 -0
- package/Tests/Types/API/HTTPErrorResponse.test.ts +61 -0
- package/Tests/Types/API/HTTPMethod.test.ts +16 -0
- package/Tests/Types/API/Headers.test.ts +14 -0
- package/Tests/Types/API/Hostname.test.ts +21 -0
- package/Tests/Types/API/Protocal.test.ts +19 -0
- package/Tests/Types/API/Response.test.ts +21 -0
- package/Tests/Types/API/ResponseType.test.ts +12 -0
- package/Tests/Types/API/Route.test.ts +29 -0
- package/Tests/Types/API/StatusCode.test.ts +25 -0
- package/Tests/Types/API/URL.test.ts +42 -0
- package/Tests/Types/Alerts/AlertEventType.test.ts +49 -0
- package/Tests/Types/Alerts/AlertType.test.ts +19 -0
- package/Tests/Types/AppEnvironment.test.ts +12 -0
- package/Tests/Types/ApplicationLog/ApplicationLogType.test.ts +13 -0
- package/Tests/Types/ArrayUtil.test.ts +90 -0
- package/Tests/Types/Billing/SubscriptionPlan.test.ts +298 -0
- package/Tests/Types/BrandColors.test.ts +140 -0
- package/Tests/Types/Char.test.ts +83 -0
- package/Tests/Types/Code/CodeType.test.ts +13 -0
- package/Tests/Types/Color.test.ts +44 -0
- package/Tests/Types/Company/CompanySize.test.ts +21 -0
- package/Tests/Types/Company/JobRole.test.ts +22 -0
- package/Tests/Types/Countries.test.ts +303 -0
- package/Tests/Types/Database/ColumnLength.test.ts +55 -0
- package/Tests/Types/Database/ColumnType.test.ts +103 -0
- package/Tests/Types/Database/Columns.test.ts +22 -0
- package/Tests/Types/Database/CompareBase.test.ts +40 -0
- package/Tests/Types/Database/Date.test.ts +82 -0
- package/Tests/Types/Database/EqualToOrNull.test.ts +70 -0
- package/Tests/Types/Database/InBetween.test.ts +80 -0
- package/Tests/Types/Database/LimitMax.test.ts +20 -0
- package/Tests/Types/Database/NotEqual.test.ts +18 -0
- package/Tests/Types/Database/Search.test.ts +10 -0
- package/Tests/Types/DatabaseType.test.ts +7 -0
- package/Tests/Types/Date.test.ts +95 -0
- package/Tests/Types/Dictionary.test.ts +25 -0
- package/Tests/Types/Domain.test.ts +39 -0
- package/Tests/Types/Email/Email.test.ts +69 -0
- package/Tests/Types/EmailWithName.test.ts +49 -0
- package/Tests/Types/EncryptionAlgorithm.test.ts +7 -0
- package/Tests/Types/Exception/ApiException.test.ts +16 -0
- package/Tests/Types/Exception/BadDataException.test.ts +15 -0
- package/Tests/Types/Exception/BadOperationException.test.ts +16 -0
- package/Tests/Types/Exception/BadRequestException.test.ts +15 -0
- package/Tests/Types/Exception/DatabaseNotConnectedException.test.ts +13 -0
- package/Tests/Types/Exception/Exception.test.ts +21 -0
- package/Tests/Types/Exception/NotImplementedException.test.ts +13 -0
- package/Tests/Types/File.test.ts +22 -0
- package/Tests/Types/HashedString.test.ts +20 -0
- package/Tests/Types/Html.test.ts +8 -0
- package/Tests/Types/IP/IP.test.ts +83 -0
- package/Tests/Types/IP/IPType.test.ts +11 -0
- package/Tests/Types/IP/IPv4.test.ts +19 -0
- package/Tests/Types/IP/IPv6.test.ts +19 -0
- package/Tests/Types/JSON.test.ts +38 -0
- package/Tests/Types/JSONFunctions.test.ts +52 -0
- package/Tests/Types/ListData.test.ts +40 -0
- package/Tests/Types/Name.test.ts +26 -0
- package/Tests/Types/ObjectID.test.ts +12 -0
- package/Tests/Types/Permission.test.ts +11 -0
- package/Tests/Types/Phone.test.ts +40 -0
- package/Tests/Types/Port.test.ts +39 -0
- package/Tests/Types/PositiveNumber.test.ts +142 -0
- package/Tests/Types/SecuritySeverity.test.ts +16 -0
- package/Tests/Types/SerializableObject.test.ts +44 -0
- package/Tests/Types/Sleep.test.ts +25 -0
- package/Tests/Types/Text.test.ts +10 -0
- package/Tests/Types/Timezone.test.ts +676 -0
- package/Tests/Types/Typeof.test.ts +19 -0
- package/Tests/Types/UserType.test.ts +16 -0
- package/Tests/Types/Version.test.ts +35 -0
- package/Tests/Types/XML.test.ts +36 -0
- package/Tests/Utils/API.test.ts +425 -0
- package/Tests/Utils/Analytics.test.ts +85 -0
- package/Tests/Utils/CronTime.test.ts +34 -0
- package/Tests/Utils/Faker.test.ts +38 -0
- package/Tests/Utils/Slug.test.ts +22 -0
- package/Tests/Utils/UUID.test.ts +12 -0
- package/Types/API/EmptyResponse.ts +3 -0
- package/Types/API/HTTPErrorResponse.ts +28 -0
- package/Types/API/HTTPMethod.ts +9 -0
- package/Types/API/HTTPResponse.ts +128 -0
- package/Types/API/Headers.ts +4 -0
- package/Types/API/Hostname.ts +118 -0
- package/Types/API/Protocol.ts +10 -0
- package/Types/API/ResponseType.ts +7 -0
- package/Types/API/Route.ts +93 -0
- package/Types/API/StatusCode.ts +45 -0
- package/Types/API/URL.ts +273 -0
- package/Types/Alerts/AlertEventType.ts +14 -0
- package/Types/Alerts/AlertType.ts +9 -0
- package/Types/AnalyticsDatabase/AnalyticsTableEngine.ts +5 -0
- package/Types/AnalyticsDatabase/TableColumn.ts +163 -0
- package/Types/AnalyticsDatabase/TableColumnType.ts +15 -0
- package/Types/AppEnvironment.ts +7 -0
- package/Types/ApplicationLog/ApplicationLogType.ts +7 -0
- package/Types/ArrayUtil.ts +54 -0
- package/Types/BaseDatabase/AccessControl.ts +11 -0
- package/Types/BaseDatabase/ColumnBillingAccessControl.ts +7 -0
- package/Types/BaseDatabase/DatabaseCommonInteractionProps.ts +24 -0
- package/Types/BaseDatabase/DatabaseCommonInteractionPropsUtil.ts +73 -0
- package/Types/BaseDatabase/DatabaseType.ts +6 -0
- package/Types/BaseDatabase/EnableWorkflowOn.ts +6 -0
- package/Types/BaseDatabase/EqualToOrNull.ts +37 -0
- package/Types/BaseDatabase/GreaterThan.ts +24 -0
- package/Types/BaseDatabase/GreaterThanOrEqual.ts +24 -0
- package/Types/BaseDatabase/InBetween.ts +77 -0
- package/Types/BaseDatabase/Includes.ts +47 -0
- package/Types/BaseDatabase/IsNull.ts +28 -0
- package/Types/BaseDatabase/LessThan.ts +24 -0
- package/Types/BaseDatabase/LessThanOrEqual.ts +24 -0
- package/Types/BaseDatabase/ModelPermission.ts +37 -0
- package/Types/BaseDatabase/NotEqual.ts +37 -0
- package/Types/BaseDatabase/NotNull.ts +28 -0
- package/Types/BaseDatabase/Search.ts +39 -0
- package/Types/BaseDatabase/SortOrder.ts +6 -0
- package/Types/BaseDatabase/TableBillingAccessControl.ts +8 -0
- package/Types/Billing/MeteredPlan.ts +27 -0
- package/Types/Billing/SubscriptionPlan.ts +241 -0
- package/Types/Billing/SubscriptionStatus.ts +32 -0
- package/Types/BrandColors.ts +35 -0
- package/Types/Calendar/CalendarEvent.ts +12 -0
- package/Types/Call/CallRequest.ts +43 -0
- package/Types/Call/CallStatus.ts +9 -0
- package/Types/CallAndSMS/TwilioConfig.ts +7 -0
- package/Types/Char.ts +65 -0
- package/Types/Code/CodeType.ts +11 -0
- package/Types/Color.ts +108 -0
- package/Types/Company/CompanySize.ts +9 -0
- package/Types/Company/JobRole.ts +10 -0
- package/Types/Countries.ts +247 -0
- package/Types/Currency.ts +34 -0
- package/Types/CustomField/CustomFieldType.ts +7 -0
- package/Types/Database/AccessControl/AllowAccessIfSubscriptionIsUnpaid.ts +7 -0
- package/Types/Database/AccessControl/ColumnAccessControl.ts +49 -0
- package/Types/Database/AccessControl/ColumnBillingAccessControl.ts +51 -0
- package/Types/Database/AccessControl/TableAccessControl.ts +22 -0
- package/Types/Database/AccessControl/TableBillingAccessControl.ts +22 -0
- package/Types/Database/AccessControlColumn.ts +7 -0
- package/Types/Database/AllowUserQueryWithoutTenant.ts +7 -0
- package/Types/Database/CanAccessIfCanReadOn.ts +10 -0
- package/Types/Database/ColumnLength.ts +72 -0
- package/Types/Database/ColumnType.ts +37 -0
- package/Types/Database/Columns.ts +21 -0
- package/Types/Database/CompareBase.ts +38 -0
- package/Types/Database/CrudApiEndpoint.ts +8 -0
- package/Types/Database/CurrentUserCanAccessRecordBy.ts +7 -0
- package/Types/Database/DatabaseProperty.ts +51 -0
- package/Types/Database/Date.ts +28 -0
- package/Types/Database/EnableDocumentation.ts +13 -0
- package/Types/Database/EnableWorkflow.ts +8 -0
- package/Types/Database/IsPermissionsIf.ts +18 -0
- package/Types/Database/LabelsColumn.ts +7 -0
- package/Types/Database/LimitMax.ts +4 -0
- package/Types/Database/MultiTenentQueryAllowed.ts +7 -0
- package/Types/Database/PartialEntity.ts +3 -0
- package/Types/Database/SlugifyColumn.ts +8 -0
- package/Types/Database/TableColumn.ts +66 -0
- package/Types/Database/TableColumnType.ts +43 -0
- package/Types/Database/TableMetadata.ts +18 -0
- package/Types/Database/TenantColumn.ts +7 -0
- package/Types/Database/TotalItemsBy.ts +13 -0
- package/Types/Database/UniqueColumnBy.ts +49 -0
- package/Types/DatabaseType.ts +6 -0
- package/Types/Date.ts +1032 -0
- package/Types/Day/DayOfWeek.ts +32 -0
- package/Types/Decimal.ts +78 -0
- package/Types/Dictionary.ts +3 -0
- package/Types/DiskSize.ts +46 -0
- package/Types/Domain.ts +94 -0
- package/Types/Email/EmailBody.ts +4 -0
- package/Types/Email/EmailMessage.ts +14 -0
- package/Types/Email/EmailServer.ts +15 -0
- package/Types/Email/EmailTemplate.ts +8 -0
- package/Types/Email/EmailTemplateType.ts +39 -0
- package/Types/Email.ts +121 -0
- package/Types/EmailWithName.ts +35 -0
- package/Types/EncryptionAlgorithm.ts +5 -0
- package/Types/Events/EventInterval.ts +9 -0
- package/Types/Events/Recurring.ts +119 -0
- package/Types/Exception/ApiException.ts +8 -0
- package/Types/Exception/BadDataException.ts +8 -0
- package/Types/Exception/BadOperationException.ts +8 -0
- package/Types/Exception/BadRequestException.ts +8 -0
- package/Types/Exception/DatabaseNotConnectedException.ts +11 -0
- package/Types/Exception/Exception.ts +22 -0
- package/Types/Exception/ExceptionCode.ts +21 -0
- package/Types/Exception/NotAuthenticatedException.ts +8 -0
- package/Types/Exception/NotAuthorizedException.ts +8 -0
- package/Types/Exception/NotFoundException.ts +8 -0
- package/Types/Exception/NotImplementedException.ts +11 -0
- package/Types/Exception/PaymentRequiredException.ts +8 -0
- package/Types/Exception/ServerException.ts +8 -0
- package/Types/Exception/SsoAuthorizationException.ts +17 -0
- package/Types/Exception/TenantNotFoundException.ts +8 -0
- package/Types/Exception/TimeoutException.ts +8 -0
- package/Types/Exception/UnableToReachServer.ts +8 -0
- package/Types/Exception/WebsiteRequestException.ts +8 -0
- package/Types/File/MimeType.ts +12 -0
- package/Types/File.ts +4 -0
- package/Types/Filter/Filter.ts +1 -0
- package/Types/Filter/FilterCondition.ts +6 -0
- package/Types/Filter/FilterType.ts +10 -0
- package/Types/FunctionTypes.ts +4 -0
- package/Types/GenericFunction.ts +4 -0
- package/Types/GenericObject.ts +4 -0
- package/Types/HashCode.ts +11 -0
- package/Types/HashedString.ts +105 -0
- package/Types/Html.ts +17 -0
- package/Types/IP/IP.ts +114 -0
- package/Types/IP/IPType.ts +6 -0
- package/Types/IP/IPv4.ts +12 -0
- package/Types/IP/IPv6.ts +12 -0
- package/Types/Icon/IconProp.ts +125 -0
- package/Types/IncomingRequest/IncomingRequestCustomFields.ts +1 -0
- package/Types/Infrastructure/BasicMetrics.ts +26 -0
- package/Types/Infrastructure/OSType.ts +8 -0
- package/Types/JSON.ts +151 -0
- package/Types/JSONFunctions.ts +265 -0
- package/Types/JsonWebTokenData.ts +13 -0
- package/Types/Link.ts +8 -0
- package/Types/ListData.ts +32 -0
- package/Types/Mail/MailStatus.ts +6 -0
- package/Types/Mixins.ts +5 -0
- package/Types/Monitor/CriteriaFilter.ts +52 -0
- package/Types/Monitor/CriteriaIncident.ts +10 -0
- package/Types/Monitor/IncomingMonitor/IncomingMonitorRequest.ts +11 -0
- package/Types/Monitor/MonitorCriteria.ts +188 -0
- package/Types/Monitor/MonitorCriteriaInstance.ts +520 -0
- package/Types/Monitor/MonitorStep.ts +306 -0
- package/Types/Monitor/MonitorSteps.ts +192 -0
- package/Types/Monitor/MonitorType.ts +114 -0
- package/Types/Monitor/ServerMonitor/ServerMonitorResponse.ts +9 -0
- package/Types/Monitor/schema.json +39 -0
- package/Types/Name.ts +86 -0
- package/Types/NotificationRule/NotificationRuleType.ts +7 -0
- package/Types/NotificationSetting/NotificationSettingEventType.ts +25 -0
- package/Types/ObjectID.ts +94 -0
- package/Types/ObjectUtil.ts +0 -0
- package/Types/OnCallDutyPolicy/Layer.ts +1018 -0
- package/Types/OnCallDutyPolicy/OnCalDutyExecutionLogTimelineStatus.ts +10 -0
- package/Types/OnCallDutyPolicy/OnCallDutyPolicyAlertStatus.ts +7 -0
- package/Types/OnCallDutyPolicy/OnCallDutyPolicyStatus.ts +9 -0
- package/Types/OnCallDutyPolicy/RestrictionTimes.ts +193 -0
- package/Types/Operation/OperationResult.ts +6 -0
- package/Types/Operation/OperationStatus.ts +9 -0
- package/Types/Permission.ts +3293 -0
- package/Types/Phone.ts +75 -0
- package/Types/Port.ts +92 -0
- package/Types/PositiveNumber.ts +79 -0
- package/Types/PricingPlan.ts +7 -0
- package/Types/Probe/ProbeApiIngestResponse.ts +9 -0
- package/Types/Probe/ProbeMonitorResponse.ts +15 -0
- package/Types/Reflection.ts +7 -0
- package/Types/SMS/SMS.ts +9 -0
- package/Types/SMS/SmsTemplateType.ts +13 -0
- package/Types/SSO/DigestMethod.ts +8 -0
- package/Types/SSO/SignatureMethod.ts +8 -0
- package/Types/ScheduledEvent/ScheduledEventState.ts +8 -0
- package/Types/SecuritySeverity.ts +8 -0
- package/Types/SerializableObject.ts +18 -0
- package/Types/SerializableObjectDictionary.ts +63 -0
- package/Types/Sleep.ts +9 -0
- package/Types/SmsStatus.ts +7 -0
- package/Types/StatusPage/StatusPageChartType.ts +10 -0
- package/Types/Text.ts +152 -0
- package/Types/Time/StartAndEndTime.ts +4 -0
- package/Types/Timezone.ts +595 -0
- package/Types/Typeof.ts +8 -0
- package/Types/UserNotification/UserNotificationEventType.ts +5 -0
- package/Types/UserNotification/UserNotificationExecutionStatus.ts +9 -0
- package/Types/UserNotification/UserNotificationStatus.ts +9 -0
- package/Types/UserType.ts +8 -0
- package/Types/Version.ts +66 -0
- package/Types/WebsiteRequest.ts +66 -0
- package/Types/Workflow/Component.ts +99 -0
- package/Types/Workflow/ComponentID.ts +20 -0
- package/Types/Workflow/Components/API.ts +363 -0
- package/Types/Workflow/Components/BaseModel.ts +590 -0
- package/Types/Workflow/Components/Condition.ts +66 -0
- package/Types/Workflow/Components/Email.ts +109 -0
- package/Types/Workflow/Components/JSON.ts +162 -0
- package/Types/Workflow/Components/JavaScript.ts +67 -0
- package/Types/Workflow/Components/Log.ts +45 -0
- package/Types/Workflow/Components/Manual.ts +40 -0
- package/Types/Workflow/Components/MicrosoftTeams.ts +69 -0
- package/Types/Workflow/Components/Schedule.ts +38 -0
- package/Types/Workflow/Components/Slack.ts +70 -0
- package/Types/Workflow/Components/Webhook.ts +58 -0
- package/Types/Workflow/Components/Workflow.ts +44 -0
- package/Types/Workflow/Components.ts +78 -0
- package/Types/Workflow/WorkflowPlan.ts +8 -0
- package/Types/Workflow/WorkflowStatus.ts +10 -0
- package/Types/XML.ts +21 -0
- package/Typings/Index.d.ts +3 -0
- package/Utils/API.ts +348 -0
- package/Utils/Analytics.ts +42 -0
- package/Utils/CronTime.ts +6 -0
- package/Utils/Faker.ts +34 -0
- package/Utils/Realtime.ts +39 -0
- package/Utils/Slug.ts +21 -0
- package/Utils/UUID.ts +7 -0
- package/build/dist/AnalyticsModels/BaseModel.js +310 -0
- package/build/dist/AnalyticsModels/BaseModel.js.map +1 -0
- package/build/dist/AnalyticsModels/CommonModel.js +135 -0
- package/build/dist/AnalyticsModels/CommonModel.js.map +1 -0
- package/build/dist/AnalyticsModels/NestedModel.js +7 -0
- package/build/dist/AnalyticsModels/NestedModel.js.map +1 -0
- package/build/dist/Models/AccessControlModel.js +10 -0
- package/build/dist/Models/AccessControlModel.js.map +1 -0
- package/build/dist/Models/BaseModel.js +454 -0
- package/build/dist/Models/BaseModel.js.map +1 -0
- package/build/dist/Models/FileModel.js +133 -0
- package/build/dist/Models/FileModel.js.map +1 -0
- package/build/dist/Models/GlobalConfig.js +7 -0
- package/build/dist/Models/GlobalConfig.js.map +1 -0
- package/build/dist/Models/TenantModel.js +10 -0
- package/build/dist/Models/TenantModel.js.map +1 -0
- package/build/dist/Models/UserModel.js +10 -0
- package/build/dist/Models/UserModel.js.map +1 -0
- package/build/dist/ServiceRoute.js +17 -0
- package/build/dist/ServiceRoute.js.map +1 -0
- package/build/dist/Tests/Types/API/ErrorResponse.test.js +13 -0
- package/build/dist/Tests/Types/API/ErrorResponse.test.js.map +1 -0
- package/build/dist/Tests/Types/API/HTTPErrorResponse.test.js +32 -0
- package/build/dist/Tests/Types/API/HTTPErrorResponse.test.js.map +1 -0
- package/build/dist/Tests/Types/API/HTTPMethod.test.js +16 -0
- package/build/dist/Tests/Types/API/HTTPMethod.test.js.map +1 -0
- package/build/dist/Tests/Types/API/Headers.test.js +14 -0
- package/build/dist/Tests/Types/API/Headers.test.js.map +1 -0
- package/build/dist/Tests/Types/API/Hostname.test.js +22 -0
- package/build/dist/Tests/Types/API/Hostname.test.js.map +1 -0
- package/build/dist/Tests/Types/API/Protocal.test.js +19 -0
- package/build/dist/Tests/Types/API/Protocal.test.js.map +1 -0
- package/build/dist/Tests/Types/API/Response.test.js +14 -0
- package/build/dist/Tests/Types/API/Response.test.js.map +1 -0
- package/build/dist/Tests/Types/API/ResponseType.test.js +13 -0
- package/build/dist/Tests/Types/API/ResponseType.test.js.map +1 -0
- package/build/dist/Tests/Types/API/Route.test.js +30 -0
- package/build/dist/Tests/Types/API/Route.test.js.map +1 -0
- package/build/dist/Tests/Types/API/StatusCode.test.js +26 -0
- package/build/dist/Tests/Types/API/StatusCode.test.js.map +1 -0
- package/build/dist/Tests/Types/API/URL.test.js +33 -0
- package/build/dist/Tests/Types/API/URL.test.js.map +1 -0
- package/build/dist/Tests/Types/Alerts/AlertEventType.test.js +34 -0
- package/build/dist/Tests/Types/Alerts/AlertEventType.test.js.map +1 -0
- package/build/dist/Tests/Types/Alerts/AlertType.test.js +19 -0
- package/build/dist/Tests/Types/Alerts/AlertType.test.js.map +1 -0
- package/build/dist/Tests/Types/AppEnvironment.test.js +13 -0
- package/build/dist/Tests/Types/AppEnvironment.test.js.map +1 -0
- package/build/dist/Tests/Types/ApplicationLog/ApplicationLogType.test.js +13 -0
- package/build/dist/Tests/Types/ApplicationLog/ApplicationLogType.test.js.map +1 -0
- package/build/dist/Tests/Types/ArrayUtil.test.js +71 -0
- package/build/dist/Tests/Types/ArrayUtil.test.js.map +1 -0
- package/build/dist/Tests/Types/Billing/SubscriptionPlan.test.js +178 -0
- package/build/dist/Tests/Types/Billing/SubscriptionPlan.test.js.map +1 -0
- package/build/dist/Tests/Types/BrandColors.test.js +123 -0
- package/build/dist/Tests/Types/BrandColors.test.js.map +1 -0
- package/build/dist/Tests/Types/Char.test.js +82 -0
- package/build/dist/Tests/Types/Char.test.js.map +1 -0
- package/build/dist/Tests/Types/Code/CodeType.test.js +13 -0
- package/build/dist/Tests/Types/Code/CodeType.test.js.map +1 -0
- package/build/dist/Tests/Types/Color.test.js +44 -0
- package/build/dist/Tests/Types/Color.test.js.map +1 -0
- package/build/dist/Tests/Types/Company/CompanySize.test.js +20 -0
- package/build/dist/Tests/Types/Company/CompanySize.test.js.map +1 -0
- package/build/dist/Tests/Types/Company/JobRole.test.js +22 -0
- package/build/dist/Tests/Types/Company/JobRole.test.js.map +1 -0
- package/build/dist/Tests/Types/Countries.test.js +249 -0
- package/build/dist/Tests/Types/Countries.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/ColumnLength.test.js +43 -0
- package/build/dist/Tests/Types/Database/ColumnLength.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/ColumnType.test.js +79 -0
- package/build/dist/Tests/Types/Database/ColumnType.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/Columns.test.js +20 -0
- package/build/dist/Tests/Types/Database/Columns.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/CompareBase.test.js +36 -0
- package/build/dist/Tests/Types/Database/CompareBase.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/Date.test.js +61 -0
- package/build/dist/Tests/Types/Database/Date.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/EqualToOrNull.test.js +61 -0
- package/build/dist/Tests/Types/Database/EqualToOrNull.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/InBetween.test.js +71 -0
- package/build/dist/Tests/Types/Database/InBetween.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/LimitMax.test.js +18 -0
- package/build/dist/Tests/Types/Database/LimitMax.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/NotEqual.test.js +18 -0
- package/build/dist/Tests/Types/Database/NotEqual.test.js.map +1 -0
- package/build/dist/Tests/Types/Database/Search.test.js +10 -0
- package/build/dist/Tests/Types/Database/Search.test.js.map +1 -0
- package/build/dist/Tests/Types/DatabaseType.test.js +7 -0
- package/build/dist/Tests/Types/DatabaseType.test.js.map +1 -0
- package/build/dist/Tests/Types/Date.test.js +55 -0
- package/build/dist/Tests/Types/Date.test.js.map +1 -0
- package/build/dist/Tests/Types/Dictionary.test.js +25 -0
- package/build/dist/Tests/Types/Dictionary.test.js.map +1 -0
- package/build/dist/Tests/Types/Domain.test.js +38 -0
- package/build/dist/Tests/Types/Domain.test.js.map +1 -0
- package/build/dist/Tests/Types/Email/Email.test.js +51 -0
- package/build/dist/Tests/Types/Email/Email.test.js.map +1 -0
- package/build/dist/Tests/Types/EmailWithName.test.js +36 -0
- package/build/dist/Tests/Types/EmailWithName.test.js.map +1 -0
- package/build/dist/Tests/Types/EncryptionAlgorithm.test.js +7 -0
- package/build/dist/Tests/Types/EncryptionAlgorithm.test.js.map +1 -0
- package/build/dist/Tests/Types/Exception/ApiException.test.js +11 -0
- package/build/dist/Tests/Types/Exception/ApiException.test.js.map +1 -0
- package/build/dist/Tests/Types/Exception/BadDataException.test.js +12 -0
- package/build/dist/Tests/Types/Exception/BadDataException.test.js.map +1 -0
- package/build/dist/Tests/Types/Exception/BadOperationException.test.js +11 -0
- package/build/dist/Tests/Types/Exception/BadOperationException.test.js.map +1 -0
- package/build/dist/Tests/Types/Exception/BadRequestException.test.js +12 -0
- package/build/dist/Tests/Types/Exception/BadRequestException.test.js.map +1 -0
- package/build/dist/Tests/Types/Exception/DatabaseNotConnectedException.test.js +10 -0
- package/build/dist/Tests/Types/Exception/DatabaseNotConnectedException.test.js.map +1 -0
- package/build/dist/Tests/Types/Exception/Exception.test.js +15 -0
- package/build/dist/Tests/Types/Exception/Exception.test.js.map +1 -0
- package/build/dist/Tests/Types/Exception/NotImplementedException.test.js +12 -0
- package/build/dist/Tests/Types/Exception/NotImplementedException.test.js.map +1 -0
- package/build/dist/Tests/Types/File.test.js +22 -0
- package/build/dist/Tests/Types/File.test.js.map +1 -0
- package/build/dist/Tests/Types/HashedString.test.js +18 -0
- package/build/dist/Tests/Types/HashedString.test.js.map +1 -0
- package/build/dist/Tests/Types/Html.test.js +8 -0
- package/build/dist/Tests/Types/Html.test.js.map +1 -0
- package/build/dist/Tests/Types/IP/IP.test.js +65 -0
- package/build/dist/Tests/Types/IP/IP.test.js.map +1 -0
- package/build/dist/Tests/Types/IP/IPType.test.js +10 -0
- package/build/dist/Tests/Types/IP/IPType.test.js.map +1 -0
- package/build/dist/Tests/Types/IP/IPv4.test.js +17 -0
- package/build/dist/Tests/Types/IP/IPv4.test.js.map +1 -0
- package/build/dist/Tests/Types/IP/IPv6.test.js +17 -0
- package/build/dist/Tests/Types/IP/IPv6.test.js.map +1 -0
- package/build/dist/Tests/Types/JSON.test.js +34 -0
- package/build/dist/Tests/Types/JSON.test.js.map +1 -0
- package/build/dist/Tests/Types/JSONFunctions.test.js +38 -0
- package/build/dist/Tests/Types/JSONFunctions.test.js.map +1 -0
- package/build/dist/Tests/Types/ListData.test.js +34 -0
- package/build/dist/Tests/Types/ListData.test.js.map +1 -0
- package/build/dist/Tests/Types/Name.test.js +26 -0
- package/build/dist/Tests/Types/Name.test.js.map +1 -0
- package/build/dist/Tests/Types/ObjectID.test.js +12 -0
- package/build/dist/Tests/Types/ObjectID.test.js.map +1 -0
- package/build/dist/Tests/Types/Permission.test.js +10 -0
- package/build/dist/Tests/Types/Permission.test.js.map +1 -0
- package/build/dist/Tests/Types/Phone.test.js +37 -0
- package/build/dist/Tests/Types/Phone.test.js.map +1 -0
- package/build/dist/Tests/Types/Port.test.js +35 -0
- package/build/dist/Tests/Types/Port.test.js.map +1 -0
- package/build/dist/Tests/Types/PositiveNumber.test.js +101 -0
- package/build/dist/Tests/Types/PositiveNumber.test.js.map +1 -0
- package/build/dist/Tests/Types/SecuritySeverity.test.js +16 -0
- package/build/dist/Tests/Types/SecuritySeverity.test.js.map +1 -0
- package/build/dist/Tests/Types/SerializableObject.test.js +35 -0
- package/build/dist/Tests/Types/SerializableObject.test.js.map +1 -0
- package/build/dist/Tests/Types/Sleep.test.js +18 -0
- package/build/dist/Tests/Types/Sleep.test.js.map +1 -0
- package/build/dist/Tests/Types/Text.test.js +8 -0
- package/build/dist/Tests/Types/Text.test.js.map +1 -0
- package/build/dist/Tests/Types/Timezone.test.js +596 -0
- package/build/dist/Tests/Types/Timezone.test.js.map +1 -0
- package/build/dist/Tests/Types/Typeof.test.js +16 -0
- package/build/dist/Tests/Types/Typeof.test.js.map +1 -0
- package/build/dist/Tests/Types/UserType.test.js +16 -0
- package/build/dist/Tests/Types/UserType.test.js.map +1 -0
- package/build/dist/Tests/Types/Version.test.js +35 -0
- package/build/dist/Tests/Types/Version.test.js.map +1 -0
- package/build/dist/Tests/Types/XML.test.js +35 -0
- package/build/dist/Tests/Types/XML.test.js.map +1 -0
- package/build/dist/Tests/Utils/API.test.js +286 -0
- package/build/dist/Tests/Utils/API.test.js.map +1 -0
- package/build/dist/Tests/Utils/Analytics.test.js +66 -0
- package/build/dist/Tests/Utils/Analytics.test.js.map +1 -0
- package/build/dist/Tests/Utils/CronTime.test.js +22 -0
- package/build/dist/Tests/Utils/CronTime.test.js.map +1 -0
- package/build/dist/Tests/Utils/Faker.test.js +26 -0
- package/build/dist/Tests/Utils/Faker.test.js.map +1 -0
- package/build/dist/Tests/Utils/Slug.test.js +20 -0
- package/build/dist/Tests/Utils/Slug.test.js.map +1 -0
- package/build/dist/Tests/Utils/UUID.test.js +10 -0
- package/build/dist/Tests/Utils/UUID.test.js.map +1 -0
- package/build/dist/Types/API/EmptyResponse.js +2 -0
- package/build/dist/Types/API/EmptyResponse.js.map +1 -0
- package/build/dist/Types/API/HTTPErrorResponse.js +21 -0
- package/build/dist/Types/API/HTTPErrorResponse.js.map +1 -0
- package/build/dist/Types/API/HTTPMethod.js +10 -0
- package/build/dist/Types/API/HTTPMethod.js.map +1 -0
- package/build/dist/Types/API/HTTPResponse.js +96 -0
- package/build/dist/Types/API/HTTPResponse.js.map +1 -0
- package/build/dist/Types/API/Headers.js +2 -0
- package/build/dist/Types/API/Headers.js.map +1 -0
- package/build/dist/Types/API/Hostname.js +93 -0
- package/build/dist/Types/API/Hostname.js.map +1 -0
- package/build/dist/Types/API/Protocol.js +11 -0
- package/build/dist/Types/API/Protocol.js.map +1 -0
- package/build/dist/Types/API/ResponseType.js +8 -0
- package/build/dist/Types/API/ResponseType.js.map +1 -0
- package/build/dist/Types/API/Route.js +74 -0
- package/build/dist/Types/API/Route.js.map +1 -0
- package/build/dist/Types/API/StatusCode.js +38 -0
- package/build/dist/Types/API/StatusCode.js.map +1 -0
- package/build/dist/Types/API/URL.js +206 -0
- package/build/dist/Types/API/URL.js.map +1 -0
- package/build/dist/Types/Alerts/AlertEventType.js +15 -0
- package/build/dist/Types/Alerts/AlertEventType.js.map +1 -0
- package/build/dist/Types/Alerts/AlertType.js +10 -0
- package/build/dist/Types/Alerts/AlertType.js.map +1 -0
- package/build/dist/Types/AnalyticsDatabase/AnalyticsTableEngine.js +6 -0
- package/build/dist/Types/AnalyticsDatabase/AnalyticsTableEngine.js.map +1 -0
- package/build/dist/Types/AnalyticsDatabase/TableColumn.js +114 -0
- package/build/dist/Types/AnalyticsDatabase/TableColumn.js.map +1 -0
- package/build/dist/Types/AnalyticsDatabase/TableColumnType.js +16 -0
- package/build/dist/Types/AnalyticsDatabase/TableColumnType.js.map +1 -0
- package/build/dist/Types/AppEnvironment.js +8 -0
- package/build/dist/Types/AppEnvironment.js.map +1 -0
- package/build/dist/Types/ApplicationLog/ApplicationLogType.js +8 -0
- package/build/dist/Types/ApplicationLog/ApplicationLogType.js.map +1 -0
- package/build/dist/Types/ArrayUtil.js +44 -0
- package/build/dist/Types/ArrayUtil.js.map +1 -0
- package/build/dist/Types/BaseDatabase/AccessControl.js +2 -0
- package/build/dist/Types/BaseDatabase/AccessControl.js.map +1 -0
- package/build/dist/Types/BaseDatabase/ColumnBillingAccessControl.js +2 -0
- package/build/dist/Types/BaseDatabase/ColumnBillingAccessControl.js.map +1 -0
- package/build/dist/Types/BaseDatabase/DatabaseCommonInteractionProps.js +2 -0
- package/build/dist/Types/BaseDatabase/DatabaseCommonInteractionProps.js.map +1 -0
- package/build/dist/Types/BaseDatabase/DatabaseCommonInteractionPropsUtil.js +49 -0
- package/build/dist/Types/BaseDatabase/DatabaseCommonInteractionPropsUtil.js.map +1 -0
- package/build/dist/Types/BaseDatabase/DatabaseType.js +7 -0
- package/build/dist/Types/BaseDatabase/DatabaseType.js.map +1 -0
- package/build/dist/Types/BaseDatabase/EnableWorkflowOn.js +2 -0
- package/build/dist/Types/BaseDatabase/EnableWorkflowOn.js.map +1 -0
- package/build/dist/Types/BaseDatabase/EqualToOrNull.js +31 -0
- package/build/dist/Types/BaseDatabase/EqualToOrNull.js.map +1 -0
- package/build/dist/Types/BaseDatabase/GreaterThan.js +21 -0
- package/build/dist/Types/BaseDatabase/GreaterThan.js.map +1 -0
- package/build/dist/Types/BaseDatabase/GreaterThanOrEqual.js +21 -0
- package/build/dist/Types/BaseDatabase/GreaterThanOrEqual.js.map +1 -0
- package/build/dist/Types/BaseDatabase/InBetween.js +57 -0
- package/build/dist/Types/BaseDatabase/InBetween.js.map +1 -0
- package/build/dist/Types/BaseDatabase/Includes.js +34 -0
- package/build/dist/Types/BaseDatabase/Includes.js.map +1 -0
- package/build/dist/Types/BaseDatabase/IsNull.js +24 -0
- package/build/dist/Types/BaseDatabase/IsNull.js.map +1 -0
- package/build/dist/Types/BaseDatabase/LessThan.js +21 -0
- package/build/dist/Types/BaseDatabase/LessThan.js.map +1 -0
- package/build/dist/Types/BaseDatabase/LessThanOrEqual.js +21 -0
- package/build/dist/Types/BaseDatabase/LessThanOrEqual.js.map +1 -0
- package/build/dist/Types/BaseDatabase/ModelPermission.js +19 -0
- package/build/dist/Types/BaseDatabase/ModelPermission.js.map +1 -0
- package/build/dist/Types/BaseDatabase/NotEqual.js +31 -0
- package/build/dist/Types/BaseDatabase/NotEqual.js.map +1 -0
- package/build/dist/Types/BaseDatabase/NotNull.js +24 -0
- package/build/dist/Types/BaseDatabase/NotNull.js.map +1 -0
- package/build/dist/Types/BaseDatabase/Search.js +31 -0
- package/build/dist/Types/BaseDatabase/Search.js.map +1 -0
- package/build/dist/Types/BaseDatabase/SortOrder.js +7 -0
- package/build/dist/Types/BaseDatabase/SortOrder.js.map +1 -0
- package/build/dist/Types/BaseDatabase/TableBillingAccessControl.js +2 -0
- package/build/dist/Types/BaseDatabase/TableBillingAccessControl.js.map +1 -0
- package/build/dist/Types/BaseDatabase/TableColumnType.js +44 -0
- package/build/dist/Types/BaseDatabase/TableColumnType.js.map +1 -0
- package/build/dist/Types/Billing/MeteredPlan.js +17 -0
- package/build/dist/Types/Billing/MeteredPlan.js.map +1 -0
- package/build/dist/Types/Billing/SubscriptionPlan.js +139 -0
- package/build/dist/Types/Billing/SubscriptionPlan.js.map +1 -0
- package/build/dist/Types/Billing/SubscriptionStatus.js +24 -0
- package/build/dist/Types/Billing/SubscriptionStatus.js.map +1 -0
- package/build/dist/Types/BrandColors.js +31 -0
- package/build/dist/Types/BrandColors.js.map +1 -0
- package/build/dist/Types/Calendar/CalendarEvent.js +2 -0
- package/build/dist/Types/Calendar/CalendarEvent.js.map +1 -0
- package/build/dist/Types/Call/CallRequest.js +11 -0
- package/build/dist/Types/Call/CallRequest.js.map +1 -0
- package/build/dist/Types/Call/CallStatus.js +10 -0
- package/build/dist/Types/Call/CallStatus.js.map +1 -0
- package/build/dist/Types/CallAndSMS/TwilioConfig.js +2 -0
- package/build/dist/Types/CallAndSMS/TwilioConfig.js.map +1 -0
- package/build/dist/Types/Char.js +2 -0
- package/build/dist/Types/Char.js.map +1 -0
- package/build/dist/Types/Code/CodeType.js +12 -0
- package/build/dist/Types/Code/CodeType.js.map +1 -0
- package/build/dist/Types/Color.js +78 -0
- package/build/dist/Types/Color.js.map +1 -0
- package/build/dist/Types/Company/CompanySize.js +10 -0
- package/build/dist/Types/Company/CompanySize.js.map +1 -0
- package/build/dist/Types/Company/JobRole.js +11 -0
- package/build/dist/Types/Company/JobRole.js.map +1 -0
- package/build/dist/Types/Countries.js +248 -0
- package/build/dist/Types/Countries.js.map +1 -0
- package/build/dist/Types/Currency.js +21 -0
- package/build/dist/Types/Currency.js.map +1 -0
- package/build/dist/Types/CustomField/CustomFieldType.js +8 -0
- package/build/dist/Types/CustomField/CustomFieldType.js.map +1 -0
- package/build/dist/Types/Database/AccessControl/AccessControl.js +2 -0
- package/build/dist/Types/Database/AccessControl/AccessControl.js.map +1 -0
- package/build/dist/Types/Database/AccessControl/AllowAccessIfSubscriptionIsUnpaid.js +6 -0
- package/build/dist/Types/Database/AccessControl/AllowAccessIfSubscriptionIsUnpaid.js.map +1 -0
- package/build/dist/Types/Database/AccessControl/ColumnAccessControl.js +19 -0
- package/build/dist/Types/Database/AccessControl/ColumnAccessControl.js.map +1 -0
- package/build/dist/Types/Database/AccessControl/ColumnBillingAccessControl.js +19 -0
- package/build/dist/Types/Database/AccessControl/ColumnBillingAccessControl.js.map +1 -0
- package/build/dist/Types/Database/AccessControl/TableAccessControl.js +17 -0
- package/build/dist/Types/Database/AccessControl/TableAccessControl.js.map +1 -0
- package/build/dist/Types/Database/AccessControl/TableBillingAccessControl.js +17 -0
- package/build/dist/Types/Database/AccessControl/TableBillingAccessControl.js.map +1 -0
- package/build/dist/Types/Database/AccessControlColumn.js +6 -0
- package/build/dist/Types/Database/AccessControlColumn.js.map +1 -0
- package/build/dist/Types/Database/AllowUserQueryWithoutTenant.js +6 -0
- package/build/dist/Types/Database/AllowUserQueryWithoutTenant.js.map +1 -0
- package/build/dist/Types/Database/CanAccessIfCanReadOn.js +8 -0
- package/build/dist/Types/Database/CanAccessIfCanReadOn.js.map +1 -0
- package/build/dist/Types/Database/ColumnLength.js +65 -0
- package/build/dist/Types/Database/ColumnLength.js.map +1 -0
- package/build/dist/Types/Database/ColumnType.js +38 -0
- package/build/dist/Types/Database/ColumnType.js.map +1 -0
- package/build/dist/Types/Database/Columns.js +19 -0
- package/build/dist/Types/Database/Columns.js.map +1 -0
- package/build/dist/Types/Database/CompareBase.js +31 -0
- package/build/dist/Types/Database/CompareBase.js.map +1 -0
- package/build/dist/Types/Database/CrudApiEndpoint.js +6 -0
- package/build/dist/Types/Database/CrudApiEndpoint.js.map +1 -0
- package/build/dist/Types/Database/CurrentUserCanAccessRecordBy.js +6 -0
- package/build/dist/Types/Database/CurrentUserCanAccessRecordBy.js.map +1 -0
- package/build/dist/Types/Database/DatabaseCommonInteractionProps.js +2 -0
- package/build/dist/Types/Database/DatabaseCommonInteractionProps.js.map +1 -0
- package/build/dist/Types/Database/DatabaseProperty.js +34 -0
- package/build/dist/Types/Database/DatabaseProperty.js.map +1 -0
- package/build/dist/Types/Database/Date.js +18 -0
- package/build/dist/Types/Database/Date.js.map +1 -0
- package/build/dist/Types/Database/EnableDocumentation.js +8 -0
- package/build/dist/Types/Database/EnableDocumentation.js.map +1 -0
- package/build/dist/Types/Database/EnableWorkflow.js +6 -0
- package/build/dist/Types/Database/EnableWorkflow.js.map +1 -0
- package/build/dist/Types/Database/EqualToOrNull.js +31 -0
- package/build/dist/Types/Database/EqualToOrNull.js.map +1 -0
- package/build/dist/Types/Database/GreaterThan.js +21 -0
- package/build/dist/Types/Database/GreaterThan.js.map +1 -0
- package/build/dist/Types/Database/GreaterThanOrEqual.js +21 -0
- package/build/dist/Types/Database/GreaterThanOrEqual.js.map +1 -0
- package/build/dist/Types/Database/InBetween.js +57 -0
- package/build/dist/Types/Database/InBetween.js.map +1 -0
- package/build/dist/Types/Database/IsNull.js +24 -0
- package/build/dist/Types/Database/IsNull.js.map +1 -0
- package/build/dist/Types/Database/IsPermissionsIf.js +11 -0
- package/build/dist/Types/Database/IsPermissionsIf.js.map +1 -0
- package/build/dist/Types/Database/LabelsColumn.js +6 -0
- package/build/dist/Types/Database/LabelsColumn.js.map +1 -0
- package/build/dist/Types/Database/LessThan.js +21 -0
- package/build/dist/Types/Database/LessThan.js.map +1 -0
- package/build/dist/Types/Database/LessThanOrEqual.js +21 -0
- package/build/dist/Types/Database/LessThanOrEqual.js.map +1 -0
- package/build/dist/Types/Database/LimitMax.js +5 -0
- package/build/dist/Types/Database/LimitMax.js.map +1 -0
- package/build/dist/Types/Database/MultiTenentQueryAllowed.js +6 -0
- package/build/dist/Types/Database/MultiTenentQueryAllowed.js.map +1 -0
- package/build/dist/Types/Database/NotEqual.js +31 -0
- package/build/dist/Types/Database/NotEqual.js.map +1 -0
- package/build/dist/Types/Database/NotNull.js +24 -0
- package/build/dist/Types/Database/NotNull.js.map +1 -0
- package/build/dist/Types/Database/PartialEntity.js +2 -0
- package/build/dist/Types/Database/PartialEntity.js.map +1 -0
- package/build/dist/Types/Database/Search.js +31 -0
- package/build/dist/Types/Database/Search.js.map +1 -0
- package/build/dist/Types/Database/SingularPluralName.js +7 -0
- package/build/dist/Types/Database/SingularPluralName.js.map +1 -0
- package/build/dist/Types/Database/SlugifyColumn.js +7 -0
- package/build/dist/Types/Database/SlugifyColumn.js.map +1 -0
- package/build/dist/Types/Database/SortOrder.js +7 -0
- package/build/dist/Types/Database/SortOrder.js.map +1 -0
- package/build/dist/Types/Database/TableColumn.js +19 -0
- package/build/dist/Types/Database/TableColumn.js.map +1 -0
- package/build/dist/Types/Database/TableColumnType.js +44 -0
- package/build/dist/Types/Database/TableColumnType.js.map +1 -0
- package/build/dist/Types/Database/TableMetadata.js +10 -0
- package/build/dist/Types/Database/TableMetadata.js.map +1 -0
- package/build/dist/Types/Database/TenantColumn.js +6 -0
- package/build/dist/Types/Database/TenantColumn.js.map +1 -0
- package/build/dist/Types/Database/TotalItemsBy.js +8 -0
- package/build/dist/Types/Database/TotalItemsBy.js.map +1 -0
- package/build/dist/Types/Database/UniqueColumnBy.js +19 -0
- package/build/dist/Types/Database/UniqueColumnBy.js.map +1 -0
- package/build/dist/Types/DatabaseType.js +7 -0
- package/build/dist/Types/DatabaseType.js.map +1 -0
- package/build/dist/Types/Date.js +698 -0
- package/build/dist/Types/Date.js.map +1 -0
- package/build/dist/Types/Day/DayOfWeek.js +32 -0
- package/build/dist/Types/Day/DayOfWeek.js.map +1 -0
- package/build/dist/Types/Decimal.js +59 -0
- package/build/dist/Types/Decimal.js.map +1 -0
- package/build/dist/Types/Dictionary.js +2 -0
- package/build/dist/Types/Dictionary.js.map +1 -0
- package/build/dist/Types/DiskSize.js +30 -0
- package/build/dist/Types/DiskSize.js.map +1 -0
- package/build/dist/Types/Domain.js +71 -0
- package/build/dist/Types/Domain.js.map +1 -0
- package/build/dist/Types/Email/EmailBody.js +2 -0
- package/build/dist/Types/Email/EmailBody.js.map +1 -0
- package/build/dist/Types/Email/EmailMessage.js +2 -0
- package/build/dist/Types/Email/EmailMessage.js.map +1 -0
- package/build/dist/Types/Email/EmailServer.js +2 -0
- package/build/dist/Types/Email/EmailServer.js.map +1 -0
- package/build/dist/Types/Email/EmailTemplate.js +2 -0
- package/build/dist/Types/Email/EmailTemplate.js.map +1 -0
- package/build/dist/Types/Email/EmailTemplateType.js +40 -0
- package/build/dist/Types/Email/EmailTemplateType.js.map +1 -0
- package/build/dist/Types/Email.js +101 -0
- package/build/dist/Types/Email.js.map +1 -0
- package/build/dist/Types/EmailWithName.js +31 -0
- package/build/dist/Types/EmailWithName.js.map +1 -0
- package/build/dist/Types/EncryptionAlgorithm.js +6 -0
- package/build/dist/Types/EncryptionAlgorithm.js.map +1 -0
- package/build/dist/Types/Events/EventInterval.js +10 -0
- package/build/dist/Types/Events/EventInterval.js.map +1 -0
- package/build/dist/Types/Events/Recurring.js +86 -0
- package/build/dist/Types/Events/Recurring.js.map +1 -0
- package/build/dist/Types/Exception/ApiException.js +8 -0
- package/build/dist/Types/Exception/ApiException.js.map +1 -0
- package/build/dist/Types/Exception/BadDataException.js +8 -0
- package/build/dist/Types/Exception/BadDataException.js.map +1 -0
- package/build/dist/Types/Exception/BadOperationException.js +8 -0
- package/build/dist/Types/Exception/BadOperationException.js.map +1 -0
- package/build/dist/Types/Exception/BadRequestException.js +8 -0
- package/build/dist/Types/Exception/BadRequestException.js.map +1 -0
- package/build/dist/Types/Exception/DatabaseNotConnectedException.js +8 -0
- package/build/dist/Types/Exception/DatabaseNotConnectedException.js.map +1 -0
- package/build/dist/Types/Exception/Exception.js +18 -0
- package/build/dist/Types/Exception/Exception.js.map +1 -0
- package/build/dist/Types/Exception/ExceptionCode.js +22 -0
- package/build/dist/Types/Exception/ExceptionCode.js.map +1 -0
- package/build/dist/Types/Exception/NotAuthenticatedException.js +8 -0
- package/build/dist/Types/Exception/NotAuthenticatedException.js.map +1 -0
- package/build/dist/Types/Exception/NotAuthorizedException.js +8 -0
- package/build/dist/Types/Exception/NotAuthorizedException.js.map +1 -0
- package/build/dist/Types/Exception/NotFoundException.js +8 -0
- package/build/dist/Types/Exception/NotFoundException.js.map +1 -0
- package/build/dist/Types/Exception/NotImplementedException.js +8 -0
- package/build/dist/Types/Exception/NotImplementedException.js.map +1 -0
- package/build/dist/Types/Exception/PaymentRequiredException.js +8 -0
- package/build/dist/Types/Exception/PaymentRequiredException.js.map +1 -0
- package/build/dist/Types/Exception/ServerException.js +8 -0
- package/build/dist/Types/Exception/ServerException.js.map +1 -0
- package/build/dist/Types/Exception/SsoAuthorizationException.js +12 -0
- package/build/dist/Types/Exception/SsoAuthorizationException.js.map +1 -0
- package/build/dist/Types/Exception/TenantNotFoundException.js +8 -0
- package/build/dist/Types/Exception/TenantNotFoundException.js.map +1 -0
- package/build/dist/Types/Exception/TimeoutException.js +8 -0
- package/build/dist/Types/Exception/TimeoutException.js.map +1 -0
- package/build/dist/Types/Exception/UnableToReachServer.js +8 -0
- package/build/dist/Types/Exception/UnableToReachServer.js.map +1 -0
- package/build/dist/Types/Exception/WebsiteRequestException.js +8 -0
- package/build/dist/Types/Exception/WebsiteRequestException.js.map +1 -0
- package/build/dist/Types/File/MimeType.js +11 -0
- package/build/dist/Types/File/MimeType.js.map +1 -0
- package/build/dist/Types/File.js +2 -0
- package/build/dist/Types/File.js.map +1 -0
- package/build/dist/Types/Filter/Filter.js +3 -0
- package/build/dist/Types/Filter/Filter.js.map +1 -0
- package/build/dist/Types/Filter/FilterCondition.js +7 -0
- package/build/dist/Types/Filter/FilterCondition.js.map +1 -0
- package/build/dist/Types/Filter/FilterType.js +11 -0
- package/build/dist/Types/Filter/FilterType.js.map +1 -0
- package/build/dist/Types/FunctionTypes.js +2 -0
- package/build/dist/Types/FunctionTypes.js.map +1 -0
- package/build/dist/Types/GenericFunction.js +2 -0
- package/build/dist/Types/GenericFunction.js.map +1 -0
- package/build/dist/Types/GenericObject.js +2 -0
- package/build/dist/Types/GenericObject.js.map +1 -0
- package/build/dist/Types/HashCode.js +12 -0
- package/build/dist/Types/HashCode.js.map +1 -0
- package/build/dist/Types/HashedString.js +77 -0
- package/build/dist/Types/HashedString.js.map +1 -0
- package/build/dist/Types/Html.js +16 -0
- package/build/dist/Types/Html.js.map +1 -0
- package/build/dist/Types/IP/IP.js +93 -0
- package/build/dist/Types/IP/IP.js.map +1 -0
- package/build/dist/Types/IP/IPType.js +7 -0
- package/build/dist/Types/IP/IPType.js.map +1 -0
- package/build/dist/Types/IP/IPv4.js +11 -0
- package/build/dist/Types/IP/IPv4.js.map +1 -0
- package/build/dist/Types/IP/IPv6.js +11 -0
- package/build/dist/Types/IP/IPv6.js.map +1 -0
- package/build/dist/Types/Icon/IconProp.js +126 -0
- package/build/dist/Types/Icon/IconProp.js.map +1 -0
- package/build/dist/Types/Incident/IncidentCustomFields.js +3 -0
- package/build/dist/Types/Incident/IncidentCustomFields.js.map +1 -0
- package/build/dist/Types/IncomingRequest/IncomingRequestCustomFields.js +3 -0
- package/build/dist/Types/IncomingRequest/IncomingRequestCustomFields.js.map +1 -0
- package/build/dist/Types/JSON.js +39 -0
- package/build/dist/Types/JSON.js.map +1 -0
- package/build/dist/Types/JSONFunctions.js +189 -0
- package/build/dist/Types/JSONFunctions.js.map +1 -0
- package/build/dist/Types/JsonWebTokenData.js +2 -0
- package/build/dist/Types/JsonWebTokenData.js.map +1 -0
- package/build/dist/Types/Link.js +2 -0
- package/build/dist/Types/Link.js.map +1 -0
- package/build/dist/Types/ListData.js +18 -0
- package/build/dist/Types/ListData.js.map +1 -0
- package/build/dist/Types/Mail/MailStatus.js +7 -0
- package/build/dist/Types/Mail/MailStatus.js.map +1 -0
- package/build/dist/Types/Mixins.js +3 -0
- package/build/dist/Types/Mixins.js.map +1 -0
- package/build/dist/Types/Monitor/CriteriaFilter.js +40 -0
- package/build/dist/Types/Monitor/CriteriaFilter.js.map +1 -0
- package/build/dist/Types/Monitor/CriteriaIncident.js +2 -0
- package/build/dist/Types/Monitor/CriteriaIncident.js.map +1 -0
- package/build/dist/Types/Monitor/IncomingMonitor/IncomingMonitorRequest.js +2 -0
- package/build/dist/Types/Monitor/IncomingMonitor/IncomingMonitorRequest.js.map +1 -0
- package/build/dist/Types/Monitor/MonitorCriteria.js +120 -0
- package/build/dist/Types/Monitor/MonitorCriteria.js.map +1 -0
- package/build/dist/Types/Monitor/MonitorCriteriaInstance.js +375 -0
- package/build/dist/Types/Monitor/MonitorCriteriaInstance.js.map +1 -0
- package/build/dist/Types/Monitor/MonitorCustomFields.js +3 -0
- package/build/dist/Types/Monitor/MonitorCustomFields.js.map +1 -0
- package/build/dist/Types/Monitor/MonitorStep.js +205 -0
- package/build/dist/Types/Monitor/MonitorStep.js.map +1 -0
- package/build/dist/Types/Monitor/MonitorSteps.js +126 -0
- package/build/dist/Types/Monitor/MonitorSteps.js.map +1 -0
- package/build/dist/Types/Monitor/MonitorType.js +80 -0
- package/build/dist/Types/Monitor/MonitorType.js.map +1 -0
- package/build/dist/Types/Name.js +69 -0
- package/build/dist/Types/Name.js.map +1 -0
- package/build/dist/Types/NotificationRule/NotificationRuleType.js +8 -0
- package/build/dist/Types/NotificationRule/NotificationRuleType.js.map +1 -0
- package/build/dist/Types/NotificationSetting/NotificationSettingEventType.js +23 -0
- package/build/dist/Types/NotificationSetting/NotificationSettingEventType.js.map +1 -0
- package/build/dist/Types/ObjectID.js +75 -0
- package/build/dist/Types/ObjectID.js.map +1 -0
- package/build/dist/Types/ObjectUtil.js +2 -0
- package/build/dist/Types/ObjectUtil.js.map +1 -0
- package/build/dist/Types/OnCallDutyPolicy/Layer.js +566 -0
- package/build/dist/Types/OnCallDutyPolicy/Layer.js.map +1 -0
- package/build/dist/Types/OnCallDutyPolicy/OnCalDutyExecutionLogTimelineStatus.js +11 -0
- package/build/dist/Types/OnCallDutyPolicy/OnCalDutyExecutionLogTimelineStatus.js.map +1 -0
- package/build/dist/Types/OnCallDutyPolicy/OnCallDutyPolicyAlertStatus.js +8 -0
- package/build/dist/Types/OnCallDutyPolicy/OnCallDutyPolicyAlertStatus.js.map +1 -0
- package/build/dist/Types/OnCallDutyPolicy/OnCallDutyPolicyStatus.js +10 -0
- package/build/dist/Types/OnCallDutyPolicy/OnCallDutyPolicyStatus.js.map +1 -0
- package/build/dist/Types/OnCallDutyPolicy/RestrictionTimes.js +137 -0
- package/build/dist/Types/OnCallDutyPolicy/RestrictionTimes.js.map +1 -0
- package/build/dist/Types/Operation/OperationResult.js +7 -0
- package/build/dist/Types/Operation/OperationResult.js.map +1 -0
- package/build/dist/Types/Operation/OperationStatus.js +10 -0
- package/build/dist/Types/Operation/OperationStatus.js.map +1 -0
- package/build/dist/Types/Permission.js +2701 -0
- package/build/dist/Types/Permission.js.map +1 -0
- package/build/dist/Types/Phone.js +61 -0
- package/build/dist/Types/Phone.js.map +1 -0
- package/build/dist/Types/Port.js +77 -0
- package/build/dist/Types/Port.js.map +1 -0
- package/build/dist/Types/PositiveNumber.js +59 -0
- package/build/dist/Types/PositiveNumber.js.map +1 -0
- package/build/dist/Types/PricingPlan.js +2 -0
- package/build/dist/Types/PricingPlan.js.map +1 -0
- package/build/dist/Types/Probe/ProbeApiIngestResponse.js +2 -0
- package/build/dist/Types/Probe/ProbeApiIngestResponse.js.map +1 -0
- package/build/dist/Types/Probe/ProbeMonitorResponse.js +2 -0
- package/build/dist/Types/Probe/ProbeMonitorResponse.js.map +1 -0
- package/build/dist/Types/Reflection.js +2 -0
- package/build/dist/Types/Reflection.js.map +1 -0
- package/build/dist/Types/Role.js +26 -0
- package/build/dist/Types/Role.js.map +1 -0
- package/build/dist/Types/SMS/SMS.js +2 -0
- package/build/dist/Types/SMS/SMS.js.map +1 -0
- package/build/dist/Types/SMS/SmsTemplateType.js +14 -0
- package/build/dist/Types/SMS/SmsTemplateType.js.map +1 -0
- package/build/dist/Types/SSO/DigestMethod.js +9 -0
- package/build/dist/Types/SSO/DigestMethod.js.map +1 -0
- package/build/dist/Types/SSO/SignatureMethod.js +9 -0
- package/build/dist/Types/SSO/SignatureMethod.js.map +1 -0
- package/build/dist/Types/ScheduledEvent/ScheduledEventState.js +9 -0
- package/build/dist/Types/ScheduledEvent/ScheduledEventState.js.map +1 -0
- package/build/dist/Types/SecuritySeverity.js +9 -0
- package/build/dist/Types/SecuritySeverity.js.map +1 -0
- package/build/dist/Types/SerializableObject.js +14 -0
- package/build/dist/Types/SerializableObject.js.map +1 -0
- package/build/dist/Types/SerializableObjectDictionary.js +61 -0
- package/build/dist/Types/SerializableObjectDictionary.js.map +1 -0
- package/build/dist/Types/Sleep.js +8 -0
- package/build/dist/Types/Sleep.js.map +1 -0
- package/build/dist/Types/SmsStatus.js +8 -0
- package/build/dist/Types/SmsStatus.js.map +1 -0
- package/build/dist/Types/StatusPage/StatusPageChartType.js +11 -0
- package/build/dist/Types/StatusPage/StatusPageChartType.js.map +1 -0
- package/build/dist/Types/Text.js +109 -0
- package/build/dist/Types/Text.js.map +1 -0
- package/build/dist/Types/Time/StartAndEndTime.js +2 -0
- package/build/dist/Types/Time/StartAndEndTime.js.map +1 -0
- package/build/dist/Types/Timezone.js +597 -0
- package/build/dist/Types/Timezone.js.map +1 -0
- package/build/dist/Types/Typeof.js +9 -0
- package/build/dist/Types/Typeof.js.map +1 -0
- package/build/dist/Types/UserNotification/UserNotificationEventType.js +6 -0
- package/build/dist/Types/UserNotification/UserNotificationEventType.js.map +1 -0
- package/build/dist/Types/UserNotification/UserNotificationExecutionStatus.js +10 -0
- package/build/dist/Types/UserNotification/UserNotificationExecutionStatus.js.map +1 -0
- package/build/dist/Types/UserNotification/UserNotificationStatus.js +10 -0
- package/build/dist/Types/UserNotification/UserNotificationStatus.js.map +1 -0
- package/build/dist/Types/UserType.js +9 -0
- package/build/dist/Types/UserType.js.map +1 -0
- package/build/dist/Types/Version.js +52 -0
- package/build/dist/Types/Version.js.map +1 -0
- package/build/dist/Types/WebsiteRequest.js +41 -0
- package/build/dist/Types/WebsiteRequest.js.map +1 -0
- package/build/dist/Types/Workflow/Component.js +37 -0
- package/build/dist/Types/Workflow/Component.js.map +1 -0
- package/build/dist/Types/Workflow/ComponentID.js +21 -0
- package/build/dist/Types/Workflow/ComponentID.js.map +1 -0
- package/build/dist/Types/Workflow/Components/API.js +343 -0
- package/build/dist/Types/Workflow/Components/API.js.map +1 -0
- package/build/dist/Types/Workflow/Components/BaseModel.js +546 -0
- package/build/dist/Types/Workflow/Components/BaseModel.js.map +1 -0
- package/build/dist/Types/Workflow/Components/Condition.js +61 -0
- package/build/dist/Types/Workflow/Components/Condition.js.map +1 -0
- package/build/dist/Types/Workflow/Components/Email.js +102 -0
- package/build/dist/Types/Workflow/Components/Email.js.map +1 -0
- package/build/dist/Types/Workflow/Components/JSON.js +149 -0
- package/build/dist/Types/Workflow/Components/JSON.js.map +1 -0
- package/build/dist/Types/Workflow/Components/JavaScript.js +61 -0
- package/build/dist/Types/Workflow/Components/JavaScript.js.map +1 -0
- package/build/dist/Types/Workflow/Components/Log.js +39 -0
- package/build/dist/Types/Workflow/Components/Log.js.map +1 -0
- package/build/dist/Types/Workflow/Components/Manual.js +34 -0
- package/build/dist/Types/Workflow/Components/Manual.js.map +1 -0
- package/build/dist/Types/Workflow/Components/MicrosoftTeams.js +61 -0
- package/build/dist/Types/Workflow/Components/MicrosoftTeams.js.map +1 -0
- package/build/dist/Types/Workflow/Components/Schedule.js +33 -0
- package/build/dist/Types/Workflow/Components/Schedule.js.map +1 -0
- package/build/dist/Types/Workflow/Components/Slack.js +61 -0
- package/build/dist/Types/Workflow/Components/Slack.js.map +1 -0
- package/build/dist/Types/Workflow/Components/Webhook.js +52 -0
- package/build/dist/Types/Workflow/Components/Webhook.js.map +1 -0
- package/build/dist/Types/Workflow/Components/Workflow.js +38 -0
- package/build/dist/Types/Workflow/Components/Workflow.js.map +1 -0
- package/build/dist/Types/Workflow/Components.js +74 -0
- package/build/dist/Types/Workflow/Components.js.map +1 -0
- package/build/dist/Types/Workflow/WorkflowPlan.js +9 -0
- package/build/dist/Types/Workflow/WorkflowPlan.js.map +1 -0
- package/build/dist/Types/Workflow/WorkflowStatus.js +11 -0
- package/build/dist/Types/Workflow/WorkflowStatus.js.map +1 -0
- package/build/dist/Types/XML.js +20 -0
- package/build/dist/Types/XML.js.map +1 -0
- package/build/dist/Utils/API.js +135 -0
- package/build/dist/Utils/API.js.map +1 -0
- package/build/dist/Utils/Analytics.js +35 -0
- package/build/dist/Utils/Analytics.js.map +1 -0
- package/build/dist/Utils/CronTime.js +7 -0
- package/build/dist/Utils/CronTime.js.map +1 -0
- package/build/dist/Utils/Faker.js +29 -0
- package/build/dist/Utils/Faker.js.map +1 -0
- package/build/dist/Utils/ObjectUtil.js +2 -0
- package/build/dist/Utils/ObjectUtil.js.map +1 -0
- package/build/dist/Utils/Realtime.js +16 -0
- package/build/dist/Utils/Realtime.js.map +1 -0
- package/build/dist/Utils/Slug.js +18 -0
- package/build/dist/Utils/Slug.js.map +1 -0
- package/build/dist/Utils/UUID.js +7 -0
- package/build/dist/Utils/UUID.js.map +1 -0
- package/jest.config.json +39 -0
- package/package.json +36 -0
- package/tsconfig.json +113 -0
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import Typeof from '../../Types/Typeof';
|
|
2
|
+
|
|
3
|
+
describe('Typeof', () => {
|
|
4
|
+
test('String should be string', () => {
|
|
5
|
+
expect(Typeof.String).toBe('string');
|
|
6
|
+
});
|
|
7
|
+
|
|
8
|
+
test('Boolean should be boolean', () => {
|
|
9
|
+
expect(Typeof.Boolean).toBe('boolean');
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
test('Number should be number', () => {
|
|
13
|
+
expect(Typeof.Number).toBe('number');
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
test('Object should be object', () => {
|
|
17
|
+
expect(Typeof.Object).toBe('object');
|
|
18
|
+
});
|
|
19
|
+
});
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import UserType from '../../Types/UserType';
|
|
2
|
+
|
|
3
|
+
describe('enum UserType', () => {
|
|
4
|
+
test('UserType.API should be API', () => {
|
|
5
|
+
expect(UserType.API).toEqual('API');
|
|
6
|
+
});
|
|
7
|
+
test('UserType.User should be User', () => {
|
|
8
|
+
expect(UserType.User).toEqual('User');
|
|
9
|
+
});
|
|
10
|
+
test('UserType.MasterAdmin should be MasterAdmin', () => {
|
|
11
|
+
expect(UserType.MasterAdmin).toEqual('MasterAdmin');
|
|
12
|
+
});
|
|
13
|
+
test('UserType.Public should be Public', () => {
|
|
14
|
+
expect(UserType.Public).toEqual('Public');
|
|
15
|
+
});
|
|
16
|
+
});
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import BadDataException from '../../Types/Exception/BadDataException';
|
|
2
|
+
import Version from '../../Types/Version';
|
|
3
|
+
|
|
4
|
+
describe('class Version', () => {
|
|
5
|
+
test('should create a version if version string is valid', () => {
|
|
6
|
+
expect(new Version('1.2.1').toString()).toEqual('1.2.1');
|
|
7
|
+
expect(new Version('1.2.1').version).toEqual('1.2.1');
|
|
8
|
+
});
|
|
9
|
+
test('Version.version should be mutatable', () => {
|
|
10
|
+
const version: Version = new Version('1.2.1');
|
|
11
|
+
version.version = '1.2.2';
|
|
12
|
+
expect(version.version).toEqual('1.2.2');
|
|
13
|
+
expect(version.toString()).toEqual('1.2.2');
|
|
14
|
+
});
|
|
15
|
+
test('mutating Version.version with invalid data should throw an BadDataException', () => {
|
|
16
|
+
const version: Version = new Version('1.0.0');
|
|
17
|
+
expect(() => {
|
|
18
|
+
version.version = '1';
|
|
19
|
+
}).toThrowError(BadDataException);
|
|
20
|
+
expect(() => {
|
|
21
|
+
version.version = '1.1';
|
|
22
|
+
}).toThrow('Version is not in valid format.');
|
|
23
|
+
expect(() => {
|
|
24
|
+
version.version = '1.1.0.0';
|
|
25
|
+
}).toThrowError(BadDataException);
|
|
26
|
+
});
|
|
27
|
+
test('creating version new Version with invalid data should throw an BadDataException', () => {
|
|
28
|
+
expect(() => {
|
|
29
|
+
new Version('1');
|
|
30
|
+
}).toThrowError(BadDataException);
|
|
31
|
+
expect(() => {
|
|
32
|
+
new Version('1.1');
|
|
33
|
+
}).toThrow('Version is not in valid format.');
|
|
34
|
+
});
|
|
35
|
+
});
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import BadDataException from '../../Types/Exception/BadDataException';
|
|
2
|
+
import XML from '../../Types/XML';
|
|
3
|
+
|
|
4
|
+
describe('class XML', () => {
|
|
5
|
+
test('new XML should return valid object if it is valid', () => {
|
|
6
|
+
const xmlString: string = '<test> <info>Test</info></test>';
|
|
7
|
+
const xml: XML = new XML(xmlString);
|
|
8
|
+
expect(xml.toString()).toEqual(xmlString);
|
|
9
|
+
expect(xml.xml).toEqual(xmlString);
|
|
10
|
+
});
|
|
11
|
+
test('XML.xml should be mutable', () => {
|
|
12
|
+
const xmlNewString: string = '<new> <info>Test</info></new>';
|
|
13
|
+
const xml: XML = new XML('<test> <info>Test</info></test>');
|
|
14
|
+
xml.xml = xmlNewString;
|
|
15
|
+
expect(xml.toString()).toEqual(xmlNewString);
|
|
16
|
+
expect(xml.xml).toEqual(xmlNewString);
|
|
17
|
+
});
|
|
18
|
+
test('mutating XML.xml with empty string should throw BadDataException', () => {
|
|
19
|
+
const xml: XML = new XML('<test> <info>Test</info></test>');
|
|
20
|
+
expect(() => {
|
|
21
|
+
xml.xml = '';
|
|
22
|
+
}).toThrowError(BadDataException);
|
|
23
|
+
expect(() => {
|
|
24
|
+
xml.xml = '';
|
|
25
|
+
}).toThrow('XML is not in valid format.');
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
test('new should throw BadDataException if empty string is given', () => {
|
|
29
|
+
expect(() => {
|
|
30
|
+
new XML('');
|
|
31
|
+
}).toThrowError(BadDataException);
|
|
32
|
+
expect(() => {
|
|
33
|
+
new XML('');
|
|
34
|
+
}).toThrow('XML is not in valid format.');
|
|
35
|
+
});
|
|
36
|
+
});
|
|
@@ -0,0 +1,425 @@
|
|
|
1
|
+
import Protocol from '../../Types/API/Protocol';
|
|
2
|
+
import API from '../../Utils/API';
|
|
3
|
+
import Hostname from '../../Types/API/Hostname';
|
|
4
|
+
import HTTPMethod from '../../Types/API/HTTPMethod';
|
|
5
|
+
import URL from '../../Types/API/URL';
|
|
6
|
+
import Route from '../../Types/API/Route';
|
|
7
|
+
import axios, {
|
|
8
|
+
AxiosResponse,
|
|
9
|
+
AxiosError,
|
|
10
|
+
AxiosStatic,
|
|
11
|
+
AxiosRequestConfig,
|
|
12
|
+
Method,
|
|
13
|
+
AxiosHeaders,
|
|
14
|
+
} from 'axios';
|
|
15
|
+
import { expect, jest } from '@jest/globals';
|
|
16
|
+
import HTTPResponse from '../../Types/API/HTTPResponse';
|
|
17
|
+
import HTTPErrorResponse from '../../Types/API/HTTPErrorResponse';
|
|
18
|
+
import APIException from '../../Types/Exception/ApiException';
|
|
19
|
+
import Dictionary from '../../Types/Dictionary';
|
|
20
|
+
import Headers from '../../Types/API/Headers';
|
|
21
|
+
import { JSONObject } from '../../Types/JSON';
|
|
22
|
+
import GenericObject from '../../Types/GenericObject';
|
|
23
|
+
|
|
24
|
+
const DEFAULT_HEADERS: Headers = {
|
|
25
|
+
'Access-Control-Allow-Origin': '*',
|
|
26
|
+
Accept: 'application/json',
|
|
27
|
+
'Content-Type': 'application/json;charset=UTF-8',
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
jest.mock('axios', () => {
|
|
31
|
+
// Use actual axios module exported functions/constants such as axios.isAxiosError()
|
|
32
|
+
return Object.assign(jest.fn(), jest.requireActual('axios'));
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
// Mock axios(config) top level function
|
|
36
|
+
// Ignore type error
|
|
37
|
+
// Property 'lastCall' is optional in type MockFunctionState but required in type MockContext
|
|
38
|
+
// @ts-ignore
|
|
39
|
+
const mockedAxios: jest.MockedFunctionDeep<typeof axios> =
|
|
40
|
+
jest.mocked<AxiosStatic>(axios);
|
|
41
|
+
|
|
42
|
+
// Spy on calls to HTTPErrorResponse
|
|
43
|
+
jest.mock('../../Types/API/HTTPErrorResponse');
|
|
44
|
+
|
|
45
|
+
const HTTPErrorResponseMock: jest.MockedClass<typeof HTTPErrorResponse> =
|
|
46
|
+
HTTPErrorResponse as jest.MockedClass<typeof HTTPErrorResponse>;
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Create a fake axios response
|
|
50
|
+
*/
|
|
51
|
+
function createAxiosResponse<T = any, D = any>(
|
|
52
|
+
{
|
|
53
|
+
data = [] as T,
|
|
54
|
+
status = 200,
|
|
55
|
+
statusText = 'OK',
|
|
56
|
+
config = {
|
|
57
|
+
headers: DEFAULT_HEADERS as AxiosHeaders,
|
|
58
|
+
},
|
|
59
|
+
headers = DEFAULT_HEADERS,
|
|
60
|
+
}: Partial<AxiosResponse<T, D>> = {
|
|
61
|
+
data: [] as T,
|
|
62
|
+
status: 200,
|
|
63
|
+
statusText: 'OK',
|
|
64
|
+
config: {
|
|
65
|
+
headers: DEFAULT_HEADERS as AxiosHeaders,
|
|
66
|
+
},
|
|
67
|
+
headers: DEFAULT_HEADERS,
|
|
68
|
+
}
|
|
69
|
+
): AxiosResponse<T, D> {
|
|
70
|
+
return {
|
|
71
|
+
data,
|
|
72
|
+
status,
|
|
73
|
+
statusText,
|
|
74
|
+
config,
|
|
75
|
+
headers,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
const mergedHeaders: Headers = {
|
|
80
|
+
'Access-Control-Allow-Origin': '*',
|
|
81
|
+
Accept: 'application/json',
|
|
82
|
+
'Content-Type': 'application/json', // replace default header
|
|
83
|
+
'X-PoweredBy': 'coffee', // add new header
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
/**
|
|
87
|
+
* Create a fake axios error
|
|
88
|
+
*/
|
|
89
|
+
function createAxiosError<T = any, D = any>(
|
|
90
|
+
{
|
|
91
|
+
config = {
|
|
92
|
+
headers: DEFAULT_HEADERS as AxiosHeaders,
|
|
93
|
+
},
|
|
94
|
+
isAxiosError = true,
|
|
95
|
+
toJSON = () => {
|
|
96
|
+
return {};
|
|
97
|
+
},
|
|
98
|
+
name = 'SOME_ERROR_OCCURRED',
|
|
99
|
+
message = 'Something went wrong',
|
|
100
|
+
response = createAxiosResponse(),
|
|
101
|
+
}: Partial<AxiosError<T, D>> = {
|
|
102
|
+
config: {
|
|
103
|
+
headers: DEFAULT_HEADERS as AxiosHeaders,
|
|
104
|
+
},
|
|
105
|
+
isAxiosError: true,
|
|
106
|
+
toJSON: () => {
|
|
107
|
+
return {};
|
|
108
|
+
},
|
|
109
|
+
name: '',
|
|
110
|
+
message: '',
|
|
111
|
+
response: createAxiosResponse(),
|
|
112
|
+
}
|
|
113
|
+
): AxiosError {
|
|
114
|
+
return {
|
|
115
|
+
config,
|
|
116
|
+
isAxiosError,
|
|
117
|
+
toJSON,
|
|
118
|
+
name,
|
|
119
|
+
message,
|
|
120
|
+
response,
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/**
|
|
125
|
+
* Create fake axios parameters
|
|
126
|
+
*/
|
|
127
|
+
function createAxiosParameters(
|
|
128
|
+
{
|
|
129
|
+
method = 'GET',
|
|
130
|
+
url = 'https://catfact.ninja/fact',
|
|
131
|
+
headers = { ...mergedHeaders },
|
|
132
|
+
data = undefined,
|
|
133
|
+
}: {
|
|
134
|
+
method?: Method;
|
|
135
|
+
url?: string;
|
|
136
|
+
headers?: Dictionary<string>;
|
|
137
|
+
data?: any;
|
|
138
|
+
} = {
|
|
139
|
+
method: 'GET',
|
|
140
|
+
url: 'https://catfact.ninja/fact',
|
|
141
|
+
headers: { ...mergedHeaders },
|
|
142
|
+
}
|
|
143
|
+
): AxiosRequestConfig {
|
|
144
|
+
return {
|
|
145
|
+
method,
|
|
146
|
+
url,
|
|
147
|
+
headers,
|
|
148
|
+
data,
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
const responseData: JSONObject = {
|
|
153
|
+
fact: 'Cats have 3 eyelids.',
|
|
154
|
+
length: 20,
|
|
155
|
+
};
|
|
156
|
+
|
|
157
|
+
const requestData: any = {
|
|
158
|
+
breed: 'Siamese',
|
|
159
|
+
};
|
|
160
|
+
|
|
161
|
+
const requestHeaders: Headers = {
|
|
162
|
+
'Content-Type': 'application/json',
|
|
163
|
+
'X-PoweredBy': 'coffee',
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
afterAll(() => {
|
|
167
|
+
jest.restoreAllMocks();
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
describe('API', () => {
|
|
171
|
+
test('should create an instance', () => {
|
|
172
|
+
const protocol: string = 'https://';
|
|
173
|
+
const hostname: string = 'catfact.ninja';
|
|
174
|
+
const api: API = new API(Protocol.HTTPS, new Hostname(hostname));
|
|
175
|
+
|
|
176
|
+
expect(api).toBeInstanceOf(API);
|
|
177
|
+
expect(api.baseRoute.toString()).toBe('/');
|
|
178
|
+
expect(api.protocol).toBe(protocol);
|
|
179
|
+
expect(api.hostname.toString()).toBe(hostname);
|
|
180
|
+
});
|
|
181
|
+
|
|
182
|
+
test('should create an instance with base route', () => {
|
|
183
|
+
const protocol: string = 'https://';
|
|
184
|
+
const hostname: string = 'catfact.ninja';
|
|
185
|
+
const route: string = 'fact';
|
|
186
|
+
|
|
187
|
+
const api: API = new API(
|
|
188
|
+
Protocol.HTTPS,
|
|
189
|
+
new Hostname(hostname),
|
|
190
|
+
new Route(route)
|
|
191
|
+
);
|
|
192
|
+
|
|
193
|
+
expect(api).toBeInstanceOf(API);
|
|
194
|
+
expect(api.baseRoute.toString()).toBe('fact');
|
|
195
|
+
expect(api.protocol).toBe(protocol);
|
|
196
|
+
expect(api.hostname.toString()).toBe(hostname);
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
describe('getErrorResponse', () => {
|
|
201
|
+
test('should create an HTTPErrorResponse instance', () => {
|
|
202
|
+
const data: any = { message: 'Something went wrong' };
|
|
203
|
+
const status: number = 500;
|
|
204
|
+
const headers: Headers = { 'X-PoweredBy': 'coffee' };
|
|
205
|
+
|
|
206
|
+
const response: AxiosResponse<typeof data, GenericObject> =
|
|
207
|
+
createAxiosResponse({
|
|
208
|
+
data,
|
|
209
|
+
headers,
|
|
210
|
+
status,
|
|
211
|
+
});
|
|
212
|
+
const axiosError: AxiosError<typeof data, GenericObject> =
|
|
213
|
+
createAxiosError({
|
|
214
|
+
response,
|
|
215
|
+
});
|
|
216
|
+
|
|
217
|
+
// Use bracket notation property access to access private method
|
|
218
|
+
const errorResponse: HTTPErrorResponse =
|
|
219
|
+
API['getErrorResponse'](axiosError);
|
|
220
|
+
|
|
221
|
+
expect(errorResponse).toBeInstanceOf(HTTPErrorResponse);
|
|
222
|
+
expect(HTTPErrorResponseMock).toHaveBeenCalledTimes(1);
|
|
223
|
+
expect(HTTPErrorResponseMock).toHaveBeenCalledWith(
|
|
224
|
+
status,
|
|
225
|
+
data,
|
|
226
|
+
headers
|
|
227
|
+
);
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
test('should throw if response error has no response', () => {
|
|
231
|
+
// NOTE: Passing undefined will initialize the default parameter
|
|
232
|
+
const axiosError: AxiosError<null, GenericObject> = createAxiosError({
|
|
233
|
+
response: null!,
|
|
234
|
+
}) as AxiosError<null, GenericObject>;
|
|
235
|
+
|
|
236
|
+
// Use bracket notation property access to access private method
|
|
237
|
+
expect(() => {
|
|
238
|
+
API['getErrorResponse'](axiosError);
|
|
239
|
+
}).toThrowError(APIException);
|
|
240
|
+
});
|
|
241
|
+
});
|
|
242
|
+
|
|
243
|
+
describe('fetch', () => {
|
|
244
|
+
test('should return an HTTPResponse if request is successful', async () => {
|
|
245
|
+
const status: number = 200;
|
|
246
|
+
const params: Dictionary<string> = {
|
|
247
|
+
count: '1',
|
|
248
|
+
};
|
|
249
|
+
|
|
250
|
+
const mockedParsedResponse: HTTPResponse<typeof responseData> =
|
|
251
|
+
new HTTPResponse(status, responseData, DEFAULT_HEADERS);
|
|
252
|
+
|
|
253
|
+
const mockedAxiosResponse: AxiosResponse<
|
|
254
|
+
typeof responseData,
|
|
255
|
+
GenericObject
|
|
256
|
+
> = createAxiosResponse({
|
|
257
|
+
status,
|
|
258
|
+
data: responseData,
|
|
259
|
+
});
|
|
260
|
+
|
|
261
|
+
mockedAxios.mockResolvedValueOnce(mockedAxiosResponse);
|
|
262
|
+
|
|
263
|
+
const response: HTTPResponse<typeof responseData> = await API.fetch(
|
|
264
|
+
HTTPMethod.POST,
|
|
265
|
+
new URL(Protocol.HTTPS, 'catfact.ninja', new Route('fact')),
|
|
266
|
+
requestData,
|
|
267
|
+
requestHeaders,
|
|
268
|
+
params
|
|
269
|
+
);
|
|
270
|
+
|
|
271
|
+
// Check method, url (protocol, hostname, parameters), headers, request data
|
|
272
|
+
expect(axios).toBeCalledWith({
|
|
273
|
+
method: 'POST',
|
|
274
|
+
url: 'https://catfact.ninja/fact?count=1',
|
|
275
|
+
headers: mergedHeaders,
|
|
276
|
+
data: requestData,
|
|
277
|
+
});
|
|
278
|
+
|
|
279
|
+
expect(response).toEqual(mockedParsedResponse);
|
|
280
|
+
});
|
|
281
|
+
|
|
282
|
+
test('should return an HTTPErrorResponse if request fails', async () => {
|
|
283
|
+
const status: number = 404;
|
|
284
|
+
const statusText: string = 'Not Found';
|
|
285
|
+
const data: JSONObject = {
|
|
286
|
+
message: 'Not Found',
|
|
287
|
+
};
|
|
288
|
+
|
|
289
|
+
const mockedAxiosError: AxiosError<undefined, GenericObject> =
|
|
290
|
+
createAxiosError({
|
|
291
|
+
response: createAxiosResponse({
|
|
292
|
+
status,
|
|
293
|
+
statusText,
|
|
294
|
+
data,
|
|
295
|
+
}),
|
|
296
|
+
message: 'An error occurred',
|
|
297
|
+
}) as AxiosError<undefined, GenericObject>;
|
|
298
|
+
|
|
299
|
+
mockedAxios.mockRejectedValueOnce(mockedAxiosError);
|
|
300
|
+
|
|
301
|
+
const httpErrorResponse: HTTPResponse<JSONObject> = await API.fetch(
|
|
302
|
+
HTTPMethod.GET,
|
|
303
|
+
new URL(Protocol.HTTPS, 'catfact.ninja', new Route('fact'))
|
|
304
|
+
);
|
|
305
|
+
|
|
306
|
+
expect(axios).toBeCalledWith({
|
|
307
|
+
method: 'GET',
|
|
308
|
+
url: 'https://catfact.ninja/fact',
|
|
309
|
+
headers: DEFAULT_HEADERS,
|
|
310
|
+
data: undefined,
|
|
311
|
+
});
|
|
312
|
+
|
|
313
|
+
expect(httpErrorResponse).toBeInstanceOf(HTTPErrorResponse);
|
|
314
|
+
});
|
|
315
|
+
|
|
316
|
+
test('should throw an APIException if initializing request fails', async () => {
|
|
317
|
+
mockedAxios.mockImplementationOnce(() => {
|
|
318
|
+
throw new Error('Something went wrong');
|
|
319
|
+
});
|
|
320
|
+
|
|
321
|
+
await expect(async () => {
|
|
322
|
+
await API.fetch(
|
|
323
|
+
HTTPMethod.GET,
|
|
324
|
+
new URL(Protocol.HTTPS, 'catfact.ninja', new Route('fact'))
|
|
325
|
+
);
|
|
326
|
+
}).rejects.toThrowError(APIException);
|
|
327
|
+
});
|
|
328
|
+
});
|
|
329
|
+
|
|
330
|
+
describe('getDefaultHeaders', () => {
|
|
331
|
+
test('should return default headers', () => {
|
|
332
|
+
expect(API.getDefaultHeaders()).toEqual(DEFAULT_HEADERS);
|
|
333
|
+
});
|
|
334
|
+
});
|
|
335
|
+
|
|
336
|
+
describe('getHeaders', () => {
|
|
337
|
+
test('should merge headers', () => {
|
|
338
|
+
// Use bracket notation to access protected member
|
|
339
|
+
expect(API['getHeaders'](requestHeaders)).toEqual(mergedHeaders);
|
|
340
|
+
});
|
|
341
|
+
});
|
|
342
|
+
|
|
343
|
+
interface HTTPMethodType {
|
|
344
|
+
name: Lowercase<HTTPMethod>; // 'get' | 'post' | 'delete' | 'put'
|
|
345
|
+
method: HTTPMethod;
|
|
346
|
+
}
|
|
347
|
+
|
|
348
|
+
// Set up table-driven tests for
|
|
349
|
+
// .get(), .post(), .put(), .delete(), get(), post(), put(), delete()
|
|
350
|
+
const httpMethodTests: Array<HTTPMethodType> = [
|
|
351
|
+
{
|
|
352
|
+
name: 'get',
|
|
353
|
+
method: HTTPMethod.GET,
|
|
354
|
+
},
|
|
355
|
+
{
|
|
356
|
+
name: 'post',
|
|
357
|
+
method: HTTPMethod.POST,
|
|
358
|
+
},
|
|
359
|
+
{
|
|
360
|
+
name: 'put',
|
|
361
|
+
method: HTTPMethod.PUT,
|
|
362
|
+
},
|
|
363
|
+
{
|
|
364
|
+
name: 'delete',
|
|
365
|
+
method: HTTPMethod.DELETE,
|
|
366
|
+
},
|
|
367
|
+
{
|
|
368
|
+
name: 'head',
|
|
369
|
+
method: HTTPMethod.HEAD,
|
|
370
|
+
},
|
|
371
|
+
];
|
|
372
|
+
|
|
373
|
+
describe.each(httpMethodTests)('$name', ({ name, method }: HTTPMethodType) => {
|
|
374
|
+
test(`should make a ${method} request`, async () => {
|
|
375
|
+
mockedAxios.mockResolvedValueOnce(createAxiosResponse());
|
|
376
|
+
|
|
377
|
+
const url: URL = new URL(
|
|
378
|
+
Protocol.HTTPS,
|
|
379
|
+
'catfact.ninja',
|
|
380
|
+
new Route('fact')
|
|
381
|
+
);
|
|
382
|
+
const got: HTTPResponse<JSONObject> = await API[name](
|
|
383
|
+
url,
|
|
384
|
+
requestData,
|
|
385
|
+
requestHeaders
|
|
386
|
+
);
|
|
387
|
+
|
|
388
|
+
// Check method, url, headers, request data
|
|
389
|
+
expect(axios).toBeCalledWith(
|
|
390
|
+
createAxiosParameters({
|
|
391
|
+
method,
|
|
392
|
+
url: 'https://catfact.ninja/fact',
|
|
393
|
+
data: requestData,
|
|
394
|
+
headers: mergedHeaders,
|
|
395
|
+
})
|
|
396
|
+
);
|
|
397
|
+
expect(got).toBeInstanceOf(HTTPResponse);
|
|
398
|
+
});
|
|
399
|
+
});
|
|
400
|
+
|
|
401
|
+
describe.each(httpMethodTests)('.$name', ({ name, method }: HTTPMethodType) => {
|
|
402
|
+
test(`should make a ${method} request`, async () => {
|
|
403
|
+
const route: string = 'fact';
|
|
404
|
+
const hostname: string = 'catfact.ninja';
|
|
405
|
+
const api: API = new API(Protocol.HTTPS, new Hostname(hostname));
|
|
406
|
+
|
|
407
|
+
mockedAxios.mockResolvedValueOnce(createAxiosResponse());
|
|
408
|
+
|
|
409
|
+
const got: HTTPResponse<JSONObject> = await api[name](
|
|
410
|
+
new Route(route),
|
|
411
|
+
requestData,
|
|
412
|
+
requestHeaders
|
|
413
|
+
);
|
|
414
|
+
|
|
415
|
+
// Check method, url (protocol, hostname, route), headers, request data
|
|
416
|
+
expect(axios).toBeCalledWith(
|
|
417
|
+
createAxiosParameters({
|
|
418
|
+
url: 'https://catfact.ninja/fact',
|
|
419
|
+
method,
|
|
420
|
+
data: requestData,
|
|
421
|
+
})
|
|
422
|
+
);
|
|
423
|
+
expect(got).toBeInstanceOf(HTTPResponse);
|
|
424
|
+
});
|
|
425
|
+
});
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import Analytics from '../../Utils/Analytics';
|
|
2
|
+
import Email from '../../Types/Email';
|
|
3
|
+
import { JSONObject } from '../../Types/JSON';
|
|
4
|
+
import posthog from 'posthog-js';
|
|
5
|
+
|
|
6
|
+
jest.mock('posthog-js', () => {
|
|
7
|
+
return {
|
|
8
|
+
init: jest.fn(),
|
|
9
|
+
identify: jest.fn(),
|
|
10
|
+
reset: jest.fn(),
|
|
11
|
+
capture: jest.fn(),
|
|
12
|
+
};
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
const apiHost: string = 'https://example.com';
|
|
16
|
+
const apiKey: string = 'your-api-key';
|
|
17
|
+
|
|
18
|
+
describe('Analytics Class', () => {
|
|
19
|
+
afterEach(() => {
|
|
20
|
+
jest.clearAllMocks();
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
it('should initialize the Analytics class', () => {
|
|
24
|
+
const analytics: Analytics = new Analytics(apiHost, apiKey);
|
|
25
|
+
|
|
26
|
+
expect(posthog.init).toHaveBeenCalledWith(apiKey, {
|
|
27
|
+
api_host: apiHost,
|
|
28
|
+
autocapture: false,
|
|
29
|
+
});
|
|
30
|
+
expect(analytics.isInitialized).toBe(true);
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it('should not initialize if apiHost and apiKey are not provided', () => {
|
|
34
|
+
const analytics: Analytics = new Analytics('', '');
|
|
35
|
+
|
|
36
|
+
expect(posthog.init).not.toHaveBeenCalled();
|
|
37
|
+
expect(analytics.isInitialized).toBe(false);
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
it('should authenticate a user', () => {
|
|
41
|
+
const analytics: Analytics = new Analytics(apiHost, apiKey);
|
|
42
|
+
const email: Email = new Email('test@example.com');
|
|
43
|
+
|
|
44
|
+
analytics.userAuth(email);
|
|
45
|
+
expect(posthog.identify).toHaveBeenCalledWith(email.toString());
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
it('should not authenticate a user if not initialized', () => {
|
|
49
|
+
const analytics: Analytics = new Analytics('', '');
|
|
50
|
+
const email: Email = new Email('test@example.com');
|
|
51
|
+
|
|
52
|
+
analytics.userAuth(email);
|
|
53
|
+
expect(posthog.identify).not.toHaveBeenCalled();
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
it('should reset the user session on logout', () => {
|
|
57
|
+
const analytics: Analytics = new Analytics(apiHost, apiKey);
|
|
58
|
+
|
|
59
|
+
analytics.logout();
|
|
60
|
+
expect(posthog.reset).toHaveBeenCalled();
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('should not reset the user session if not initialized', () => {
|
|
64
|
+
const analytics: Analytics = new Analytics('', '');
|
|
65
|
+
|
|
66
|
+
analytics.logout();
|
|
67
|
+
expect(posthog.reset).not.toHaveBeenCalled();
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
it('should capture an event with optional data', () => {
|
|
71
|
+
const analytics: Analytics = new Analytics(apiHost, apiKey);
|
|
72
|
+
const eventName: string = 'testEvent';
|
|
73
|
+
const data: JSONObject = { key: 'value' };
|
|
74
|
+
|
|
75
|
+
analytics.capture(eventName, data);
|
|
76
|
+
expect(posthog.capture).toHaveBeenCalledWith(eventName, data);
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it('should not capture an event if not initialized', () => {
|
|
80
|
+
const analytics: Analytics = new Analytics('', '');
|
|
81
|
+
|
|
82
|
+
analytics.capture('testEvent');
|
|
83
|
+
expect(posthog.capture).not.toHaveBeenCalled();
|
|
84
|
+
});
|
|
85
|
+
});
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
EVERY_MINUTE,
|
|
3
|
+
EVERY_DAY,
|
|
4
|
+
EVERY_HOUR,
|
|
5
|
+
EVERY_FIVE_MINUTE,
|
|
6
|
+
EVERY_FIVE_SECONDS,
|
|
7
|
+
EVERY_WEEK,
|
|
8
|
+
} from '../../Utils/CronTime';
|
|
9
|
+
|
|
10
|
+
describe('CronTime', () => {
|
|
11
|
+
test('should return every minute', () => {
|
|
12
|
+
expect(EVERY_MINUTE).toEqual('* * * * *');
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
test('should return every day', () => {
|
|
16
|
+
expect(EVERY_DAY).toEqual('0 8 * * *');
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
test('should return every hour', () => {
|
|
20
|
+
expect(EVERY_HOUR).toEqual('1 * * * *');
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
test('should return every five minute', () => {
|
|
24
|
+
expect(EVERY_FIVE_MINUTE).toEqual('*/5 * * * *');
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
test('should return every five seconds', () => {
|
|
28
|
+
expect(EVERY_FIVE_SECONDS).toEqual('*/5 * * * * *');
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
test('should return every week', () => {
|
|
32
|
+
expect(EVERY_WEEK).toEqual('0 0 * * 0');
|
|
33
|
+
});
|
|
34
|
+
});
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import Faker from '../../Utils/Faker';
|
|
2
|
+
import Email from '../../Types/Email';
|
|
3
|
+
import Name from '../../Types/Name';
|
|
4
|
+
import Phone from '../../Types/Phone';
|
|
5
|
+
|
|
6
|
+
describe('Faker Class', () => {
|
|
7
|
+
it('should generate a random name with alphanumeric characters', () => {
|
|
8
|
+
expect(Faker.generateName()).toMatch(/^[a-zA-Z0-9]{10}$/);
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
it('should generate a random company name', () => {
|
|
12
|
+
expect(Faker.generateCompanyName()).toBeTruthy();
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
it('should generate a string of random numbers of specified length', () => {
|
|
16
|
+
expect(Faker.randomNumbers(8)).toMatch(/^\d{8}$/);
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
it('should generate a user full name', () => {
|
|
20
|
+
const userFullName: Name = Faker.generateUserFullName();
|
|
21
|
+
expect(userFullName).toHaveProperty('name');
|
|
22
|
+
expect(userFullName.name).toBeTruthy();
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it('should generate a valid email address', () => {
|
|
26
|
+
const email: Email = Faker.generateEmail();
|
|
27
|
+
expect(email.email).toMatch(
|
|
28
|
+
/^[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,9}$/i
|
|
29
|
+
);
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
it('should generate a valid phone number', () => {
|
|
33
|
+
const phone: Phone = Faker.generatePhone();
|
|
34
|
+
expect(phone.phone).toMatch(
|
|
35
|
+
/^[+]?[(]?[0-9]{3}[)]?[-\s.]?[0-9]{3}[-\s.]?[0-9]{4,7}$/
|
|
36
|
+
);
|
|
37
|
+
});
|
|
38
|
+
});
|