import * as React from 'react'; import { render, screen } from '@testing-library/react'; import { Icon } from '../Icon'; import { CheckIcon } from '@patternfly/react-icons'; test('renders basic icon successfully', () => { const { asFragment } = render( ); expect(asFragment()).toMatchSnapshot(); }); test('checks basic icon structure', () => { const { asFragment } = render( ); const iconContainer = screen.getByTitle('icon'); expect(iconContainer).toHaveClass('pf-v5-c-icon'); const iconContent = iconContainer.querySelector('.pf-v5-c-icon__content'); expect(iconContent).toHaveClass('pf-v5-c-icon__content'); }); test('renders without children', () => { const { asFragment } = render(); expect(asFragment()).toMatchSnapshot(); }); test('sets additional custom class successfully', () => { render( ); const iconContainer = screen.getByTitle('custom-icon'); expect(iconContainer).toHaveClass('test'); }); Object.values(['sm', 'md', 'lg', 'xl']).forEach((size) => { test(`sets icon size modifier successfully - ${size}`, () => { render( ); const iconContainer = screen.getByTitle(`content-${size}-icon`).querySelector('.pf-v5-c-icon__content'); expect(iconContainer).toHaveClass(`pf-m-${size}`); }); }); test('check icon without iconSize', () => { render( ); const iconContainer = screen.getByTitle('no-icon-size').querySelector('.pf-v5-c-icon__content'); expect(Array.from(iconContainer?.classList || []).some((c) => /pf-m-*/.test(c))); // Check no modifier classes have been added }); Object.values(['sm', 'md', 'lg', 'xl']).forEach((size) => { test(`sets progress icon size modifier successfully - ${size}`, () => { render( ); const iconContainer = screen.getByTitle(`progress-content-${size}-icon`).querySelector('.pf-v5-c-icon__progress'); expect(iconContainer).toHaveClass(`pf-m-${size}`); }); }); test('check icon without progress icon size', () => { render( ); const iconContainer = screen.getByTitle('no-progress-icon-size').querySelector('.pf-v5-c-icon__progress'); expect(Array.from(iconContainer?.classList || []).some((c) => /pf-m-*/.test(c))); // Check no modifier classes have been added }); Object.values(['sm', 'md', 'lg', 'xl']).forEach((size) => { test(`sets size modifier successfully - ${size}`, () => { render( ); const iconContainer = screen.getByTitle(`${size}-icon`); expect(iconContainer).toHaveClass(`pf-m-${size}`); }); }); test('check icon without size', () => { render( ); const iconContainer = screen.getByTitle('no-size'); expect(Array.from(iconContainer?.classList || []).some((c) => /pf-m-*/.test(c))); // Check no modifier classes have been added }); Object.values(['custom', 'info', 'success', 'warning', 'danger']).forEach((status) => { test(`sets status modifier successfully - ${status}`, () => { render( ); const iconContent = screen.getByTitle(`${status}-icon`).querySelector('.pf-v5-c-icon__content'); expect(iconContent).toHaveClass(`pf-m-${status}`); }); }); test('check icon without status', () => { render( ); const iconContent = screen.getByTitle('no-status').querySelector('.pf-v5-c-icon__content'); expect(Array.from(iconContent?.classList || []).some((c) => /pf-m-*/.test(c))); // Check no modifier classes have been added }); test('sets isInline successfully', () => { render( ); const iconContainer = screen.getByTitle('inline-icon'); expect(iconContainer).toHaveClass('pf-m-inline'); }); test('check icon without isInline', () => { render( ); const iconContainer = screen.getByTitle('no-inline'); expect(Array.from(iconContainer?.classList || []).some((c) => /pf-m-*/.test(c))); // Check no modifier classes have been added }); test('sets isInProgress successfully', () => { render( ); const iconContainer = screen.getByTitle('progress-icon'); expect(iconContainer).toHaveClass('pf-m-in-progress'); const iconContent = iconContainer.querySelector('.pf-v5-c-icon__progress'); expect(iconContent).toHaveClass('pf-v5-c-icon__progress'); }); test('check icon without isInProgress', () => { render( ); const iconContainer = screen.getByTitle('no-in-progress'); expect(Array.from(iconContainer?.classList || []).some((c) => /pf-m-*/.test(c))); // Check no modifier classes have been added }); test('sets default progres aria-label successfully', () => { render( ); expect(screen.getByLabelText('test')); }); test('renders progress icon successfully', () => { const { asFragment } = render( }> ); expect(asFragment()).toMatchSnapshot(); });