administrator.e2e-spec.ts 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  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 { ADMINISTRATOR_FRAGMENT } from './graphql/fragments';
  7. import {
  8. Administrator,
  9. CreateAdministrator,
  10. GetAdministrator,
  11. GetAdministrators,
  12. UpdateAdministrator,
  13. } from './graphql/generated-e2e-admin-types';
  14. import { CREATE_ADMINISTRATOR } from './graphql/shared-definitions';
  15. import { assertThrowsWithMessage } from './utils/assert-throws-with-message';
  16. describe('Administrator resolver', () => {
  17. const { server, adminClient } = createTestEnvironment(testConfig);
  18. let createdAdmin: Administrator.Fragment;
  19. beforeAll(async () => {
  20. await server.init({
  21. dataDir: path.join(__dirname, '__data__'),
  22. initialData,
  23. productsCsvPath: path.join(__dirname, 'fixtures/e2e-products-minimal.csv'),
  24. customerCount: 1,
  25. });
  26. await adminClient.asSuperAdmin();
  27. }, TEST_SETUP_TIMEOUT_MS);
  28. afterAll(async () => {
  29. await server.destroy();
  30. });
  31. it('administrators', async () => {
  32. const result = await adminClient.query<GetAdministrators.Query, GetAdministrators.Variables>(
  33. GET_ADMINISTRATORS,
  34. );
  35. expect(result.administrators.items.length).toBe(1);
  36. expect(result.administrators.totalItems).toBe(1);
  37. });
  38. it('createAdministrator', async () => {
  39. const result = await adminClient.query<CreateAdministrator.Mutation, CreateAdministrator.Variables>(
  40. CREATE_ADMINISTRATOR,
  41. {
  42. input: {
  43. emailAddress: 'test@test.com',
  44. firstName: 'First',
  45. lastName: 'Last',
  46. password: 'password',
  47. roleIds: ['1'],
  48. },
  49. },
  50. );
  51. createdAdmin = result.createAdministrator;
  52. expect(createdAdmin).toMatchSnapshot();
  53. });
  54. it('administrator', async () => {
  55. const result = await adminClient.query<GetAdministrator.Query, GetAdministrator.Variables>(
  56. GET_ADMINISTRATOR,
  57. {
  58. id: createdAdmin.id,
  59. },
  60. );
  61. expect(result.administrator).toEqual(createdAdmin);
  62. });
  63. it('updateAdministrator', async () => {
  64. const result = await adminClient.query<UpdateAdministrator.Mutation, UpdateAdministrator.Variables>(
  65. UPDATE_ADMINISTRATOR,
  66. {
  67. input: {
  68. id: createdAdmin.id,
  69. emailAddress: 'new-email',
  70. firstName: 'new first',
  71. lastName: 'new last',
  72. password: 'new password',
  73. roleIds: ['2'],
  74. },
  75. },
  76. );
  77. expect(result.updateAdministrator).toMatchSnapshot();
  78. });
  79. it('updateAdministrator works with partial input', async () => {
  80. const result = await adminClient.query<UpdateAdministrator.Mutation, UpdateAdministrator.Variables>(
  81. UPDATE_ADMINISTRATOR,
  82. {
  83. input: {
  84. id: createdAdmin.id,
  85. emailAddress: 'newest-email',
  86. },
  87. },
  88. );
  89. expect(result.updateAdministrator.emailAddress).toBe('newest-email');
  90. expect(result.updateAdministrator.firstName).toBe('new first');
  91. expect(result.updateAdministrator.lastName).toBe('new last');
  92. });
  93. it(
  94. 'updateAdministrator throws with invalid roleId',
  95. assertThrowsWithMessage(
  96. () =>
  97. adminClient.query<UpdateAdministrator.Mutation, UpdateAdministrator.Variables>(
  98. UPDATE_ADMINISTRATOR,
  99. {
  100. input: {
  101. id: createdAdmin.id,
  102. emailAddress: 'new-email',
  103. firstName: 'new first',
  104. lastName: 'new last',
  105. password: 'new password',
  106. roleIds: ['999'],
  107. },
  108. },
  109. ),
  110. `No Role with the id '999' could be found`,
  111. ),
  112. );
  113. });
  114. export const GET_ADMINISTRATORS = gql`
  115. query GetAdministrators($options: AdministratorListOptions) {
  116. administrators(options: $options) {
  117. items {
  118. ...Administrator
  119. }
  120. totalItems
  121. }
  122. }
  123. ${ADMINISTRATOR_FRAGMENT}
  124. `;
  125. export const GET_ADMINISTRATOR = gql`
  126. query GetAdministrator($id: ID!) {
  127. administrator(id: $id) {
  128. ...Administrator
  129. }
  130. }
  131. ${ADMINISTRATOR_FRAGMENT}
  132. `;
  133. export const UPDATE_ADMINISTRATOR = gql`
  134. mutation UpdateAdministrator($input: UpdateAdministratorInput!) {
  135. updateAdministrator(input: $input) {
  136. ...Administrator
  137. }
  138. }
  139. ${ADMINISTRATOR_FRAGMENT}
  140. `;