administrator.e2e-spec.ts 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  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 { TestClient } from './test-client';
  15. import { TestServer } from './test-server';
  16. describe('Administrator resolver', () => {
  17. const client = new TestClient();
  18. const server = new TestServer();
  19. let createdAdmin: Administrator.Fragment;
  20. beforeAll(async () => {
  21. const token = await server.init({
  22. productCount: 1,
  23. customerCount: 1,
  24. });
  25. await client.init();
  26. }, 60000);
  27. afterAll(async () => {
  28. await server.destroy();
  29. });
  30. it('administrators', async () => {
  31. const result = await client.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 client.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 client.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 client.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 client.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('updateAdministrator throws with invalid roleId', async () => {
  93. try {
  94. const result = await client.query<UpdateAdministrator.Mutation, UpdateAdministrator.Variables>(
  95. UPDATE_ADMINISTRATOR,
  96. {
  97. input: {
  98. id: createdAdmin.id,
  99. emailAddress: 'new-email',
  100. firstName: 'new first',
  101. lastName: 'new last',
  102. password: 'new password',
  103. roleIds: ['999'],
  104. },
  105. },
  106. );
  107. fail(`Should throw`);
  108. } catch (err) {
  109. expect(err.message).toEqual(expect.stringContaining(`No Role with the id '999' could be found`));
  110. }
  111. });
  112. });