From 1a723436389f7599a5d714a1d1d77a510f264ecf Mon Sep 17 00:00:00 2001 From: Drikus Roor Date: Fri, 8 Dec 2023 15:01:03 +0100 Subject: [PATCH] test: Add unit tests for Circle component --- frontend/src/components/Circle/Circle.js | 2 +- frontend/src/components/Circle/Circle.test.js | 86 +++++++++++++++++++ 2 files changed, 87 insertions(+), 1 deletion(-) create mode 100644 frontend/src/components/Circle/Circle.test.js diff --git a/frontend/src/components/Circle/Circle.js b/frontend/src/components/Circle/Circle.js index dbc6f69b4..a833acd57 100644 --- a/frontend/src/components/Circle/Circle.js +++ b/frontend/src/components/Circle/Circle.js @@ -1,5 +1,5 @@ import React, { useEffect, useState } from "react"; -import Timer from "../../util/timer"; +import Timer from "util/timer"; // Circle shows a counterclockwise circular animation const Circle = ({ diff --git a/frontend/src/components/Circle/Circle.test.js b/frontend/src/components/Circle/Circle.test.js new file mode 100644 index 000000000..9087bfb9d --- /dev/null +++ b/frontend/src/components/Circle/Circle.test.js @@ -0,0 +1,86 @@ +import React from 'react'; +import { render, waitFor } from '@testing-library/react'; +import Circle from './Circle'; +import Timer from 'util/timer'; + +global.requestAnimationFrame = (callback) => { + setTimeout(callback, 0); +}; +global.performance = { + now: () => Date.now() +}; + +jest.mock('util/timer', () => ({ + __esModule: true, + default: jest.fn(), +})); + +describe('Circle', () => { + + afterEach(() => { + jest.clearAllMocks(); + }); + + it('renders correctly with default props', () => { + const { container } = render(); + expect(container.querySelector('.aha__circle')).toBeInTheDocument(); + expect(container.querySelectorAll('circle').length).toBe(2); + }); + + it('calls onTick and onFinish callbacks', async () => { + + Timer.mockImplementation(({ onTick, onFinish, duration }) => { + let time = 0; + const interval = 10; // Simulate a timer interval + const timerId = setInterval(() => { + time += interval; + if (onTick) { + onTick(time); + } + if (time >= duration) { + if (onFinish) { + onFinish(); + } + clearInterval(timerId); + } + }, interval); + return () => clearInterval(timerId); + }); + + const onTick = jest.fn(); + const onFinish = jest.fn(); + render(); + + await waitFor(() => expect(onTick).toHaveBeenCalled()); + await waitFor(() => expect(onFinish).toHaveBeenCalled()); + }); + + it('starts timer when running is true', () => { + const startTime = 0; + const duration = 0; + render(); + + expect(Timer).toHaveBeenCalled(); + }); + + it('calculates style for circle animation correctly', () => { + const time = 50; + const duration = 100; + const { container } = render(); + + const percentageCircle = container.querySelector('.circle-percentage'); + + expect(percentageCircle).toHaveStyle('stroke-dashoffset: 0.5340707511102648;'); + }); + + it('does not start timer when running is false', () => { + const onTick = jest.fn(); + const onFinish = jest.fn(); + render(); + + expect(Timer).not.toHaveBeenCalled(); + expect(onTick).not.toHaveBeenCalled(); + expect(onFinish).not.toHaveBeenCalled(); + }); + +});