stripe-dev-server.ts 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. import { AdminUiPlugin } from '@vendure/admin-ui-plugin';
  2. import {
  3. ChannelService,
  4. DefaultLogger,
  5. LanguageCode,
  6. Logger,
  7. LogLevel,
  8. mergeConfig,
  9. OrderService,
  10. RequestContext,
  11. } from '@vendure/core';
  12. import { createTestEnvironment, registerInitializer, SqljsInitializer, testConfig } from '@vendure/testing';
  13. import gql from 'graphql-tag';
  14. import path from 'path';
  15. import { initialData } from '../../../e2e-common/e2e-initial-data';
  16. import { StripePlugin } from '../src/stripe';
  17. import { stripePaymentMethodHandler } from '../src/stripe/stripe.handler';
  18. /* eslint-disable */
  19. import { CREATE_PAYMENT_METHOD } from './graphql/admin-queries';
  20. import {
  21. CreatePaymentMethodMutation,
  22. CreatePaymentMethodMutationVariables,
  23. } from './graphql/generated-admin-types';
  24. import { AddItemToOrderMutation, AddItemToOrderMutationVariables } from './graphql/generated-shop-types';
  25. import { ADD_ITEM_TO_ORDER } from './graphql/shop-queries';
  26. import { CREATE_STRIPE_PAYMENT_INTENT, setShipping } from './payment-helpers';
  27. import { StripeCheckoutTestPlugin } from './stripe-checkout-test.plugin';
  28. export let clientSecret: string;
  29. /**
  30. * The actual starting of the dev server
  31. */
  32. (async () => {
  33. require('dotenv').config();
  34. registerInitializer('sqljs', new SqljsInitializer(path.join(__dirname, '__data__')));
  35. const config = mergeConfig(testConfig, {
  36. plugins: [
  37. ...testConfig.plugins,
  38. AdminUiPlugin.init({
  39. route: 'admin',
  40. port: 5001,
  41. }),
  42. StripePlugin.init({}),
  43. StripeCheckoutTestPlugin,
  44. ],
  45. logger: new DefaultLogger({ level: LogLevel.Debug }),
  46. });
  47. const { server, shopClient, adminClient } = createTestEnvironment(config as any);
  48. await server.init({
  49. initialData,
  50. productsCsvPath: path.join(__dirname, 'fixtures/e2e-products-minimal.csv'),
  51. customerCount: 1,
  52. });
  53. // Create method
  54. await adminClient.asSuperAdmin();
  55. await adminClient.query<CreatePaymentMethodMutation, CreatePaymentMethodMutationVariables>(
  56. CREATE_PAYMENT_METHOD,
  57. {
  58. input: {
  59. code: 'stripe-payment-method',
  60. enabled: true,
  61. translations: [
  62. {
  63. name: 'Stripe',
  64. description: 'This is a Stripe test payment method',
  65. languageCode: LanguageCode.en,
  66. },
  67. ],
  68. handler: {
  69. code: stripePaymentMethodHandler.code,
  70. arguments: [
  71. { name: 'apiKey', value: process.env.STRIPE_APIKEY! },
  72. { name: 'webhookSecret', value: process.env.STRIPE_WEBHOOK_SECRET! },
  73. ],
  74. },
  75. },
  76. },
  77. );
  78. // Prepare order for payment
  79. await shopClient.asUserWithCredentials('hayden.zieme12@hotmail.com', 'test');
  80. await shopClient.query<AddItemToOrderMutation, AddItemToOrderMutationVariables>(ADD_ITEM_TO_ORDER, {
  81. productVariantId: 'T_1',
  82. quantity: 1,
  83. });
  84. const ctx = new RequestContext({
  85. apiType: 'admin',
  86. isAuthorized: true,
  87. authorizedAsOwnerOnly: false,
  88. channel: await server.app.get(ChannelService).getDefaultChannel(),
  89. });
  90. await server.app.get(OrderService).addSurchargeToOrder(ctx, 1, {
  91. description: 'Negative test surcharge',
  92. listPrice: -20000,
  93. });
  94. await setShipping(shopClient);
  95. const { createStripePaymentIntent } = await shopClient.query(CREATE_STRIPE_PAYMENT_INTENT);
  96. clientSecret = createStripePaymentIntent;
  97. Logger.info('http://localhost:3050/checkout', 'Stripe DevServer');
  98. })();