1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- // Copyright (C) 2012-2024 Zammad Foundation, https://zammad-foundation.org/
- import { createPinia, setActivePinia } from 'pinia'
- import { mockGraphQLApi } from '#tests/support/mock-graphql-api.ts'
- import { waitForTimeout } from '#tests/support/utils.ts'
- import { EnumObjectManagerObjects } from '#shared/graphql/types.ts'
- import { ObjectManagerFrontendAttributesDocument } from '../../graphql/queries/objectManagerFrontendAttributes.api.ts'
- import { useObjectAttributes } from '../useObjectAttributes.ts'
- import objectFrontendAttributes from './mocks/objectFrontendAttributes.json'
- const mockOrganizationObjectManagerAttributes = () => {
- mockGraphQLApi(ObjectManagerFrontendAttributesDocument).willResolve({
- objectManagerFrontendAttributes: objectFrontendAttributes,
- })
- }
- const getMeta = async () => {
- mockOrganizationObjectManagerAttributes()
- const meta = useObjectAttributes(EnumObjectManagerObjects.Organization)
- await waitForTimeout()
- return meta
- }
- describe('Object Manager Frontend Attributes Store', () => {
- beforeEach(() => {
- setActivePinia(createPinia())
- })
- it('is filled for Organization', async () => {
- const meta = await getMeta()
- expect(meta.attributes).not.toBe(undefined)
- })
- it('contains screens', async () => {
- const meta = await getMeta()
- expect(meta.screens.value).toEqual({
- view: [
- 'name',
- 'shared',
- 'domain_assignment',
- 'domain',
- 'note',
- 'active',
- 'test',
- 'textarea',
- ],
- edit: [
- 'name',
- 'shared',
- 'domain_assignment',
- 'domain',
- 'note',
- 'active',
- 'test',
- 'textarea',
- ],
- })
- })
- it('provides a fancy lookup of all attributes', async () => {
- const meta = await getMeta()
- expect(meta.attributesLookup.value.get('name')).toEqual({
- __typename: 'ObjectManagerFrontendAttribute',
- name: 'name',
- display: 'Name',
- dataType: 'input',
- isInternal: true,
- dataOption: {
- type: 'text',
- maxlength: 150,
- null: false,
- item_class: 'formGroup--halfSize',
- },
- screens: {},
- })
- })
- })
|