database-transactions.e2e-spec.ts 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. import { mergeConfig } from '@vendure/core';
  2. import { createTestEnvironment } from '@vendure/testing';
  3. import gql from 'graphql-tag';
  4. import path from 'path';
  5. import { ReplaySubject } from 'rxjs';
  6. import { initialData } from '../../../e2e-common/e2e-initial-data';
  7. import { testConfig, TEST_SETUP_TIMEOUT_MS } from '../../../e2e-common/test-config';
  8. import {
  9. TransactionTestPlugin,
  10. TRIGGER_ATTEMPTED_READ_EMAIL,
  11. TRIGGER_ATTEMPTED_UPDATE_EMAIL,
  12. } from './fixtures/test-plugins/transaction-test-plugin';
  13. describe('Transaction infrastructure', () => {
  14. const { server, adminClient } = createTestEnvironment(
  15. mergeConfig(testConfig, {
  16. plugins: [TransactionTestPlugin],
  17. }),
  18. );
  19. beforeAll(async () => {
  20. await server.init({
  21. initialData,
  22. productsCsvPath: path.join(__dirname, 'fixtures/e2e-products-minimal.csv'),
  23. customerCount: 0,
  24. });
  25. await adminClient.asSuperAdmin();
  26. }, TEST_SETUP_TIMEOUT_MS);
  27. afterAll(async () => {
  28. await server.destroy();
  29. });
  30. it('non-failing mutation', async () => {
  31. const { createTestAdministrator } = await adminClient.query(CREATE_ADMIN, {
  32. emailAddress: 'test1',
  33. fail: false,
  34. });
  35. expect(createTestAdministrator.emailAddress).toBe('test1');
  36. expect(createTestAdministrator.user.identifier).toBe('test1');
  37. const { verify } = await adminClient.query(VERIFY_TEST);
  38. expect(verify.admins.length).toBe(2);
  39. expect(verify.users.length).toBe(2);
  40. expect(!!verify.admins.find((a: any) => a.emailAddress === 'test1')).toBe(true);
  41. expect(!!verify.users.find((u: any) => u.identifier === 'test1')).toBe(true);
  42. });
  43. it('failing mutation', async () => {
  44. try {
  45. await adminClient.query(CREATE_ADMIN, {
  46. emailAddress: 'test2',
  47. fail: true,
  48. });
  49. fail('Should have thrown');
  50. } catch (e) {
  51. expect(e.message).toContain('Failed!');
  52. }
  53. const { verify } = await adminClient.query(VERIFY_TEST);
  54. expect(verify.admins.length).toBe(2);
  55. expect(verify.users.length).toBe(2);
  56. expect(!!verify.admins.find((a: any) => a.emailAddress === 'test2')).toBe(false);
  57. expect(!!verify.users.find((u: any) => u.identifier === 'test2')).toBe(false);
  58. });
  59. it('failing manual mutation', async () => {
  60. try {
  61. await adminClient.query(CREATE_ADMIN2, {
  62. emailAddress: 'test3',
  63. fail: true,
  64. });
  65. fail('Should have thrown');
  66. } catch (e) {
  67. expect(e.message).toContain('Failed!');
  68. }
  69. const { verify } = await adminClient.query(VERIFY_TEST);
  70. expect(verify.admins.length).toBe(2);
  71. expect(verify.users.length).toBe(2);
  72. expect(!!verify.admins.find((a: any) => a.emailAddress === 'test3')).toBe(false);
  73. expect(!!verify.users.find((u: any) => u.identifier === 'test3')).toBe(false);
  74. });
  75. it('failing manual mutation without transaction', async () => {
  76. try {
  77. await adminClient.query(CREATE_ADMIN3, {
  78. emailAddress: 'test4',
  79. fail: true,
  80. });
  81. fail('Should have thrown');
  82. } catch (e) {
  83. expect(e.message).toContain('Failed!');
  84. }
  85. const { verify } = await adminClient.query(VERIFY_TEST);
  86. expect(verify.admins.length).toBe(2);
  87. expect(verify.users.length).toBe(3);
  88. expect(!!verify.admins.find((a: any) => a.emailAddress === 'test4')).toBe(false);
  89. expect(!!verify.users.find((u: any) => u.identifier === 'test4')).toBe(true);
  90. });
  91. // Testing https://github.com/vendure-ecommerce/vendure/issues/520
  92. it('passing transaction via EventBus', async () => {
  93. TransactionTestPlugin.reset();
  94. const { createTestAdministrator } = await adminClient.query(CREATE_ADMIN, {
  95. emailAddress: TRIGGER_ATTEMPTED_UPDATE_EMAIL,
  96. fail: false,
  97. });
  98. await TransactionTestPlugin.eventHandlerComplete$.toPromise();
  99. expect(createTestAdministrator.emailAddress).toBe(TRIGGER_ATTEMPTED_UPDATE_EMAIL);
  100. expect(TransactionTestPlugin.errorHandler).not.toHaveBeenCalled();
  101. });
  102. // Testing https://github.com/vendure-ecommerce/vendure/issues/1107
  103. it('passing transaction via EventBus with delay in committing transaction', async () => {
  104. TransactionTestPlugin.reset();
  105. const { createTestAdministrator4 } = await adminClient.query(CREATE_ADMIN4, {
  106. emailAddress: TRIGGER_ATTEMPTED_READ_EMAIL,
  107. fail: false,
  108. });
  109. await TransactionTestPlugin.eventHandlerComplete$.toPromise();
  110. expect(createTestAdministrator4.emailAddress).toBe(TRIGGER_ATTEMPTED_READ_EMAIL);
  111. expect(TransactionTestPlugin.errorHandler).not.toHaveBeenCalled();
  112. });
  113. });
  114. const ADMIN_FRAGMENT = gql`
  115. fragment CreatedAdmin on Administrator {
  116. id
  117. emailAddress
  118. user {
  119. id
  120. identifier
  121. }
  122. }
  123. `;
  124. const CREATE_ADMIN = gql`
  125. mutation CreateTestAdmin($emailAddress: String!, $fail: Boolean!) {
  126. createTestAdministrator(emailAddress: $emailAddress, fail: $fail) {
  127. ...CreatedAdmin
  128. }
  129. }
  130. ${ADMIN_FRAGMENT}
  131. `;
  132. const CREATE_ADMIN2 = gql`
  133. mutation CreateTestAdmin2($emailAddress: String!, $fail: Boolean!) {
  134. createTestAdministrator2(emailAddress: $emailAddress, fail: $fail) {
  135. ...CreatedAdmin
  136. }
  137. }
  138. ${ADMIN_FRAGMENT}
  139. `;
  140. const CREATE_ADMIN3 = gql`
  141. mutation CreateTestAdmin3($emailAddress: String!, $fail: Boolean!) {
  142. createTestAdministrator3(emailAddress: $emailAddress, fail: $fail) {
  143. ...CreatedAdmin
  144. }
  145. }
  146. ${ADMIN_FRAGMENT}
  147. `;
  148. const CREATE_ADMIN4 = gql`
  149. mutation CreateTestAdmin4($emailAddress: String!, $fail: Boolean!) {
  150. createTestAdministrator4(emailAddress: $emailAddress, fail: $fail) {
  151. ...CreatedAdmin
  152. }
  153. }
  154. ${ADMIN_FRAGMENT}
  155. `;
  156. const VERIFY_TEST = gql`
  157. query VerifyTest {
  158. verify {
  159. admins {
  160. id
  161. emailAddress
  162. }
  163. users {
  164. id
  165. identifier
  166. }
  167. }
  168. }
  169. `;