1
0

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