import * as React from 'react'; import { render, screen } from '@testing-library/react'; import { Banner } from '../Banner'; test('Renders without children', () => { render(
); expect(screen.getByTestId('banner').firstChild).toBeVisible(); }); test('Renders children', () => { render(Test); expect(screen.getByText('Test')).toBeVisible(); }); test('Renders with class name pf-v5-c-banner', () => { render(Test); expect(screen.getByText('Test')).toHaveClass('pf-v5-c-banner'); }); test('Renders with custom class name when className prop is provided', () => { render(Test); expect(screen.getByText('Test')).toHaveClass('custom-class'); }); test('Renders without any modifier class when variant prop is not passed', () => { render(Test); expect(screen.getByText('Test')).toHaveClass('pf-v5-c-banner', { exact: true }); }); test('Renders with class name pf-m-green when "green" is passed to variant prop', () => { render(Test); expect(screen.getByText('Test')).toHaveClass('pf-m-green'); }); test('Renders with class name pf-m-red when "red" is passed to variant prop', () => { render(Test); expect(screen.getByText('Test')).toHaveClass('pf-m-red'); }); test('Renders with class name pf-m-gold when "gold" is passed to variant prop', () => { render(Test); expect(screen.getByText('Test')).toHaveClass('pf-m-gold'); }); test('Renders with class name pf-m-blue when "blue" is passed to variant prop', () => { render(Test); expect(screen.getByText('Test')).toHaveClass('pf-m-blue'); }); test('Does not render pf-v5-screen-reader class by default', () => { render(Test); expect(screen.getByText('Test')).not.toContainHTML(''); }); test('Renders screenReaderText passed via prop', () => { render(Test); expect(screen.getByText('Custom screen reader text')).toBeInTheDocument(); }); test('Renders without pf-m-sticky by default', () => { render(Test); expect(screen.getByText('Test')).not.toHaveClass('pf-m-sticky'); }); test('Renders with class name pf-m-sticky when isSticky prop is passed', () => { render(Test); expect(screen.getByText('Test')).toHaveClass('pf-m-sticky'); }); test('Renders with inherited element props spread to the component', () => { render(Test); expect(screen.getByText('Test')).toHaveAccessibleName('Test label'); }); test('Matches the snapshot', () => { const { asFragment } = render(Test); expect(asFragment()).toMatchSnapshot(); });