|
| 1 | +import * as React from 'react'; |
| 2 | +import { render, screen } from '@testing-library/react'; |
1 | 3 | import { Banner } from '../Banner'; |
2 | | -import React from 'react'; |
3 | | -import { render } from '@testing-library/react'; |
4 | | - |
5 | | -['default', 'info', 'success', 'warning', 'danger'].forEach((variant: string) => { |
6 | | - test(`${variant} banner`, () => { |
7 | | - const { asFragment } = render( |
8 | | - <Banner |
9 | | - variant={variant as 'default' | 'info' | 'success' | 'warning' | 'danger'} |
10 | | - aria-label={variant} |
11 | | - screenReaderText={`${variant} banner`} |
12 | | - > |
13 | | - {variant} Banner |
14 | | - </Banner> |
15 | | - ); |
16 | | - expect(asFragment()).toMatchSnapshot(); |
17 | | - }); |
18 | | -}); |
19 | | - |
20 | | -test(`sticky banner`, () => { |
21 | | - const { asFragment } = render( |
22 | | - <Banner aria-label="sticky" isSticky> |
23 | | - Sticky Banner |
24 | | - </Banner> |
| 4 | + |
| 5 | +test('Renders without children', () => { |
| 6 | + render( |
| 7 | + <div data-testid="banner"> |
| 8 | + <Banner /> |
| 9 | + </div> |
25 | 10 | ); |
| 11 | + expect(screen.getByTestId('banner').firstChild).toBeVisible(); |
| 12 | +}); |
| 13 | + |
| 14 | +test('Renders children', () => { |
| 15 | + render(<Banner>Test</Banner>); |
| 16 | + expect(screen.getByText('Test')).toBeVisible(); |
| 17 | +}); |
| 18 | + |
| 19 | +test('Renders with class name pf-c-banner', () => { |
| 20 | + render(<Banner>Test</Banner>); |
| 21 | + expect(screen.getByText('Test')).toHaveClass('pf-c-banner'); |
| 22 | +}); |
| 23 | + |
| 24 | +test('Renders with custom class name when className prop is provided', () => { |
| 25 | + render(<Banner className="custom-class">Test</Banner>); |
| 26 | + expect(screen.getByText('Test')).toHaveClass('custom-class'); |
| 27 | +}); |
| 28 | + |
| 29 | +test('Renders without any modifier class when variant prop is not passed', () => { |
| 30 | + render(<Banner>Test</Banner>); |
| 31 | + expect(screen.getByText('Test')).toHaveClass('pf-c-banner', { exact: true }); |
| 32 | +}); |
| 33 | + |
| 34 | +test('Renders with class name pf-m-success when "success" is passed to variant prop', () => { |
| 35 | + render(<Banner variant="success">Test</Banner>); |
| 36 | + expect(screen.getByText('Test')).toHaveClass('pf-m-success'); |
| 37 | +}); |
| 38 | + |
| 39 | +test('Renders with class name pf-m-danger when "danger" is passed to variant prop', () => { |
| 40 | + render(<Banner variant="danger">Test</Banner>); |
| 41 | + expect(screen.getByText('Test')).toHaveClass('pf-m-danger'); |
| 42 | +}); |
| 43 | + |
| 44 | +test('Renders with class name pf-m-warning when "warning" is passed to variant prop', () => { |
| 45 | + render(<Banner variant="warning">Test</Banner>); |
| 46 | + expect(screen.getByText('Test')).toHaveClass('pf-m-warning'); |
| 47 | +}); |
| 48 | + |
| 49 | +test('Renders with class name pf-m-info when "info" is passed to variant prop', () => { |
| 50 | + render(<Banner variant="info">Test</Banner>); |
| 51 | + expect(screen.getByText('Test')).toHaveClass('pf-m-info'); |
| 52 | +}); |
| 53 | + |
| 54 | +test('Renders screenReaderText as "default banner" by default', () => { |
| 55 | + render(<Banner>Test</Banner>); |
| 56 | + expect(screen.getByText('Test').lastChild).toHaveTextContent(/^default banner$/); |
| 57 | +}); |
| 58 | + |
| 59 | +test('Renders custom screenReaderText passed via prop', () => { |
| 60 | + render(<Banner screenReaderText="Custom screen reader text">Test</Banner>); |
| 61 | + expect(screen.getByText('Test').lastChild).toHaveTextContent(/^Custom screen reader text$/); |
| 62 | +}); |
| 63 | + |
| 64 | +test('Renders without pf-m-sticky by default', () => { |
| 65 | + render(<Banner>Test</Banner>); |
| 66 | + expect(screen.getByText('Test')).not.toHaveClass('pf-m-sticky'); |
| 67 | +}); |
| 68 | + |
| 69 | +test('Renders with class name pf-m-sticky when isSticky prop is passed', () => { |
| 70 | + render(<Banner isSticky>Test</Banner>); |
| 71 | + expect(screen.getByText('Test')).toHaveClass('pf-m-sticky'); |
| 72 | +}); |
| 73 | + |
| 74 | +test('Renders with inherited element props spread to the component', () => { |
| 75 | + render(<Banner aria-label="Test label">Test</Banner>); |
| 76 | + expect(screen.getByText('Test')).toHaveAccessibleName('Test label'); |
| 77 | +}); |
| 78 | + |
| 79 | +test('Matches the snapshot', () => { |
| 80 | + const { asFragment } = render(<Banner>Test</Banner>); |
26 | 81 | expect(asFragment()).toMatchSnapshot(); |
27 | 82 | }); |
0 commit comments