administrator.e2e-spec.ts 4.9 KB

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