Skip to content

Commit

Permalink
Organization dash cards tests migration (fixes : #2806) (#2881)
Browse files Browse the repository at this point in the history
* Migrated test from jest to Vitest for all components of OrganizationDashCards component and also merged css files into global css file

* Migrated test from jest to Vitest for all components of OrganizationDashCards component and also merged css files into global css file

* coderabbit issue resolved

* Git check resolved

* git issue resolved

* git issue resolved

* git requested changes

* resolved conversation

* git resolved conversation

* requested changes

* resolved issue

* updated branch

* codrabbit issue resolved
  • Loading branch information
amaan-aly246 authored Dec 27, 2024
1 parent ac36851 commit c364d0d
Show file tree
Hide file tree
Showing 11 changed files with 233 additions and 178 deletions.
81 changes: 0 additions & 81 deletions src/components/OrganizationDashCards/CardItem.module.css

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import React from 'react';
import { render, screen } from '@testing-library/react';
import CardItem from './CardItem';
import type { InterfaceCardItem } from './CardItem';
import dayjs from 'dayjs';
import React from 'react';

describe('Testing the Organization Card', () => {
test('Should render props and text elements For event card', () => {
Expand Down Expand Up @@ -36,7 +36,6 @@ describe('Testing the Organization Card', () => {
email: 'johndoe@example.com',
firstName: 'John',
lastName: 'Doe',
__typename: 'User',
_id: '1',
},
};
Expand Down
13 changes: 9 additions & 4 deletions src/components/OrganizationDashCards/CardItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import MarkerIcon from 'assets/svgs/cardItemLocation.svg?react';
import DateIcon from 'assets/svgs/cardItemDate.svg?react';
import UserIcon from 'assets/svgs/user.svg?react';
import dayjs from 'dayjs';
import styles from './CardItem.module.css';
import styles from '../../style/app.module.css';
import { PersonAddAlt1Rounded } from '@mui/icons-material';

/**
Expand All @@ -17,7 +17,12 @@ export interface InterfaceCardItem {
time?: string;
startdate?: string;
enddate?: string;
creator?: any;
creator?: {
_id: string;
firstName: string;
lastName: string;
email: string;
};
location?: string;
}

Expand All @@ -27,7 +32,7 @@ export interface InterfaceCardItem {
* @param props - Props for the CardItem component.
* @returns JSX element representing the card item.
*/
const cardItem = (props: InterfaceCardItem): JSX.Element => {
const CardItem = (props: InterfaceCardItem): JSX.Element => {
const { creator, type, title, startdate, time, enddate, location } = props;
return (
<>
Expand Down Expand Up @@ -120,4 +125,4 @@ const cardItem = (props: InterfaceCardItem): JSX.Element => {
);
};

export default cardItem;
export default CardItem;
23 changes: 23 additions & 0 deletions src/components/OrganizationDashCards/CardItemLoading.spec.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import CardItemLoading from './CardItemLoading';
import React from 'react';
import { render, screen } from '@testing-library/react';
import styles from '../../style/app.module.css';
describe('Test the CardItemLoading component', () => {
test('Should render the component', () => {
render(<CardItemLoading />);
expect(screen.getByTestId('cardItemLoading')).toBeInTheDocument();
});

test('Should render all required child elements', () => {
render(<CardItemLoading />);

const cardItemLoading = screen.getByTestId('cardItemLoading');
expect(cardItemLoading).toBeInTheDocument();

const iconWrapper = cardItemLoading.querySelector(`.${styles.iconWrapper}`);
expect(iconWrapper).toBeInTheDocument();

const title = cardItemLoading.querySelector(`.${styles.title}`);
expect(title).toBeInTheDocument();
});
});
6 changes: 3 additions & 3 deletions src/components/OrganizationDashCards/CardItemLoading.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import React from 'react';
import styles from './CardItem.module.css';
import styles from '../../style/app.module.css';

/**
* CardItemLoading component is a loading state for the card item. It is used when the data is being fetched.
* @returns JSX.Element
*/
const cardItemLoading = (): JSX.Element => {
const CardItemLoading = (): JSX.Element => {
return (
<>
<div
Expand All @@ -28,4 +28,4 @@ const cardItemLoading = (): JSX.Element => {
);
};

export default cardItemLoading;
export default CardItemLoading;
28 changes: 28 additions & 0 deletions src/components/OrganizationDashCards/DashBoardCardLoading.spec.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import DashBoardCardLoading from './DashboardCardLoading';
import React from 'react';
import { render, screen } from '@testing-library/react';
import styles from '../../style/app.module.css';
describe('Testing the DashBoardCardLoading component', () => {
beforeEach(() => {
render(<DashBoardCardLoading />);
});
test('should render the component', () => {
expect(screen.getByTestId('Card')).toBeInTheDocument();
});

test('should render every children elements of the component', () => {
const Card = screen.queryByTestId('Card');
const CardBody = Card?.querySelector(`.${styles.cardBody}`);
expect(CardBody).toBeInTheDocument();
const iconWrapper = Card?.querySelector(`.${styles.iconWrapper}`);
expect(iconWrapper).toBeInTheDocument();
const themeOverlay = Card?.querySelector(`.${styles.themeOverlay}`);
expect(themeOverlay).toBeInTheDocument();
const textWrapper = Card?.querySelector(`.${styles.textWrapper}`);
expect(textWrapper).toBeInTheDocument();
const primaryText = Card?.querySelector(`.${styles.primaryText}`);
expect(primaryText).toBeInTheDocument();
const secondaryText = Card?.querySelector(`.${styles.secondaryText}`);
expect(secondaryText).toBeInTheDocument();
});
});
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import React from 'react';
import { render, screen } from '@testing-library/react';
import DashboardCard from './DashboardCard';

import React from 'react';
describe('Testing the Dashboard Card', () => {
test('should render props and text elements For event card', () => {
const props = {
Expand Down
2 changes: 1 addition & 1 deletion src/components/OrganizationDashCards/DashboardCard.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React from 'react';
import { Card, Row } from 'react-bootstrap';
import Col from 'react-bootstrap/Col';
import styles from './Dashboardcard.module.css';
import styles from '../../style/app.module.css';

/** Dashboard card component is used to display the card with icon, title and count.
* @param icon - Icon for the card
Expand Down
8 changes: 4 additions & 4 deletions src/components/OrganizationDashCards/DashboardCardLoading.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
import React from 'react';
import { Card, Row } from 'react-bootstrap';
import Col from 'react-bootstrap/Col';
import styles from './Dashboardcard.module.css';
import styles from '../../style/app.module.css';

/**
* Dashboard card loading component is a loading state for the dashboard card. It is used when the data is being fetched.
* @returns JSX.Element
*/
const dashBoardCardLoading = (): JSX.Element => {
const DashBoardCardLoading = (): JSX.Element => {
return (
<Card className="rounded-4" border="0">
<Card className="rounded-4" border="0" data-testid="Card">
<Card.Body className={styles.cardBody}>
<Row className="align-items-center">
<Col sm={4}>
Expand Down Expand Up @@ -37,4 +37,4 @@ const dashBoardCardLoading = (): JSX.Element => {
);
};

export default dashBoardCardLoading;
export default DashBoardCardLoading;
60 changes: 0 additions & 60 deletions src/components/OrganizationDashCards/Dashboardcard.module.css

This file was deleted.

Loading

0 comments on commit c364d0d

Please sign in to comment.