globalpayments-api 3.7.0 → 3.8.1
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/CHANGELOG.md +17 -1
- package/LICENSE.md +257 -257
- package/README.md +141 -141
- package/lib/src/Builders/BaseBuilder/Validations.js +1 -1
- package/lib/src/Builders/BaseBuilder/Validations.js.map +1 -1
- package/lib/src/Builders/ManagementBuilder.d.ts +26 -6
- package/lib/src/Builders/ManagementBuilder.js +66 -34
- package/lib/src/Builders/ManagementBuilder.js.map +1 -1
- package/lib/src/Builders/RequestBuilder/GpApi/GpApiManagementRequestBuilder.js +19 -0
- package/lib/src/Builders/RequestBuilder/GpApi/GpApiManagementRequestBuilder.js.map +1 -1
- package/lib/src/Builders/RequestBuilder/GpApi/GpApiReportRequestBuilder.d.ts +2 -0
- package/lib/src/Builders/RequestBuilder/GpApi/GpApiReportRequestBuilder.js +86 -0
- package/lib/src/Builders/RequestBuilder/GpApi/GpApiReportRequestBuilder.js.map +1 -1
- package/lib/src/Builders/TransactionReportBuilder.d.ts +5 -2
- package/lib/src/Builders/TransactionReportBuilder.js +19 -0
- package/lib/src/Builders/TransactionReportBuilder.js.map +1 -1
- package/lib/src/Entities/AdditionalTaxDetails.d.ts +5 -0
- package/lib/src/Entities/AdditionalTaxDetails.js +10 -0
- package/lib/src/Entities/AdditionalTaxDetails.js.map +1 -0
- package/lib/src/Entities/CommercialData.d.ts +26 -0
- package/lib/src/Entities/CommercialData.js +36 -0
- package/lib/src/Entities/CommercialData.js.map +1 -0
- package/lib/src/Entities/CommercialLineItem.d.ts +21 -0
- package/lib/src/Entities/CommercialLineItem.js +24 -0
- package/lib/src/Entities/CommercialLineItem.js.map +1 -0
- package/lib/src/Entities/DiscountDetails.d.ts +8 -0
- package/lib/src/Entities/DiscountDetails.js +13 -0
- package/lib/src/Entities/DiscountDetails.js.map +1 -0
- package/lib/src/Entities/DisputeDocument.d.ts +5 -0
- package/lib/src/Entities/DisputeDocument.js +10 -0
- package/lib/src/Entities/DisputeDocument.js.map +1 -0
- package/lib/src/Entities/Document.d.ts +10 -0
- package/lib/src/Entities/Document.js +13 -0
- package/lib/src/Entities/Document.js.map +1 -0
- package/lib/src/Entities/Enums/DisputeSortProperty.d.ts +12 -0
- package/lib/src/Entities/Enums/DisputeSortProperty.js +17 -0
- package/lib/src/Entities/Enums/DisputeSortProperty.js.map +1 -0
- package/lib/src/Entities/Enums/DisputeStage.d.ts +11 -0
- package/lib/src/Entities/Enums/DisputeStage.js +16 -0
- package/lib/src/Entities/Enums/DisputeStage.js.map +1 -0
- package/lib/src/Entities/Enums/DisputeStatus.d.ts +7 -0
- package/lib/src/Entities/Enums/DisputeStatus.js +12 -0
- package/lib/src/Entities/Enums/DisputeStatus.js.map +1 -0
- package/lib/src/Entities/Enums/DocumentCategory.d.ts +5 -0
- package/lib/src/Entities/Enums/DocumentCategory.js +10 -0
- package/lib/src/Entities/Enums/DocumentCategory.js.map +1 -0
- package/lib/src/Entities/Enums/FileType.d.ts +11 -0
- package/lib/src/Entities/Enums/FileType.js +16 -0
- package/lib/src/Entities/Enums/FileType.js.map +1 -0
- package/lib/src/Entities/Enums.d.ts +17 -1
- package/lib/src/Entities/Enums.js +20 -2
- package/lib/src/Entities/Enums.js.map +1 -1
- package/lib/src/Entities/HostedPaymentData.d.ts +3 -0
- package/lib/src/Entities/HostedPaymentData.js +3 -0
- package/lib/src/Entities/HostedPaymentData.js.map +1 -1
- package/lib/src/Entities/Reporting/DisputeSummary.d.ts +53 -0
- package/lib/src/Entities/Reporting/DisputeSummary.js +64 -0
- package/lib/src/Entities/Reporting/DisputeSummary.js.map +1 -0
- package/lib/src/Entities/Reporting/SearchCriteriaBuilder.d.ts +4 -2
- package/lib/src/Entities/Reporting/SearchCriteriaBuilder.js +2 -0
- package/lib/src/Entities/Reporting/SearchCriteriaBuilder.js.map +1 -1
- package/lib/src/Entities/Reporting/index.d.ts +1 -0
- package/lib/src/Entities/Reporting/index.js +1 -0
- package/lib/src/Entities/Reporting/index.js.map +1 -1
- package/lib/src/Entities/Transaction.js +3 -0
- package/lib/src/Entities/Transaction.js.map +1 -1
- package/lib/src/Entities/TransactionSummary.d.ts +1 -0
- package/lib/src/Entities/TransactionSummary.js +1 -0
- package/lib/src/Entities/TransactionSummary.js.map +1 -1
- package/lib/src/Entities/index.d.ts +7 -0
- package/lib/src/Entities/index.js +7 -0
- package/lib/src/Entities/index.js.map +1 -1
- package/lib/src/Gateways/GpApiConnector.js +3 -0
- package/lib/src/Gateways/GpApiConnector.js.map +1 -1
- package/lib/src/Gateways/GpEcomConnector.js +9 -0
- package/lib/src/Gateways/GpEcomConnector.js.map +1 -1
- package/lib/src/Gateways/PayPlanConnector.d.ts +1 -1
- package/lib/src/Gateways/PorticoConnector.d.ts +3 -3
- package/lib/src/Gateways/PorticoConnector.js +117 -4
- package/lib/src/Gateways/PorticoConnector.js.map +1 -1
- package/lib/src/Mapping/GpApiMapping.d.ts +2 -1
- package/lib/src/Mapping/GpApiMapping.js +75 -2
- package/lib/src/Mapping/GpApiMapping.js.map +1 -1
- package/lib/src/Services/ReportingService.d.ts +6 -1
- package/lib/src/Services/ReportingService.js +15 -0
- package/lib/src/Services/ReportingService.js.map +1 -1
- package/lib/test/Integration/Gateways/GpApiConnector/{3DS2Test.js → 3DS2.test.js} +338 -341
- package/lib/test/Integration/Gateways/GpApiConnector/3DS2.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/{3DSecureTest.js → 3DSecure.test.js} +167 -173
- package/lib/test/Integration/Gateways/GpApiConnector/3DSecure.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/AccessToken.test.js +130 -0
- package/lib/test/Integration/Gateways/GpApiConnector/AccessToken.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/CreditCardNotPresent.test.js +1070 -0
- package/lib/test/Integration/Gateways/GpApiConnector/CreditCardNotPresent.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/{DebitCardTest.js → DebitCard.test.js} +27 -33
- package/lib/test/Integration/Gateways/GpApiConnector/DebitCard.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/{GpApiCertificationTest.js → GpApiCertification.test.js} +211 -208
- package/lib/test/Integration/Gateways/GpApiConnector/GpApiCertification.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/GpApiTokenManagement.test.js +151 -0
- package/lib/test/Integration/Gateways/GpApiConnector/GpApiTokenManagement.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/{ReportingDepositsTest.js → ReportingDeposits.test.js} +103 -103
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingDeposits.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingDisputes.test.js +571 -0
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingDisputes.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/{ReportingSettlementTransactionsTest.js → ReportingSettlementTransactions.test.js} +104 -108
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingSettlementTransactions.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/{ReportingStoredPaymentMethodsTest.js → ReportingStoredPaymentMethods.test.js} +75 -76
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingStoredPaymentMethods.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpApiConnector/{ReportingTransactionsTest.js → ReportingTransactions.test.js} +97 -95
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingTransactions.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/{AuthTest.js → Auth.test.js} +441 -461
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/Auth.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/{AvsTest.js → Avs.test.js} +274 -218
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/Avs.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/{CreditTest.js → Credit.test.js} +317 -321
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/Credit.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/{HoldTest.js → Hold.test.js} +290 -257
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/Hold.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/{CreditTest.js → Credit.test.js} +76 -84
- package/lib/test/Integration/Gateways/GpEcomConnector/Credit.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/Hpp.test.js +137 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/Hpp.test.js.map +1 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/Recurring.test.js +124 -0
- package/lib/test/Integration/Gateways/GpEcomConnector/Recurring.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Ach.test.js +54 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Ach.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/Check.test.js +357 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/Check.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{EcommerceTest.js → Ecommerce.test.js} +403 -459
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/Ecommerce.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{EcommerceCheckTest.js → EcommerceCheck.test.js} +17 -23
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceCheck.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{MotoTest.js → Moto.test.js} +377 -650
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/Moto.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{MotoCheckTest.js → MotoCheck.test.js} +16 -22
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoCheck.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/Recurring.test.js +393 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/Recurring.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{RetailTest.js → Retail.test.js} +481 -600
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/Retail.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Credit.test.js +433 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Credit.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/{DebitTest.js → Debit.test.js} +32 -37
- package/lib/test/Integration/Gateways/PorticoConnector/Debit.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/{EbtTest.js → Ebt.test.js} +30 -39
- package/lib/test/Integration/Gateways/PorticoConnector/Ebt.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/{EcommerceTest.js → Ecommerce.test.js} +38 -45
- package/lib/test/Integration/Gateways/PorticoConnector/Ecommerce.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Gift.test.js +121 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Gift.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/{PorticoManagementTokenTest.js → PorticoManagementToken.test.js} +8 -16
- package/lib/test/Integration/Gateways/PorticoConnector/PorticoManagementToken.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Recurring.test.js +87 -0
- package/lib/test/Integration/Gateways/PorticoConnector/Recurring.test.js.map +1 -0
- package/lib/test/Integration/Gateways/PorticoConnector/{ReportingTest.js → Reporting.test.js} +12 -18
- package/lib/test/Integration/Gateways/PorticoConnector/Reporting.test.js.map +1 -0
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{GetInformationCertificationTest.js → GetInformationCertification.test.js} +12 -18
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/GetInformationCertification.test.js.map +1 -0
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayAccountCertificationTest.js → ProPayAccountCertification.test.js} +49 -64
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayAccountCertification.test.js.map +1 -0
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayFundCertificationTest.js → ProPayFundCertification.test.js} +14 -22
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayFundCertification.test.js.map +1 -0
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayInNetworkTransactionCertificationTest.js → ProPayInNetworkTransactionCertification.test.js} +18 -26
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayInNetworkTransactionCertification.test.js.map +1 -0
- package/lib/test/Integration/Gateways/ProPayConnector/{GetInformationTest.js → GetInformation.test.js} +11 -18
- package/lib/test/Integration/Gateways/ProPayConnector/GetInformation.test.js.map +1 -0
- package/lib/test/Integration/Gateways/ProPayConnector/{ProPayAccountTest.js → ProPayAccount.test.js} +63 -83
- package/lib/test/Integration/Gateways/ProPayConnector/ProPayAccount.test.js.map +1 -0
- package/lib/test/Integration/Gateways/ProPayConnector/{ProPayFundsTest.js → ProPayFunds.test.js} +15 -22
- package/lib/test/Integration/Gateways/ProPayConnector/ProPayFunds.test.js.map +1 -0
- package/lib/test/Integration/Gateways/ProPayConnector/{ProPayInNetworkTransactionTest.js → ProPayInNetworkTransaction.test.js} +17 -25
- package/lib/test/Integration/Gateways/ProPayConnector/ProPayInNetworkTransaction.test.js.map +1 -0
- package/lib/test/Integration/Gateways/Terminals/UPA/UpaMic.test.js +165 -0
- package/lib/test/Integration/Gateways/Terminals/UPA/UpaMic.test.js.map +1 -0
- package/lib/test/Integration/Services/{CheckServiceTest.js → CheckService.test.js} +11 -18
- package/lib/test/Integration/Services/CheckService.test.js.map +1 -0
- package/lib/test/Integration/Services/{CreditServiceTest.js → CreditService.test.js} +48 -64
- package/lib/test/Integration/Services/CreditService.test.js.map +1 -0
- package/lib/test/Integration/Services/{DebitServiceTest.js → DebitService.test.js} +28 -32
- package/lib/test/Integration/Services/DebitService.test.js.map +1 -0
- package/lib/test/Integration/Services/{EBTServiceTest.js → EBTService.test.js} +16 -26
- package/lib/test/Integration/Services/EBTService.test.js.map +1 -0
- package/lib/test/Unit/Builders/AuthorizationBuilder/Validation.test.js +122 -0
- package/lib/test/Unit/Builders/AuthorizationBuilder/Validation.test.js.map +1 -0
- package/lib/test/Unit/Builders/ReportBuilder/Validation.test.js +66 -0
- package/lib/test/Unit/Builders/ReportBuilder/Validation.test.js.map +1 -0
- package/lib/test/Unit/Gateways/GpEcomConnector/{CreditTest.js → Credit.test.js} +13 -15
- package/lib/test/Unit/Gateways/GpEcomConnector/Credit.test.js.map +1 -0
- package/lib/test/Unit/Gateways/PorticoConnector/InputValidation.test.js +128 -0
- package/lib/test/Unit/Gateways/PorticoConnector/InputValidation.test.js.map +1 -0
- package/package.json +7 -17
- package/lib/test/Integration/Gateways/GpApiConnector/3DS2Test.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/3DSecureTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/AccessTokenTest.js +0 -109
- package/lib/test/Integration/Gateways/GpApiConnector/AccessTokenTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/CreditCardNotPresentTest.js +0 -1025
- package/lib/test/Integration/Gateways/GpApiConnector/CreditCardNotPresentTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/CreditCardPresentTest.js +0 -439
- package/lib/test/Integration/Gateways/GpApiConnector/CreditCardPresentTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/DebitCardTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/GpApiCertificationTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/GpApiTokenManagementTest.js +0 -149
- package/lib/test/Integration/Gateways/GpApiConnector/GpApiTokenManagementTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingDepositsTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingSettlementTransactionsTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingStoredPaymentMethodsTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpApiConnector/ReportingTransactionsTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/AuthTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/AvsTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/CreditTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpEcomConnector/Certification/HoldTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpEcomConnector/CreditTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpEcomConnector/HppTest.js +0 -99
- package/lib/test/Integration/Gateways/GpEcomConnector/HppTest.js.map +0 -1
- package/lib/test/Integration/Gateways/GpEcomConnector/RecurringTest.js +0 -133
- package/lib/test/Integration/Gateways/GpEcomConnector/RecurringTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/AchTest.js +0 -59
- package/lib/test/Integration/Gateways/PorticoConnector/AchTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/CheckTest.js +0 -378
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/CheckTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceCheckTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoCheckTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RecurringTest.js +0 -420
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RecurringTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RetailTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/CreditTest.js +0 -392
- package/lib/test/Integration/Gateways/PorticoConnector/CreditTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/DebitTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/EbtTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/EcommerceTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/GiftTest.js +0 -147
- package/lib/test/Integration/Gateways/PorticoConnector/GiftTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/PorticoManagementTokenTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/RecurringTest.js +0 -101
- package/lib/test/Integration/Gateways/PorticoConnector/RecurringTest.js.map +0 -1
- package/lib/test/Integration/Gateways/PorticoConnector/ReportingTest.js.map +0 -1
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/GetInformationCertificationTest.js.map +0 -1
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayAccountCertificationTest.js.map +0 -1
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayFundCertificationTest.js.map +0 -1
- package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayInNetworkTransactionCertificationTest.js.map +0 -1
- package/lib/test/Integration/Gateways/ProPayConnector/GetInformationTest.js.map +0 -1
- package/lib/test/Integration/Gateways/ProPayConnector/ProPayAccountTest.js.map +0 -1
- package/lib/test/Integration/Gateways/ProPayConnector/ProPayFundsTest.js.map +0 -1
- package/lib/test/Integration/Gateways/ProPayConnector/ProPayInNetworkTransactionTest.js.map +0 -1
- package/lib/test/Integration/Gateways/Terminals/UPA/UpaMicTest.js +0 -149
- package/lib/test/Integration/Gateways/Terminals/UPA/UpaMicTest.js.map +0 -1
- package/lib/test/Integration/Services/CheckServiceTest.js.map +0 -1
- package/lib/test/Integration/Services/CreditServiceTest.js.map +0 -1
- package/lib/test/Integration/Services/DebitServiceTest.js.map +0 -1
- package/lib/test/Integration/Services/EBTServiceTest.js.map +0 -1
- package/lib/test/Unit/Builders/AuthorizationBuilder/ValidationTest.js +0 -111
- package/lib/test/Unit/Builders/AuthorizationBuilder/ValidationTest.js.map +0 -1
- package/lib/test/Unit/Builders/ReportBuilder/ValidationTest.js +0 -62
- package/lib/test/Unit/Builders/ReportBuilder/ValidationTest.js.map +0 -1
- package/lib/test/Unit/Gateways/GpEcomConnector/CreditTest.js.map +0 -1
- package/lib/test/Unit/Gateways/PorticoConnector/InputValidationTest.js +0 -125
- package/lib/test/Unit/Gateways/PorticoConnector/InputValidationTest.js.map +0 -1
- /package/lib/test/Integration/Gateways/GpApiConnector/{3DS2Test.d.ts → 3DS2.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{3DSecureTest.d.ts → 3DSecure.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{AccessTokenTest.d.ts → AccessToken.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{CreditCardNotPresentTest.d.ts → CreditCardNotPresent.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{CreditCardPresentTest.d.ts → DebitCard.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{DebitCardTest.d.ts → GpApiCertification.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{GpApiCertificationTest.d.ts → GpApiTokenManagement.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{GpApiTokenManagementTest.d.ts → ReportingDeposits.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{ReportingDepositsTest.d.ts → ReportingDisputes.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{ReportingSettlementTransactionsTest.d.ts → ReportingSettlementTransactions.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{ReportingStoredPaymentMethodsTest.d.ts → ReportingStoredPaymentMethods.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpApiConnector/{ReportingTransactionsTest.d.ts → ReportingTransactions.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpEcomConnector/Certification/{AuthTest.d.ts → Auth.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpEcomConnector/Certification/{AvsTest.d.ts → Avs.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpEcomConnector/Certification/{CreditTest.d.ts → Credit.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpEcomConnector/Certification/{HoldTest.d.ts → Hold.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpEcomConnector/{CreditTest.d.ts → Credit.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpEcomConnector/{HppTest.d.ts → Hpp.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/GpEcomConnector/{RecurringTest.d.ts → Recurring.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{AchTest.d.ts → Ach.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{CheckTest.d.ts → Check.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{EcommerceCheckTest.d.ts → Ecommerce.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{EcommerceTest.d.ts → EcommerceCheck.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{MotoCheckTest.d.ts → Moto.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{MotoTest.d.ts → MotoCheck.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{RecurringTest.d.ts → Recurring.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/Certifications/{RetailTest.d.ts → Retail.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{CreditTest.d.ts → Credit.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{DebitTest.d.ts → Debit.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{EbtTest.d.ts → Ebt.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{EcommerceTest.d.ts → Ecommerce.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{GiftTest.d.ts → Gift.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{PorticoManagementTokenTest.d.ts → PorticoManagementToken.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{RecurringTest.d.ts → Recurring.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/PorticoConnector/{ReportingTest.d.ts → Reporting.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{GetInformationCertificationTest.d.ts → GetInformationCertification.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayAccountCertificationTest.d.ts → ProPayAccountCertification.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayFundCertificationTest.d.ts → ProPayFundCertification.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayInNetworkTransactionCertificationTest.d.ts → ProPayInNetworkTransactionCertification.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/ProPayConnector/{GetInformationTest.d.ts → GetInformation.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/ProPayConnector/{ProPayAccountTest.d.ts → ProPayAccount.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/ProPayConnector/{ProPayFundsTest.d.ts → ProPayFunds.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/ProPayConnector/{ProPayInNetworkTransactionTest.d.ts → ProPayInNetworkTransaction.test.d.ts} +0 -0
- /package/lib/test/Integration/Gateways/Terminals/UPA/{UpaMicTest.d.ts → UpaMic.test.d.ts} +0 -0
- /package/lib/test/Integration/Services/{CheckServiceTest.d.ts → CheckService.test.d.ts} +0 -0
- /package/lib/test/Integration/Services/{CreditServiceTest.d.ts → CreditService.test.d.ts} +0 -0
- /package/lib/test/Integration/Services/{DebitServiceTest.d.ts → DebitService.test.d.ts} +0 -0
- /package/lib/test/Integration/Services/{EBTServiceTest.d.ts → EBTService.test.d.ts} +0 -0
- /package/lib/test/Unit/Builders/AuthorizationBuilder/{ValidationTest.d.ts → Validation.test.d.ts} +0 -0
- /package/lib/test/Unit/Builders/ReportBuilder/{ValidationTest.d.ts → Validation.test.d.ts} +0 -0
- /package/lib/test/Unit/Gateways/GpEcomConnector/{CreditTest.d.ts → Credit.test.d.ts} +0 -0
- /package/lib/test/Unit/Gateways/PorticoConnector/{InputValidationTest.d.ts → InputValidation.test.d.ts} +0 -0
|
@@ -1,15 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const ava_1 = __importDefault(require("ava"));
|
|
7
3
|
const src_1 = require("../../../../src");
|
|
8
4
|
const Data_1 = require("../../../Data");
|
|
9
5
|
const ThreeDSecureAsClient_1 = require("../ThreeDSecureAsClient");
|
|
10
6
|
const AcsResponse_1 = require("../AcsResponse");
|
|
11
|
-
const runSerially = true;
|
|
12
|
-
const test = runSerially ? ava_1.default.serial : ava_1.default;
|
|
13
7
|
const currency = "GBP";
|
|
14
8
|
const amount = "10.01";
|
|
15
9
|
const date = new Date();
|
|
@@ -42,12 +36,12 @@ browserData.challengWindowSize = src_1.ChallengeWindowSize.Windowed600x400;
|
|
|
42
36
|
browserData.timeZone = "0";
|
|
43
37
|
browserData.userAgent =
|
|
44
38
|
"Mozilla/5.0 (Windows NT 6.1; Win64, x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.110 Safari/537.36";
|
|
45
|
-
|
|
39
|
+
beforeAll(() => {
|
|
46
40
|
const config = Data_1.BaseGpApiTestConfig.gpApiSetupConfig(src_1.Channel.CardNotPresent);
|
|
47
41
|
src_1.ServicesContainer.configureService(config);
|
|
48
42
|
gatewayProvider = config.gatewayProvider;
|
|
49
43
|
});
|
|
50
|
-
test("frictionless full cycle v2", async (
|
|
44
|
+
test("frictionless full cycle v2", async () => {
|
|
51
45
|
const frictionlessSuccessfull3DSV2CardTests = {
|
|
52
46
|
"Frictionless v2.1": [
|
|
53
47
|
Data_1.GpApi3DSTestCards.CARD_AUTH_SUCCESSFUL_V2_1,
|
|
@@ -66,17 +60,17 @@ test("frictionless full cycle v2", async (t) => {
|
|
|
66
60
|
src_1.Secure3dStatus.SuccessAuthenticated,
|
|
67
61
|
],
|
|
68
62
|
};
|
|
69
|
-
|
|
63
|
+
for (const testCase of Object.keys(frictionlessSuccessfull3DSV2CardTests)) {
|
|
70
64
|
card.number = frictionlessSuccessfull3DSV2CardTests[testCase][0];
|
|
71
65
|
const secureEcom = await src_1.Secure3dService.checkEnrollment(card)
|
|
72
66
|
.withCurrency(currency)
|
|
73
67
|
.withAmount(amount)
|
|
74
68
|
.execute();
|
|
75
|
-
|
|
69
|
+
expect(secureEcom).toBeTruthy();
|
|
76
70
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
71
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
72
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
73
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
80
74
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
81
75
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(card, secureEcom)
|
|
82
76
|
.withAmount(amount)
|
|
@@ -88,32 +82,32 @@ test("frictionless full cycle v2", async (t) => {
|
|
|
88
82
|
.withOrderTransactionType(src_1.OrderTransactionType.GoodsServicePurchase)
|
|
89
83
|
.withBrowserData(browserData)
|
|
90
84
|
.execute();
|
|
91
|
-
|
|
92
|
-
|
|
85
|
+
expect(initAuth).toBeTruthy();
|
|
86
|
+
expect(frictionlessSuccessfull3DSV2CardTests[testCase][1]).toBe(initAuth instanceof src_1.ThreeDSecure && initAuth.status);
|
|
93
87
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
94
88
|
.withServerTransactionId(secureEcom.serverTransactionId)
|
|
95
89
|
.withAmount(amount)
|
|
96
90
|
.execute();
|
|
97
91
|
card.threeDSecure = secureEcom2;
|
|
98
92
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
99
|
-
|
|
100
|
-
|
|
93
|
+
expect(frictionlessSuccessfull3DSV2CardTests[testCase][1]).toBe(secureEcom2.status);
|
|
94
|
+
expect("YES").toBe(secureEcom2.liabilityShift);
|
|
101
95
|
}
|
|
102
96
|
const response = await card.verify().withCurrency(currency).execute();
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
97
|
+
expect(response).toBeTruthy();
|
|
98
|
+
expect("SUCCESS").toBe(response.responseCode);
|
|
99
|
+
expect("VERIFIED").toBe(response.responseMessage);
|
|
106
100
|
const transaction = await card
|
|
107
101
|
.charge(amount)
|
|
108
102
|
.withCurrency(currency)
|
|
109
103
|
.execute();
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
104
|
+
expect(transaction).toBeTruthy();
|
|
105
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
106
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
113
107
|
}
|
|
114
|
-
}
|
|
108
|
+
}
|
|
115
109
|
});
|
|
116
|
-
test("frictionless full cycle v2 - failed", async (
|
|
110
|
+
test("frictionless full cycle v2 - failed", async () => {
|
|
117
111
|
const frictionlessSuccessfull3DSV2CardTests = {
|
|
118
112
|
"Frictionless failed 1": [
|
|
119
113
|
Data_1.GpApi3DSTestCards.CARD_AUTH_ATTEMPTED_BUT_NOT_SUCCESSFUL_V2_1,
|
|
@@ -148,17 +142,17 @@ test("frictionless full cycle v2 - failed", async (t) => {
|
|
|
148
142
|
src_1.Secure3dStatus.Failed,
|
|
149
143
|
],
|
|
150
144
|
};
|
|
151
|
-
|
|
145
|
+
for (const testCase of Object.keys(frictionlessSuccessfull3DSV2CardTests)) {
|
|
152
146
|
card.number = frictionlessSuccessfull3DSV2CardTests[testCase][0];
|
|
153
147
|
const secureEcom = await src_1.Secure3dService.checkEnrollment(card)
|
|
154
148
|
.withCurrency(currency)
|
|
155
149
|
.withAmount(amount)
|
|
156
150
|
.execute();
|
|
157
|
-
|
|
151
|
+
expect(secureEcom).toBeTruthy();
|
|
158
152
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
153
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
154
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
155
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
162
156
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
163
157
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(card, secureEcom)
|
|
164
158
|
.withAmount(amount)
|
|
@@ -169,8 +163,8 @@ test("frictionless full cycle v2 - failed", async (t) => {
|
|
|
169
163
|
.withAddress(shippingAddress, src_1.AddressType.Shipping)
|
|
170
164
|
.withBrowserData(browserData)
|
|
171
165
|
.execute();
|
|
172
|
-
|
|
173
|
-
|
|
166
|
+
expect(initAuth).toBeTruthy();
|
|
167
|
+
expect(frictionlessSuccessfull3DSV2CardTests[testCase][1]).toBe(initAuth instanceof src_1.ThreeDSecure && initAuth.status);
|
|
174
168
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
175
169
|
.withServerTransactionId(secureEcom.serverTransactionId)
|
|
176
170
|
.withAmount(amount)
|
|
@@ -181,20 +175,20 @@ test("frictionless full cycle v2 - failed", async (t) => {
|
|
|
181
175
|
: "NO";
|
|
182
176
|
card.threeDSecure = secureEcom2;
|
|
183
177
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
184
|
-
|
|
185
|
-
|
|
178
|
+
expect(frictionlessSuccessfull3DSV2CardTests[testCase][1]).toBe(secureEcom2.status);
|
|
179
|
+
expect(liabilityShift).toBe(secureEcom2.liabilityShift);
|
|
186
180
|
}
|
|
187
181
|
const transaction = await card
|
|
188
182
|
.charge(amount)
|
|
189
183
|
.withCurrency(currency)
|
|
190
184
|
.execute();
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
185
|
+
expect(transaction).toBeTruthy();
|
|
186
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
187
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
194
188
|
}
|
|
195
|
-
}
|
|
189
|
+
}
|
|
196
190
|
});
|
|
197
|
-
test("card holder enrolled - challenge required - v2", async (
|
|
191
|
+
test("card holder enrolled - challenge required - v2", async () => {
|
|
198
192
|
const challengeSuccessful3DSV2CardTests = {
|
|
199
193
|
"Challenge v2.1": [
|
|
200
194
|
Data_1.GpApi3DSTestCards.CARD_CHALLENGE_REQUIRED_V2_1,
|
|
@@ -205,17 +199,17 @@ test("card holder enrolled - challenge required - v2", async (t) => {
|
|
|
205
199
|
src_1.Secure3dStatus.SuccessAuthenticated,
|
|
206
200
|
],
|
|
207
201
|
};
|
|
208
|
-
|
|
202
|
+
for (const testCase of Object.keys(challengeSuccessful3DSV2CardTests)) {
|
|
209
203
|
card.number = challengeSuccessful3DSV2CardTests[testCase][0];
|
|
210
204
|
const secureEcom = await src_1.Secure3dService.checkEnrollment(card)
|
|
211
205
|
.withCurrency(currency)
|
|
212
206
|
.withAmount(amount)
|
|
213
207
|
.execute();
|
|
214
|
-
|
|
208
|
+
expect(secureEcom).toBeTruthy();
|
|
215
209
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
210
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
211
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
212
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
219
213
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
220
214
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(card, secureEcom)
|
|
221
215
|
.withAmount(amount)
|
|
@@ -226,49 +220,49 @@ test("card holder enrolled - challenge required - v2", async (t) => {
|
|
|
226
220
|
.withAddress(shippingAddress, src_1.AddressType.Shipping)
|
|
227
221
|
.withBrowserData(browserData)
|
|
228
222
|
.execute();
|
|
229
|
-
|
|
223
|
+
expect(initAuth).toBeTruthy();
|
|
230
224
|
if (initAuth instanceof src_1.ThreeDSecure) {
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
225
|
+
expect(src_1.Secure3dStatus.ChallengeRequired).toBe(initAuth.status);
|
|
226
|
+
expect(initAuth.issuerAcsUrl).toBeTruthy();
|
|
227
|
+
expect(initAuth.payerAuthenticationRequest).toBeTruthy();
|
|
234
228
|
const authClient = new ThreeDSecureAsClient_1.ThreeDSecureAcsClient(secureEcom.issuerAcsUrl);
|
|
235
229
|
authClient.setGatewayProvider(gatewayProvider);
|
|
236
230
|
const authResponse = await authClient.authenticate_v2(initAuth);
|
|
237
231
|
if (authResponse instanceof AcsResponse_1.AcsResponse) {
|
|
238
|
-
|
|
239
|
-
|
|
232
|
+
expect(authResponse.getStatus()).toBe(true);
|
|
233
|
+
expect(authResponse.getMerchantData()).toBeTruthy();
|
|
240
234
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
241
235
|
.withServerTransactionId(authResponse.getMerchantData())
|
|
242
236
|
.withAmount(amount)
|
|
243
237
|
.execute();
|
|
244
238
|
card.threeDSecure = secureEcom2;
|
|
245
239
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
246
|
-
|
|
247
|
-
|
|
240
|
+
expect(challengeSuccessful3DSV2CardTests[testCase][1]).toBe(secureEcom2.status);
|
|
241
|
+
expect("YES").toBe(secureEcom2.liabilityShift);
|
|
248
242
|
}
|
|
249
243
|
const transaction = await card
|
|
250
244
|
.charge(amount)
|
|
251
245
|
.withCurrency(currency)
|
|
252
246
|
.execute();
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
247
|
+
expect(transaction).toBeTruthy();
|
|
248
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
249
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
256
250
|
}
|
|
257
251
|
}
|
|
258
252
|
}
|
|
259
|
-
}
|
|
253
|
+
}
|
|
260
254
|
});
|
|
261
|
-
test("card holder enrolled - challenge required - get results failed - v2", async (
|
|
255
|
+
test("card holder enrolled - challenge required - get results failed - v2", async () => {
|
|
262
256
|
card.number = Data_1.GpApi3DSTestCards.CARD_CHALLENGE_REQUIRED_V2_2;
|
|
263
257
|
const secureEcom = await src_1.Secure3dService.checkEnrollment(card)
|
|
264
258
|
.withCurrency(currency)
|
|
265
259
|
.withAmount(amount)
|
|
266
260
|
.execute();
|
|
267
|
-
|
|
261
|
+
expect(secureEcom).toBeTruthy();
|
|
268
262
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
263
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
264
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
265
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
272
266
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
273
267
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(card, secureEcom)
|
|
274
268
|
.withAmount(amount)
|
|
@@ -279,23 +273,23 @@ test("card holder enrolled - challenge required - get results failed - v2", asyn
|
|
|
279
273
|
.withAddress(shippingAddress, src_1.AddressType.Shipping)
|
|
280
274
|
.withBrowserData(browserData)
|
|
281
275
|
.execute();
|
|
282
|
-
|
|
276
|
+
expect(initAuth).toBeTruthy();
|
|
283
277
|
if (initAuth instanceof src_1.ThreeDSecure) {
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
278
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(initAuth.enrolled);
|
|
279
|
+
expect(src_1.Secure3dStatus.ChallengeRequired).toBe(initAuth.status);
|
|
280
|
+
expect(initAuth.issuerAcsUrl).toBeTruthy();
|
|
281
|
+
expect(initAuth.payerAuthenticationRequest).toBeTruthy();
|
|
288
282
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
289
283
|
.withServerTransactionId(initAuth.serverTransactionId)
|
|
290
284
|
.withAmount(amount)
|
|
291
285
|
.execute();
|
|
292
286
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
293
|
-
|
|
287
|
+
expect(src_1.Secure3dStatus.ChallengeRequired).toBe(secureEcom2.status);
|
|
294
288
|
}
|
|
295
289
|
}
|
|
296
290
|
}
|
|
297
291
|
});
|
|
298
|
-
test("full cycle with card tokenization v2", async (
|
|
292
|
+
test("full cycle with card tokenization v2", async () => {
|
|
299
293
|
card.number = Data_1.GpApi3DSTestCards.CARD_AUTH_SUCCESSFUL_V2_1;
|
|
300
294
|
const response = await card.tokenize().execute();
|
|
301
295
|
const tokenizedCard = new src_1.CreditCardData();
|
|
@@ -305,11 +299,11 @@ test("full cycle with card tokenization v2", async (t) => {
|
|
|
305
299
|
.withCurrency(currency)
|
|
306
300
|
.withAmount(amount)
|
|
307
301
|
.execute();
|
|
308
|
-
|
|
302
|
+
expect(secureEcom).toBeTruthy();
|
|
309
303
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
304
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
305
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
306
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
313
307
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
314
308
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(card, secureEcom)
|
|
315
309
|
.withAmount(amount)
|
|
@@ -321,43 +315,43 @@ test("full cycle with card tokenization v2", async (t) => {
|
|
|
321
315
|
.withOrderTransactionType(src_1.OrderTransactionType.GoodsServicePurchase)
|
|
322
316
|
.withBrowserData(browserData)
|
|
323
317
|
.execute();
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
318
|
+
expect(initAuth).toBeTruthy();
|
|
319
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(secureEcom.status);
|
|
320
|
+
expect("YES").toBe(secureEcom.liabilityShift);
|
|
327
321
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
328
322
|
.withServerTransactionId(secureEcom.serverTransactionId)
|
|
329
323
|
.withAmount(amount)
|
|
330
324
|
.execute();
|
|
331
325
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
332
|
-
|
|
333
|
-
|
|
326
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(secureEcom2.status);
|
|
327
|
+
expect("YES").toBe(secureEcom2.liabilityShift);
|
|
334
328
|
}
|
|
335
329
|
tokenizedCard.threeDSecure = secureEcom2;
|
|
336
330
|
const response = await card.verify().withCurrency(currency).execute();
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
331
|
+
expect(response).toBeTruthy();
|
|
332
|
+
expect("SUCCESS").toBe(response.responseCode);
|
|
333
|
+
expect("VERIFIED").toBe(response.responseMessage);
|
|
340
334
|
const transaction = await card
|
|
341
335
|
.charge(amount)
|
|
342
336
|
.withCurrency(currency)
|
|
343
337
|
.execute();
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
338
|
+
expect(transaction).toBeTruthy();
|
|
339
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
340
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
347
341
|
}
|
|
348
342
|
});
|
|
349
|
-
test("frictionless full cycle - different amount - v2", async (
|
|
343
|
+
test("frictionless full cycle - different amount - v2", async () => {
|
|
350
344
|
card.number = Data_1.GpApi3DSTestCards.CARD_AUTH_SUCCESSFUL_V2_1;
|
|
351
345
|
const secureEcom = await src_1.Secure3dService.checkEnrollment(card)
|
|
352
346
|
.withCurrency(currency)
|
|
353
347
|
.withAmount(amount)
|
|
354
348
|
.execute();
|
|
355
|
-
|
|
349
|
+
expect(secureEcom).toBeTruthy();
|
|
356
350
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
351
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
352
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
353
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
354
|
+
expect(amount).toBe(String(secureEcom.amount));
|
|
361
355
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
362
356
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(card, secureEcom)
|
|
363
357
|
.withAmount(9)
|
|
@@ -368,41 +362,41 @@ test("frictionless full cycle - different amount - v2", async (t) => {
|
|
|
368
362
|
.withAddress(shippingAddress, src_1.AddressType.Shipping)
|
|
369
363
|
.withBrowserData(browserData)
|
|
370
364
|
.execute();
|
|
371
|
-
|
|
365
|
+
expect(initAuth).toBeTruthy();
|
|
372
366
|
if (initAuth instanceof src_1.ThreeDSecure) {
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
367
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(initAuth.status);
|
|
368
|
+
expect(amount).toBe(String(initAuth.getAmount()));
|
|
369
|
+
expect("YES").toBe(initAuth.liabilityShift);
|
|
376
370
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
377
371
|
.withServerTransactionId(initAuth.serverTransactionId)
|
|
378
372
|
.execute();
|
|
379
373
|
card.threeDSecure = initAuth;
|
|
380
374
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
375
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(secureEcom2.status);
|
|
376
|
+
expect("YES").toBe(secureEcom2.liabilityShift);
|
|
377
|
+
expect(amount).toBe(String(secureEcom2.getAmount()));
|
|
384
378
|
}
|
|
385
379
|
const transaction = await card
|
|
386
380
|
.charge(amount)
|
|
387
381
|
.withCurrency(currency)
|
|
388
382
|
.execute();
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
383
|
+
expect(transaction).toBeTruthy();
|
|
384
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
385
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
392
386
|
}
|
|
393
387
|
}
|
|
394
388
|
});
|
|
395
|
-
test("card holder enrolled - challenge required - v2 duplicate acs request", async (
|
|
389
|
+
test("card holder enrolled - challenge required - v2 duplicate acs request", async () => {
|
|
396
390
|
card.number = Data_1.GpApi3DSTestCards.CARD_CHALLENGE_REQUIRED_V2_2;
|
|
397
391
|
const secureEcom = await src_1.Secure3dService.checkEnrollment(card)
|
|
398
392
|
.withCurrency(currency)
|
|
399
393
|
.withAmount(amount)
|
|
400
394
|
.execute();
|
|
401
|
-
|
|
395
|
+
expect(secureEcom).toBeTruthy();
|
|
402
396
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
397
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
398
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
399
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
406
400
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
407
401
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(card, secureEcom)
|
|
408
402
|
.withAmount(amount)
|
|
@@ -413,45 +407,45 @@ test("card holder enrolled - challenge required - v2 duplicate acs request", asy
|
|
|
413
407
|
.withAddress(shippingAddress, src_1.AddressType.Shipping)
|
|
414
408
|
.withBrowserData(browserData)
|
|
415
409
|
.execute();
|
|
416
|
-
|
|
410
|
+
expect(initAuth).toBeTruthy();
|
|
417
411
|
if (initAuth instanceof src_1.ThreeDSecure) {
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
412
|
+
expect(src_1.Secure3dStatus.ChallengeRequired).toBe(initAuth.status);
|
|
413
|
+
expect(initAuth.issuerAcsUrl).toBeTruthy();
|
|
414
|
+
expect(initAuth.payerAuthenticationRequest).toBeTruthy();
|
|
421
415
|
const authClient = new ThreeDSecureAsClient_1.ThreeDSecureAcsClient(secureEcom.issuerAcsUrl);
|
|
422
416
|
authClient.setGatewayProvider(gatewayProvider);
|
|
423
417
|
const authResponse = await authClient.authenticate_v2(initAuth);
|
|
424
418
|
if (authResponse instanceof AcsResponse_1.AcsResponse) {
|
|
425
|
-
|
|
426
|
-
|
|
419
|
+
expect(authResponse.getStatus()).toBe(true);
|
|
420
|
+
expect(authResponse.getMerchantData()).toBeTruthy();
|
|
427
421
|
}
|
|
428
422
|
const authClient2 = new ThreeDSecureAsClient_1.ThreeDSecureAcsClient(secureEcom.issuerAcsUrl);
|
|
429
423
|
authClient2.setGatewayProvider(gatewayProvider);
|
|
430
424
|
const authResponse2 = await authClient2.authenticate_v2(initAuth);
|
|
431
425
|
if (authResponse2 instanceof AcsResponse_1.AcsResponse) {
|
|
432
|
-
|
|
433
|
-
|
|
426
|
+
expect(authResponse2.getStatus()).toBe(true);
|
|
427
|
+
expect(authResponse2.getMerchantData()).toBeTruthy();
|
|
434
428
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
435
429
|
.withServerTransactionId(authResponse2.getMerchantData())
|
|
436
430
|
.withAmount(amount)
|
|
437
431
|
.execute();
|
|
438
432
|
card.threeDSecure = secureEcom2;
|
|
439
433
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
440
|
-
|
|
441
|
-
|
|
434
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(secureEcom2.status);
|
|
435
|
+
expect("YES").toBe(secureEcom2.liabilityShift);
|
|
442
436
|
}
|
|
443
437
|
const transaction = await card
|
|
444
438
|
.charge(amount)
|
|
445
439
|
.withCurrency(currency)
|
|
446
440
|
.execute();
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
441
|
+
expect(transaction).toBeTruthy();
|
|
442
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
443
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
450
444
|
}
|
|
451
445
|
}
|
|
452
446
|
}
|
|
453
447
|
});
|
|
454
|
-
test("credit sale tokenized with stored credentials recurring", async (
|
|
448
|
+
test("credit sale tokenized with stored credentials recurring", async () => {
|
|
455
449
|
card.number = Data_1.GpApi3DSTestCards.CARD_AUTH_SUCCESSFUL_V2_1;
|
|
456
450
|
card.entryMethod = src_1.ManualEntryMethod.MOTO;
|
|
457
451
|
const storedCredentials = new src_1.StoredCredential();
|
|
@@ -467,11 +461,11 @@ test("credit sale tokenized with stored credentials recurring", async (t) => {
|
|
|
467
461
|
.withAmount(amount)
|
|
468
462
|
.withAuthenticationSource(src_1.AuthenticationSource.Browser)
|
|
469
463
|
.execute();
|
|
470
|
-
|
|
464
|
+
expect(secureEcom).toBeTruthy();
|
|
471
465
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
466
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
467
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
468
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
475
469
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
476
470
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(tokenizedCard, secureEcom)
|
|
477
471
|
.withAmount(amount)
|
|
@@ -482,51 +476,51 @@ test("credit sale tokenized with stored credentials recurring", async (t) => {
|
|
|
482
476
|
.withAddress(shippingAddress, src_1.AddressType.Shipping)
|
|
483
477
|
.withBrowserData(browserData)
|
|
484
478
|
.execute();
|
|
485
|
-
|
|
479
|
+
expect(initAuth).toBeTruthy();
|
|
486
480
|
if (initAuth instanceof src_1.ThreeDSecure) {
|
|
487
|
-
|
|
481
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(initAuth.status);
|
|
488
482
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
489
483
|
.withServerTransactionId(secureEcom.serverTransactionId)
|
|
490
484
|
.withAmount(amount)
|
|
491
485
|
.execute();
|
|
492
486
|
tokenizedCard.threeDSecure = secureEcom2;
|
|
493
487
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
494
|
-
|
|
495
|
-
|
|
488
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(secureEcom2.status);
|
|
489
|
+
expect("YES").toBe(secureEcom2.liabilityShift);
|
|
496
490
|
}
|
|
497
491
|
const transaction = await tokenizedCard
|
|
498
492
|
.charge(amount)
|
|
499
493
|
.withCurrency(currency)
|
|
500
494
|
.execute();
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
495
|
+
expect(transaction).toBeTruthy();
|
|
496
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
497
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
498
|
+
expect(transaction.cardBrandTransactionId).toBeTruthy();
|
|
505
499
|
const recurringPayment = await tokenizedCard
|
|
506
500
|
.charge(amount)
|
|
507
501
|
.withCurrency(currency)
|
|
508
502
|
.withStoredCredentials(storedCredentials)
|
|
509
503
|
.withCardBrandStorage(src_1.StoredCredentialInitiator.Merchant, transaction.cardBrandTransactionId)
|
|
510
504
|
.execute();
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
505
|
+
expect(recurringPayment).toBeTruthy();
|
|
506
|
+
expect("SUCCESS").toBe(recurringPayment.responseCode);
|
|
507
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(recurringPayment.responseMessage);
|
|
508
|
+
expect(recurringPayment.cardBrandTransactionId).toBeTruthy();
|
|
515
509
|
}
|
|
516
510
|
}
|
|
517
511
|
});
|
|
518
|
-
test("frictionless full cycle - v2 - with mobile SDK", async (
|
|
512
|
+
test("frictionless full cycle - v2 - with mobile SDK", async () => {
|
|
519
513
|
card.number = Data_1.GpApi3DSTestCards.CARD_AUTH_SUCCESSFUL_V2_2;
|
|
520
514
|
const secureEcom = await src_1.Secure3dService.checkEnrollment(card)
|
|
521
515
|
.withCurrency(currency)
|
|
522
516
|
.withAmount(amount)
|
|
523
517
|
.withAuthenticationSource(src_1.AuthenticationSource.Browser)
|
|
524
518
|
.execute();
|
|
525
|
-
|
|
519
|
+
expect(secureEcom).toBeTruthy();
|
|
526
520
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
521
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
522
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
523
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
530
524
|
const mobileData = new src_1.MobileData();
|
|
531
525
|
mobileData.encodedData =
|
|
532
526
|
"ew0KCSJEViI6ICIxLjAiLA0KCSJERCI6IHsNCgkJIkMwMDEiOiAiQW5kcm9pZCIsDQoJCSJDMDAyIjogIkhUQyBPbmVfTTgiLA0KCQkiQzAwNCI6ICI1LjAuMSIsDQoJCSJDMDA1IjogImVuX1VTIiwNCgkJIkMwMDYiOiAiRWFzdGVybiBTdGFuZGFyZCBUaW1lIiwNCgkJIkMwMDciOiAiMDY3OTc5MDMtZmI2MS00MWVkLTk0YzItNGQyYjc0ZTI3ZDE4IiwNCgkJIkMwMDkiOiAiSm9obidzIEFuZHJvaWQgRGV2aWNlIg0KCX0sDQoJIkRQTkEiOiB7DQoJCSJDMDEwIjogIlJFMDEiLA0KCQkiQzAxMSI6ICJSRTAzIg0KCX0sDQoJIlNXIjogWyJTVzAxIiwgIlNXMDQiXQ0KfQ0K";
|
|
@@ -553,36 +547,36 @@ test("frictionless full cycle - v2 - with mobile SDK", async (t) => {
|
|
|
553
547
|
.withOrderTransactionType(src_1.OrderTransactionType.GoodsServicePurchase)
|
|
554
548
|
.withMobileData(mobileData)
|
|
555
549
|
.execute();
|
|
556
|
-
|
|
550
|
+
expect(initAuth).toBeTruthy();
|
|
557
551
|
if (initAuth instanceof src_1.ThreeDSecure) {
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
552
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(initAuth.status);
|
|
553
|
+
expect(initAuth.issuerAcsUrl).toBeTruthy();
|
|
554
|
+
expect(initAuth.payerAuthenticationRequest).toBeTruthy();
|
|
555
|
+
expect(initAuth.acsTransactionId).toBeTruthy();
|
|
556
|
+
expect(initAuth.providerServerTransRef).toBeTruthy();
|
|
557
|
+
expect(initAuth.acsReferenceNumber).toBeTruthy();
|
|
558
|
+
expect("05").toBe(String(initAuth.eci));
|
|
559
|
+
expect("2.2.0").toBe(initAuth.messageVersion);
|
|
566
560
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
567
561
|
.withServerTransactionId(secureEcom.serverTransactionId)
|
|
568
562
|
.withAmount(amount)
|
|
569
563
|
.execute();
|
|
570
564
|
card.threeDSecure = secureEcom2;
|
|
571
565
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
572
|
-
|
|
573
|
-
|
|
566
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(secureEcom2.status);
|
|
567
|
+
expect("YES").toBe(secureEcom2.liabilityShift);
|
|
574
568
|
}
|
|
575
569
|
const transaction = await card
|
|
576
570
|
.charge(amount)
|
|
577
571
|
.withCurrency(currency)
|
|
578
572
|
.execute();
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
573
|
+
expect(transaction).toBeTruthy();
|
|
574
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
575
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
582
576
|
}
|
|
583
577
|
}
|
|
584
578
|
});
|
|
585
|
-
test("decoupled auth", async (
|
|
579
|
+
test("decoupled auth", async () => {
|
|
586
580
|
card.number = Data_1.GpApi3DSTestCards.CARD_AUTH_SUCCESSFUL_V2_1;
|
|
587
581
|
const response = await card.tokenize().execute();
|
|
588
582
|
const tokenizedCard = new src_1.CreditCardData();
|
|
@@ -593,11 +587,11 @@ test("decoupled auth", async (t) => {
|
|
|
593
587
|
.withAmount(amount)
|
|
594
588
|
.withDecoupledNotificationUrl("https://www.example.com/decoupledNotification")
|
|
595
589
|
.execute();
|
|
596
|
-
|
|
590
|
+
expect(secureEcom).toBeTruthy();
|
|
597
591
|
if (!(secureEcom instanceof src_1.Transaction)) {
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
592
|
+
expect(src_1.Secure3dStatus.Enrolled).toBe(secureEcom?.enrolled);
|
|
593
|
+
expect(src_1.Secure3dVersion.TWO).toBe(secureEcom.getVersion());
|
|
594
|
+
expect(src_1.Secure3dStatus.Available).toBe(secureEcom.status);
|
|
601
595
|
const formatedDate = `${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`;
|
|
602
596
|
const initAuth = await src_1.Secure3dService.initiateAuthentication(tokenizedCard, secureEcom)
|
|
603
597
|
.withAmount(amount)
|
|
@@ -611,10 +605,10 @@ test("decoupled auth", async (t) => {
|
|
|
611
605
|
.withDecoupledFlowTimeout(9001)
|
|
612
606
|
.withDecoupledNotificationUrl("https://www.example.com/decoupledNotification")
|
|
613
607
|
.execute();
|
|
614
|
-
|
|
608
|
+
expect(initAuth).toBeTruthy();
|
|
615
609
|
if (initAuth instanceof src_1.ThreeDSecure) {
|
|
616
|
-
|
|
617
|
-
|
|
610
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(initAuth.status);
|
|
611
|
+
expect("YES").toBe(initAuth.liabilityShift);
|
|
618
612
|
}
|
|
619
613
|
const secureEcom2 = await src_1.Secure3dService.getAuthenticationData()
|
|
620
614
|
.withServerTransactionId(secureEcom.serverTransactionId)
|
|
@@ -622,28 +616,28 @@ test("decoupled auth", async (t) => {
|
|
|
622
616
|
.execute();
|
|
623
617
|
tokenizedCard.threeDSecure = secureEcom2;
|
|
624
618
|
if (secureEcom2 instanceof src_1.ThreeDSecure) {
|
|
625
|
-
|
|
626
|
-
|
|
619
|
+
expect(src_1.Secure3dStatus.SuccessAuthenticated).toBe(secureEcom2.status);
|
|
620
|
+
expect("YES").toBe(secureEcom2.liabilityShift);
|
|
627
621
|
}
|
|
628
622
|
const transaction = await tokenizedCard
|
|
629
623
|
.charge(amount)
|
|
630
624
|
.withCurrency(currency)
|
|
631
625
|
.execute();
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
626
|
+
expect(transaction).toBeTruthy();
|
|
627
|
+
expect("SUCCESS").toBe(transaction.responseCode);
|
|
628
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(transaction.responseMessage);
|
|
629
|
+
expect(transaction.cardBrandTransactionId).toBeTruthy();
|
|
636
630
|
}
|
|
637
631
|
});
|
|
638
|
-
test("exemption sale transaction", async (
|
|
632
|
+
test("exemption sale transaction", async () => {
|
|
639
633
|
card.number = Data_1.GpApi3DSTestCards.CARD_CHALLENGE_REQUIRED_V2_2;
|
|
640
634
|
const threeDS = new src_1.ThreeDSecure();
|
|
641
635
|
threeDS.exemptStatus = src_1.ExemptStatus.LowValue;
|
|
642
636
|
card.threeDSecure = threeDS;
|
|
643
637
|
const response = await card.charge(amount).withCurrency(currency).execute();
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
638
|
+
expect(response).toBeTruthy();
|
|
639
|
+
expect("SUCCESS").toBe(response.responseCode);
|
|
640
|
+
expect(src_1.TransactionStatus.CAPTURED).toBe(response.responseMessage);
|
|
647
641
|
});
|
|
648
|
-
|
|
649
|
-
//# sourceMappingURL=
|
|
642
|
+
afterAll(() => Data_1.BaseGpApiTestConfig.resetGpApiConfig());
|
|
643
|
+
//# sourceMappingURL=3DSecure.test.js.map
|