123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { getByIconName } from '#tests/support/components/iconQueries.ts'
- import { renderComponent } from '#tests/support/components/index.ts'
- import CommonLoader from '../CommonLoader.vue'
- describe('CommonLoader.vue', () => {
- it('does not render with default prop values', async () => {
- const view = renderComponent(CommonLoader)
- expect(view.queryByRole('status')).not.toBeInTheDocument()
- })
- it('renders loading animation with loading prop set', async () => {
- const view = renderComponent(CommonLoader, {
- props: {
- loading: true,
- },
- })
- const loader = view.getByRole('status')
- expect(getByIconName(loader, 'spinner')).toBeInTheDocument()
- })
- it('hides loading animation when loading prop is unset', async () => {
- const view = renderComponent(CommonLoader, {
- props: {
- loading: true,
- },
- })
- const loader = view.getByRole('status')
- expect(loader).toBeInTheDocument()
- await view.rerender({
- loading: false,
- })
- expect(loader).not.toBeInTheDocument()
- })
- it('renders alert if error prop is supplied', async () => {
- const view = renderComponent(CommonLoader, {
- props: {
- error: 'foobar',
- },
- })
- const alert = view.getByRole('alert')
- expect(alert).toHaveTextContent('foobar')
- expect(getByIconName(alert, 'x-circle')).toBeInTheDocument()
- })
- it('provides default slot', async () => {
- const view = renderComponent(CommonLoader, {
- slots: {
- default: 'foobar',
- },
- })
- expect(view.baseElement).toHaveTextContent('foobar')
- expect(view.queryByRole('status')).not.toBeInTheDocument()
- expect(view.queryByRole('alert')).not.toBeInTheDocument()
- })
- })
|