From 5828ba2e753ab7da0d6bebfb755313beebf7b43a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9my=20Lenoir?= <103024358+cf-remylenoir@users.noreply.github.com> Date: Wed, 8 Jan 2025 12:14:49 +0100 Subject: [PATCH] chore(Tooltip): update default delay (#2965) * chore: update tooltip default delay * test(Tooltip): accommodate default delay * test(AvatarGroup): accommodate default tooltip delay * test(Avatar): accommodate default tooltip delay + add icon test-id --- .../avatar/src/Avatar/Avatar.test.tsx | 12 ++++-- .../components/avatar/src/Avatar/Avatar.tsx | 6 ++- .../src/AvatarGroup/AvatarGroup.test.tsx | 7 +++- .../components/tooltip/src/Tooltip.test.tsx | 40 ++++++++++++------- packages/components/tooltip/src/Tooltip.tsx | 4 +- 5 files changed, 47 insertions(+), 22 deletions(-) diff --git a/packages/components/avatar/src/Avatar/Avatar.test.tsx b/packages/components/avatar/src/Avatar/Avatar.test.tsx index 961c1ff99f..5932129e36 100644 --- a/packages/components/avatar/src/Avatar/Avatar.test.tsx +++ b/packages/components/avatar/src/Avatar/Avatar.test.tsx @@ -1,5 +1,5 @@ import React from 'react'; -import { render, screen } from '@testing-library/react'; +import { render, screen, waitFor } from '@testing-library/react'; import { CheckCircleIcon } from '@contentful/f36-icons'; import userEvent from '@testing-library/user-event'; import { Avatar } from './Avatar'; @@ -26,6 +26,8 @@ describe('Avatar', () => { it('renders an icon when it is provided', () => { const src = 'https://example.com/image.jpg'; render(} />); + + expect(screen.queryByTestId('cf-ui-avatar-icon')).toBeInTheDocument(); }); it('renders no tooltip when no props are provided', async () => { @@ -33,7 +35,9 @@ describe('Avatar', () => { render(); await user.hover(screen.getByTestId('cf-ui-avatar-fallback')); - expect(screen.queryByTestId('tooltip')).not.toBeInTheDocument(); + await waitFor(() => + expect(screen.queryByTestId('tooltip')).not.toBeInTheDocument(), + ); }); it('renders with tooltip when props are provided', async () => { @@ -41,6 +45,8 @@ describe('Avatar', () => { render(); await user.hover(screen.getByTestId('cf-ui-avatar-fallback')); - expect(screen.getByRole('tooltip').textContent).toBe('some content'); + await waitFor(() => + expect(screen.getByRole('tooltip').textContent).toBe('some content'), + ); }); }); diff --git a/packages/components/avatar/src/Avatar/Avatar.tsx b/packages/components/avatar/src/Avatar/Avatar.tsx index 0ff43e2126..95cf2fd943 100644 --- a/packages/components/avatar/src/Avatar/Avatar.tsx +++ b/packages/components/avatar/src/Avatar/Avatar.tsx @@ -87,7 +87,11 @@ function _Avatar( width="100%" /> )} - {!!icon && {icon}} + {!!icon && ( + + {icon} + + )} ); diff --git a/packages/components/avatar/src/AvatarGroup/AvatarGroup.test.tsx b/packages/components/avatar/src/AvatarGroup/AvatarGroup.test.tsx index ac4b40074e..25fdb46655 100644 --- a/packages/components/avatar/src/AvatarGroup/AvatarGroup.test.tsx +++ b/packages/components/avatar/src/AvatarGroup/AvatarGroup.test.tsx @@ -1,5 +1,5 @@ import React from 'react'; -import { render, screen } from '@testing-library/react'; +import { render, screen, waitFor } from '@testing-library/react'; import UserEvent from '@testing-library/user-event/'; import { Avatar } from '../Avatar'; import { AvatarGroup } from './AvatarGroup'; @@ -87,7 +87,10 @@ describe('AvatarGroup', () => { // Renders the tooltip for the presented avatars await user.hover(screen.getAllByTestId('cf-ui-avatar')[0]); - expect(screen.getByRole('tooltip').textContent).toBe('Marge Simpson'); + + await waitFor(() => + expect(screen.getByRole('tooltip').textContent).toBe('Marge Simpson'), + ); }); it('renders the avatars with tooltip in dropdown', async () => { diff --git a/packages/components/tooltip/src/Tooltip.test.tsx b/packages/components/tooltip/src/Tooltip.test.tsx index 7b3b1b89ff..17ab56e5f4 100644 --- a/packages/components/tooltip/src/Tooltip.test.tsx +++ b/packages/components/tooltip/src/Tooltip.test.tsx @@ -1,5 +1,5 @@ import React from 'react'; -import { render, screen } from '@testing-library/react'; +import { render, screen, waitFor } from '@testing-library/react'; import userEvent from '@testing-library/user-event'; import { axe } from '@/scripts/test/axeHelper'; @@ -36,7 +36,9 @@ describe('Tooltip', () => { await user.hover(screen.getByText('Hover me')); - expect(screen.getByRole('tooltip').textContent).toBe('Tooltip content'); + await waitFor(() => + expect(screen.getByRole('tooltip').textContent).toBe('Tooltip content'), + ); }); it('renders the component with an additional class name', async () => { @@ -49,7 +51,9 @@ describe('Tooltip', () => { await user.hover(screen.getByText('Hover me')); - expect(screen.getByRole('tooltip')).toHaveClass('extra-class-name'); + await waitFor(() => + expect(screen.getByRole('tooltip')).toHaveClass('extra-class-name'), + ); }); it('renders the component with a target wrapper classname', async () => { @@ -80,9 +84,11 @@ describe('Tooltip', () => { await user.hover(screen.getByText('Hover me')); - expect( - screen.getByRole('tooltip').getAttribute('data-popper-placement'), - ).toBe('left'); + await waitFor(() => + expect( + screen.getByRole('tooltip').getAttribute('data-popper-placement'), + ).toBe('left'), + ); }); it('renders the component with a id attribute', async () => { @@ -95,7 +101,9 @@ describe('Tooltip', () => { await user.hover(screen.getByText('Hover me')); - expect(screen.getByRole('tooltip').getAttribute('id')).toBe('Tooltip'); + await waitFor(() => + expect(screen.getByRole('tooltip').getAttribute('id')).toBe('Tooltip'), + ); }); it('renders the component as span with a id attribute', async () => { @@ -108,9 +116,11 @@ describe('Tooltip', () => { await user.hover(screen.getByText('Hover me')); - const tooltip = screen.getByRole('tooltip'); - expect(tooltip.getAttribute('id')).toBe('Tooltip'); - expect(tooltip.nodeName).toMatch(/span/i); + await waitFor(() => { + const tooltip = screen.getByRole('tooltip'); + expect(tooltip.getAttribute('id')).toBe('Tooltip'); + expect(tooltip.nodeName).toMatch(/span/i); + }); }); it('has no a11y issues', async () => { @@ -144,9 +154,11 @@ describe('Tooltip', () => { const results = await axe(container); - expect(results).toHaveNoViolations(); - expect(screen.getByRole('tooltip').textContent).toBe( - 'Ich bin ein Paragraph', - ); + await waitFor(() => { + expect(results).toHaveNoViolations(); + expect(screen.getByRole('tooltip').textContent).toBe( + 'Ich bin ein Paragraph', + ); + }); }); }); diff --git a/packages/components/tooltip/src/Tooltip.tsx b/packages/components/tooltip/src/Tooltip.tsx index d50de787ad..f73bde6adc 100644 --- a/packages/components/tooltip/src/Tooltip.tsx +++ b/packages/components/tooltip/src/Tooltip.tsx @@ -25,7 +25,7 @@ export type WithEnhancedContent = { */ content?: ReactElement | string; /** - * Accesible label property, only required when using ReactElement as content + * Accessible label property, only required when using ReactElement as content */ label?: string; }; @@ -123,7 +123,7 @@ export const Tooltip = ({ onMouseLeave, onMouseOver, onKeyDown, - showDelay = 0, + showDelay = 375, targetWrapperClassName, maxWidth = 360, testId = 'cf-ui-tooltip',