zone.e2e-spec.ts 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. import { createTestEnvironment } from '@vendure/testing';
  2. import gql from 'graphql-tag';
  3. import path from 'path';
  4. import { initialData } from '../../../e2e-common/e2e-initial-data';
  5. import { TEST_SETUP_TIMEOUT_MS, testConfig } from '../../../e2e-common/test-config';
  6. import { ZONE_FRAGMENT } from './graphql/fragments';
  7. import {
  8. AddMembersToZone,
  9. CreateZone,
  10. DeleteZone,
  11. DeletionResult,
  12. GetCountryList,
  13. GetZone,
  14. GetZones,
  15. RemoveMembersFromZone,
  16. UpdateZone,
  17. } from './graphql/generated-e2e-admin-types';
  18. import { GET_COUNTRY_LIST } from './graphql/shared-definitions';
  19. // tslint:disable:no-non-null-assertion
  20. describe('Facet resolver', () => {
  21. const { server, adminClient } = createTestEnvironment(testConfig);
  22. let countries: GetCountryList.Items[];
  23. let zones: Array<{ id: string; name: string }>;
  24. let oceania: { id: string; name: string };
  25. let pangaea: { id: string; name: string; members: any[] };
  26. beforeAll(async () => {
  27. await server.init({
  28. dataDir: path.join(__dirname, '__data__'),
  29. initialData,
  30. productsCsvPath: path.join(__dirname, 'fixtures/e2e-products-minimal.csv'),
  31. customerCount: 1,
  32. });
  33. await adminClient.asSuperAdmin();
  34. const result = await adminClient.query<GetCountryList.Query>(GET_COUNTRY_LIST, {});
  35. countries = result.countries.items;
  36. }, TEST_SETUP_TIMEOUT_MS);
  37. afterAll(async () => {
  38. await server.destroy();
  39. });
  40. it('zones', async () => {
  41. const result = await adminClient.query<GetZones.Query>(GET_ZONE_LIST);
  42. expect(result.zones.length).toBe(5);
  43. zones = result.zones;
  44. oceania = zones[0];
  45. });
  46. it('zone', async () => {
  47. const result = await adminClient.query<GetZone.Query, GetZone.Variables>(GET_ZONE, {
  48. id: oceania.id,
  49. });
  50. expect(result.zone!.name).toBe('Oceania');
  51. });
  52. it('updateZone', async () => {
  53. const result = await adminClient.query<UpdateZone.Mutation, UpdateZone.Variables>(UPDATE_ZONE, {
  54. input: {
  55. id: oceania.id,
  56. name: 'oceania2',
  57. },
  58. });
  59. expect(result.updateZone.name).toBe('oceania2');
  60. });
  61. it('createZone', async () => {
  62. const result = await adminClient.query<CreateZone.Mutation, CreateZone.Variables>(CREATE_ZONE, {
  63. input: {
  64. name: 'Pangaea',
  65. memberIds: [countries[0].id, countries[1].id],
  66. },
  67. });
  68. pangaea = result.createZone;
  69. expect(pangaea.name).toBe('Pangaea');
  70. expect(pangaea.members.map(m => m.name)).toEqual([countries[0].name, countries[1].name]);
  71. });
  72. it('addMembersToZone', async () => {
  73. const result = await adminClient.query<AddMembersToZone.Mutation, AddMembersToZone.Variables>(
  74. ADD_MEMBERS_TO_ZONE,
  75. {
  76. zoneId: oceania.id,
  77. memberIds: [countries[2].id, countries[3].id],
  78. },
  79. );
  80. expect(!!result.addMembersToZone.members.find(m => m.name === countries[2].name)).toBe(true);
  81. expect(!!result.addMembersToZone.members.find(m => m.name === countries[3].name)).toBe(true);
  82. });
  83. it('removeMembersFromZone', async () => {
  84. const result = await adminClient.query<
  85. RemoveMembersFromZone.Mutation,
  86. RemoveMembersFromZone.Variables
  87. >(REMOVE_MEMBERS_FROM_ZONE, {
  88. zoneId: oceania.id,
  89. memberIds: [countries[0].id, countries[2].id],
  90. });
  91. expect(!!result.removeMembersFromZone.members.find(m => m.name === countries[0].name)).toBe(false);
  92. expect(!!result.removeMembersFromZone.members.find(m => m.name === countries[2].name)).toBe(false);
  93. expect(!!result.removeMembersFromZone.members.find(m => m.name === countries[3].name)).toBe(true);
  94. });
  95. describe('deletion', () => {
  96. it('deletes Zone not used in any TaxRate', async () => {
  97. const result1 = await adminClient.query<DeleteZone.Mutation, DeleteZone.Variables>(DELETE_ZONE, {
  98. id: pangaea.id,
  99. });
  100. expect(result1.deleteZone).toEqual({
  101. result: DeletionResult.DELETED,
  102. message: '',
  103. });
  104. const result2 = await adminClient.query<GetZones.Query>(GET_ZONE_LIST);
  105. expect(result2.zones.find(c => c.id === pangaea.id)).toBeUndefined();
  106. });
  107. it('does not delete Zone that is used in one or more TaxRates', async () => {
  108. const result1 = await adminClient.query<DeleteZone.Mutation, DeleteZone.Variables>(DELETE_ZONE, {
  109. id: oceania.id,
  110. });
  111. expect(result1.deleteZone).toEqual({
  112. result: DeletionResult.NOT_DELETED,
  113. message:
  114. 'The selected Zone cannot be deleted as it is used in the following ' +
  115. 'TaxRates: Standard Tax Oceania, Reduced Tax Oceania, Zero Tax Oceania',
  116. });
  117. const result2 = await adminClient.query<GetZones.Query>(GET_ZONE_LIST);
  118. expect(result2.zones.find(c => c.id === oceania.id)).not.toBeUndefined();
  119. });
  120. });
  121. });
  122. const DELETE_ZONE = gql`
  123. mutation DeleteZone($id: ID!) {
  124. deleteZone(id: $id) {
  125. result
  126. message
  127. }
  128. }
  129. `;
  130. const GET_ZONE_LIST = gql`
  131. query GetZones {
  132. zones {
  133. id
  134. name
  135. }
  136. }
  137. `;
  138. export const GET_ZONE = gql`
  139. query GetZone($id: ID!) {
  140. zone(id: $id) {
  141. ...Zone
  142. }
  143. }
  144. ${ZONE_FRAGMENT}
  145. `;
  146. export const CREATE_ZONE = gql`
  147. mutation CreateZone($input: CreateZoneInput!) {
  148. createZone(input: $input) {
  149. ...Zone
  150. }
  151. }
  152. ${ZONE_FRAGMENT}
  153. `;
  154. export const UPDATE_ZONE = gql`
  155. mutation UpdateZone($input: UpdateZoneInput!) {
  156. updateZone(input: $input) {
  157. ...Zone
  158. }
  159. }
  160. ${ZONE_FRAGMENT}
  161. `;
  162. export const ADD_MEMBERS_TO_ZONE = gql`
  163. mutation AddMembersToZone($zoneId: ID!, $memberIds: [ID!]!) {
  164. addMembersToZone(zoneId: $zoneId, memberIds: $memberIds) {
  165. ...Zone
  166. }
  167. }
  168. ${ZONE_FRAGMENT}
  169. `;
  170. export const REMOVE_MEMBERS_FROM_ZONE = gql`
  171. mutation RemoveMembersFromZone($zoneId: ID!, $memberIds: [ID!]!) {
  172. removeMembersFromZone(zoneId: $zoneId, memberIds: $memberIds) {
  173. ...Zone
  174. }
  175. }
  176. ${ZONE_FRAGMENT}
  177. `;