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();
});