test-payment-methods.ts 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. import { PaymentMethodHandler } from '@vendure/core';
  2. import { LanguageCode } from '../graphql/generated-e2e-admin-types';
  3. export const testSuccessfulPaymentMethod = new PaymentMethodHandler({
  4. code: 'test-payment-method',
  5. description: [{ languageCode: LanguageCode.en, value: 'Test Payment Method' }],
  6. args: {},
  7. createPayment: (ctx, order, amount, args, metadata) => {
  8. return {
  9. amount,
  10. state: 'Settled',
  11. transactionId: '12345',
  12. metadata: { public: metadata },
  13. };
  14. },
  15. settlePayment: () => ({
  16. success: true,
  17. }),
  18. });
  19. export const onTransitionSpy = jest.fn();
  20. /**
  21. * A two-stage (authorize, capture) payment method, with no createRefund method.
  22. */
  23. export const twoStagePaymentMethod = new PaymentMethodHandler({
  24. code: 'authorize-only-payment-method',
  25. description: [{ languageCode: LanguageCode.en, value: 'Test Payment Method' }],
  26. args: {},
  27. createPayment: (ctx, order, amount, args, metadata) => {
  28. return {
  29. amount,
  30. state: 'Authorized',
  31. transactionId: '12345',
  32. metadata: { public: metadata },
  33. };
  34. },
  35. settlePayment: () => {
  36. return {
  37. success: true,
  38. metadata: {
  39. moreData: 42,
  40. },
  41. };
  42. },
  43. onStateTransitionStart: (fromState, toState, data) => {
  44. onTransitionSpy(fromState, toState, data);
  45. },
  46. });
  47. /**
  48. * A method that can be used to pay for only part of the order (allowing us to test multiple payments
  49. * per order).
  50. */
  51. export const partialPaymentMethod = new PaymentMethodHandler({
  52. code: 'partial-payment-method',
  53. description: [{ languageCode: LanguageCode.en, value: 'Partial Payment Method' }],
  54. args: {},
  55. createPayment: (ctx, order, amount, args, metadata) => {
  56. return {
  57. amount: metadata.amount,
  58. state: 'Settled',
  59. transactionId: '12345',
  60. metadata: { public: metadata },
  61. };
  62. },
  63. settlePayment: () => {
  64. return {
  65. success: true,
  66. };
  67. },
  68. });
  69. /**
  70. * A payment method which includes a createRefund method.
  71. */
  72. export const singleStageRefundablePaymentMethod = new PaymentMethodHandler({
  73. code: 'single-stage-refundable-payment-method',
  74. description: [{ languageCode: LanguageCode.en, value: 'Test Payment Method' }],
  75. args: {},
  76. createPayment: (ctx, order, amount, args, metadata) => {
  77. return {
  78. amount,
  79. state: 'Settled',
  80. transactionId: '12345',
  81. metadata,
  82. };
  83. },
  84. settlePayment: () => {
  85. return { success: true };
  86. },
  87. createRefund: (ctx, input, amount, order, payment, args) => {
  88. return {
  89. amount,
  90. state: 'Settled',
  91. transactionId: 'abc123',
  92. };
  93. },
  94. });
  95. /**
  96. * A payment method where calling `settlePayment` always fails.
  97. */
  98. export const failsToSettlePaymentMethod = new PaymentMethodHandler({
  99. code: 'fails-to-settle-payment-method',
  100. description: [{ languageCode: LanguageCode.en, value: 'Test Payment Method' }],
  101. args: {},
  102. createPayment: (ctx, order, amount, args, metadata) => {
  103. return {
  104. amount,
  105. state: 'Authorized',
  106. transactionId: '12345',
  107. metadata: {
  108. privateCreatePaymentData: 'secret',
  109. public: {
  110. publicCreatePaymentData: 'public',
  111. },
  112. },
  113. };
  114. },
  115. settlePayment: () => {
  116. return {
  117. success: false,
  118. errorMessage: 'Something went horribly wrong',
  119. metadata: {
  120. privateSettlePaymentData: 'secret',
  121. public: {
  122. publicSettlePaymentData: 'public',
  123. },
  124. },
  125. };
  126. },
  127. });
  128. export const testFailingPaymentMethod = new PaymentMethodHandler({
  129. code: 'test-failing-payment-method',
  130. description: [{ languageCode: LanguageCode.en, value: 'Test Failing Payment Method' }],
  131. args: {},
  132. createPayment: (ctx, order, amount, args, metadata) => {
  133. return {
  134. amount,
  135. state: 'Declined',
  136. errorMessage: 'Insufficient funds',
  137. metadata: { public: metadata },
  138. };
  139. },
  140. settlePayment: () => ({
  141. success: true,
  142. }),
  143. });
  144. export const testErrorPaymentMethod = new PaymentMethodHandler({
  145. code: 'test-error-payment-method',
  146. description: [{ languageCode: LanguageCode.en, value: 'Test Error Payment Method' }],
  147. args: {},
  148. createPayment: (ctx, order, amount, args, metadata) => {
  149. return {
  150. amount,
  151. state: 'Error',
  152. errorMessage: 'Something went horribly wrong',
  153. metadata,
  154. };
  155. },
  156. settlePayment: () => ({
  157. success: true,
  158. }),
  159. });