myAccessesMenuBuilder.test.ts 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. import { describe, test, it, expect } from 'vitest'
  2. import {RuntimeConfig} from "@nuxt/schema";
  3. import {AnyAbility} from "@casl/ability/dist/types";
  4. import {AccessProfile, organizationState} from "~/types/interfaces";
  5. import MyAccessesMenuBuilder from "~/services/layout/menuBuilder/myAccessesMenuBuilder";
  6. import {MenuGroup, MenuItem} from "~/types/layout";
  7. import {MENU_LINK_TYPE} from "~/types/enum/layout";
  8. let runtimeConfig: RuntimeConfig
  9. let ability: AnyAbility
  10. let organizationProfile: organizationState
  11. let accessProfile: AccessProfile
  12. let menuBuilder: MyAccessesMenuBuilder
  13. beforeEach(()=> {
  14. runtimeConfig = vi.fn() as any as RuntimeConfig
  15. ability = vi.fn() as any as AnyAbility
  16. organizationProfile = vi.fn() as any as organizationState
  17. accessProfile = vi.fn() as any as AccessProfile
  18. runtimeConfig.baseUrlAdminLegacy = 'https://mydomain.com/'
  19. menuBuilder = new MyAccessesMenuBuilder(runtimeConfig, ability, organizationProfile, accessProfile)
  20. })
  21. describe('getMenuName', () => {
  22. test('validate name', () => {
  23. expect(menuBuilder.getMenuName()).toEqual("MyAccesses")
  24. })
  25. })
  26. describe('build', () => {
  27. test('default : has no items, even with rights', () => {
  28. ability.can = vi.fn(() => true)
  29. expect(menuBuilder.build()).toEqual(null)
  30. })
  31. test('with enabled multi accesses', () => {
  32. accessProfile.multiAccesses = [
  33. { id: 1, name: 'Bob' },
  34. { id: 2, name: 'Séraphin' },
  35. { id: 3, name: 'Lilou' },
  36. ]
  37. const result = menuBuilder.build() as MenuGroup
  38. expect(result.label).toEqual('multiAccesses')
  39. expect(result.icon).toEqual({name: 'fas fa-building'})
  40. expect(result.children).toEqual([
  41. { label: 'Bob', icon: undefined, to: 'https://mydomain.com/#/switch/1', type: MENU_LINK_TYPE.V1, active: false },
  42. { label: 'Séraphin', icon: undefined, to: 'https://mydomain.com/#/switch/2', type: MENU_LINK_TYPE.V1, active: false },
  43. { label: 'Lilou', icon: undefined, to: 'https://mydomain.com/#/switch/3', type: MENU_LINK_TYPE.V1, active: false }
  44. ])
  45. })
  46. })