From 615608db4d1df22fc6e4ea4dc2967f5f3e15d8aa Mon Sep 17 00:00:00 2001 From: mhnpd Date: Fri, 22 Dec 2023 15:38:00 +0545 Subject: [PATCH] Add Whirl component and tests --- src/experimental/whirl.tsx | 1 + test/experimantal/whirl.spec.tsx | 30 ++++++++++++++++++++++++++++++ 2 files changed, 31 insertions(+) create mode 100644 test/experimantal/whirl.spec.tsx diff --git a/src/experimental/whirl.tsx b/src/experimental/whirl.tsx index 4b16881..8920603 100644 --- a/src/experimental/whirl.tsx +++ b/src/experimental/whirl.tsx @@ -54,6 +54,7 @@ export const Whirl: FunctionComponent = ({ viewBox="0 0 100 100" className={wrapperClass} preserveAspectRatio="xMidYMid" + data-testid="whirl" > diff --git a/test/experimantal/whirl.spec.tsx b/test/experimantal/whirl.spec.tsx new file mode 100644 index 0000000..8a0721f --- /dev/null +++ b/test/experimantal/whirl.spec.tsx @@ -0,0 +1,30 @@ +import React from 'react'; +import { render, screen } from '@testing-library/react'; +import { Whirl } from '../../src/beta' + +describe('Whirl', () => { + test('renders Whirl component', () => { + render(); + const svgElement = screen.getByTestId('whirl'); + expect(svgElement).toBeInTheDocument(); + }); + + test('applies wrapperClass correctly', () => { + render(); + const svgElement = screen.getByTestId('whirl'); + expect(svgElement).toHaveClass('test-class'); + }); + + test('applies wrapperStyle correctly', () => { + render(); + const svgElement = screen.getByTestId('whirl'); + expect(svgElement).toHaveStyle('background-color: red'); + }); + + test('does not render when visible is false', () => { + render(); + const svg = screen.queryByTestId('whirl'); + expect(svg).not.toBeInTheDocument(); + }); +}); +