administrator.e2e-spec.ts 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. import {
  2. Administrator,
  3. CreateAdministrator,
  4. GetAdministrator,
  5. GetAdministrators,
  6. UpdateAdministrator,
  7. } from '../../shared/generated-types';
  8. import {
  9. CREATE_ADMINISTRATOR,
  10. GET_ADMINISTRATOR,
  11. GET_ADMINISTRATORS,
  12. UPDATE_ADMINISTRATOR,
  13. } from '../../admin-ui/src/app/data/definitions/administrator-definitions';
  14. import { TEST_SETUP_TIMEOUT_MS } from './config/test-config';
  15. import { TestClient } from './test-client';
  16. import { TestServer } from './test-server';
  17. describe('Administrator resolver', () => {
  18. const client = new TestClient();
  19. const server = new TestServer();
  20. let createdAdmin: Administrator.Fragment;
  21. beforeAll(async () => {
  22. const token = await server.init({
  23. productCount: 1,
  24. customerCount: 1,
  25. });
  26. await client.init();
  27. }, TEST_SETUP_TIMEOUT_MS);
  28. afterAll(async () => {
  29. await server.destroy();
  30. });
  31. it('administrators', async () => {
  32. const result = await client.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 client.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 client.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 client.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 client.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('updateAdministrator throws with invalid roleId', async () => {
  94. try {
  95. const result = await client.query<UpdateAdministrator.Mutation, UpdateAdministrator.Variables>(
  96. UPDATE_ADMINISTRATOR,
  97. {
  98. input: {
  99. id: createdAdmin.id,
  100. emailAddress: 'new-email',
  101. firstName: 'new first',
  102. lastName: 'new last',
  103. password: 'new password',
  104. roleIds: ['999'],
  105. },
  106. },
  107. );
  108. fail(`Should throw`);
  109. } catch (err) {
  110. expect(err.message).toEqual(expect.stringContaining(`No Role with the id '999' could be found`));
  111. }
  112. });
  113. });