-
-
Notifications
You must be signed in to change notification settings - Fork 840
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Refactor: Adding vitest to Avatar component (#2622)
- Loading branch information
1 parent
afa614a
commit 0630cff
Showing
2 changed files
with
92 additions
and
50 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
import React from 'react'; | ||
import { render } from '@testing-library/react'; | ||
import '@testing-library/jest-dom'; | ||
import { describe, test, expect, vi } from 'vitest'; | ||
import Avatar from './Avatar'; | ||
|
||
/** | ||
* Unit tests for the `Avatar` component. | ||
* | ||
* The tests ensure the `Avatar` component renders correctly with various props. | ||
* Mocked dependencies are used to isolate the component and verify its behavior. | ||
* | ||
*/ | ||
|
||
vi.mock('state/store', () => ({ | ||
store: { | ||
getState: vi.fn(() => ({ | ||
auth: { | ||
user: null, | ||
loading: false, | ||
}, | ||
})), | ||
subscribe: vi.fn(), | ||
dispatch: vi.fn(), | ||
}, | ||
})); | ||
|
||
vi.mock('utils/i18nForTest', () => ({ | ||
__esModule: true, | ||
default: vi.fn(() => ({ | ||
t: (key: string) => key, | ||
})), | ||
})); | ||
|
||
describe('Avatar component', () => { | ||
/** | ||
* Test: Verifies the `Avatar` component renders correctly with the `name` and `alt` attributes. | ||
* | ||
* Steps: | ||
* 1. Render the `Avatar` component with `name`, `alt`, and `size` props. | ||
* 2. Check if the avatar image is present in the document. | ||
* 3. Validate the `src` attribute is defined. | ||
*/ | ||
test('renders with name and alt attribute', () => { | ||
const testName = 'John Doe'; | ||
const testAlt = 'Test Alt Text'; | ||
const testSize = 64; | ||
|
||
const { getByAltText } = render( | ||
<Avatar name={testName} alt={testAlt} size={testSize} />, | ||
); | ||
|
||
const avatarElement = getByAltText(testAlt); | ||
|
||
expect(avatarElement).toBeInTheDocument(); | ||
expect(avatarElement.getAttribute('src')).toBeDefined(); | ||
}); | ||
|
||
/** | ||
* Test: Verifies the `Avatar` component renders correctly with custom style and `data-testid`. | ||
* | ||
* Steps: | ||
* 1. Render the `Avatar` component with `avatarStyle` and `dataTestId` props. | ||
* 2. Check if the avatar image is present in the document. | ||
* 3. Validate the `className` contains the custom style. | ||
* 4. Validate the `data-testid` attribute matches the expected value. | ||
*/ | ||
|
||
test('renders with custom style and data-testid', () => { | ||
const testName = 'Jane Doe'; | ||
const testStyle = 'custom-avatar-style'; | ||
const testDataTestId = 'custom-avatar-test-id'; | ||
|
||
const { getByAltText } = render( | ||
<Avatar | ||
name={testName} | ||
alt="Dummy Avatar" | ||
avatarStyle={testStyle} | ||
dataTestId={testDataTestId} | ||
/>, | ||
); | ||
|
||
const avatarElement = getByAltText('Dummy Avatar'); | ||
|
||
expect(avatarElement).toBeInTheDocument(); | ||
expect(avatarElement.getAttribute('src')).toBeDefined(); | ||
|
||
expect(avatarElement.className).toContain(testStyle); | ||
|
||
expect(avatarElement.getAttribute('data-testid')).toBe(testDataTestId); | ||
}); | ||
}); |
This file was deleted.
Oops, something went wrong.