From d8ba2fc778b243a009bf61d0098b5e9818f0bd28 Mon Sep 17 00:00:00 2001 From: Sajjad Hashemian Date: Wed, 27 Nov 2019 22:52:37 +0330 Subject: [PATCH] add more tests --- .../components/Loading/tests/Loading.test.tsx | 29 ++++++++++++++++--- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/src/components/Frame/components/Loading/tests/Loading.test.tsx b/src/components/Frame/components/Loading/tests/Loading.test.tsx index a1b76e458d6..2136b229a9e 100644 --- a/src/components/Frame/components/Loading/tests/Loading.test.tsx +++ b/src/components/Frame/components/Loading/tests/Loading.test.tsx @@ -1,17 +1,38 @@ import React from 'react'; import {mountWithAppProvider} from 'test-utilities/legacy'; +import {animationFrame} from '@shopify/jest-dom-mocks'; +import {act} from 'react-dom/test-utils'; import {Loading} from '../Loading'; describe('', () => { - const loading = mountWithAppProvider(); + beforeEach(() => { + animationFrame.mock(); + }); + + afterEach(() => { + animationFrame.restore(); + }); + + it('increases over time', () => { + const loading = mountWithAppProvider(); - it('mounts', () => { - expect(loading.exists()).toBe(true); + for (let i = 0; i <= 100; i++) { + act(() => animationFrame.runFrame()); + } + + loading.update(); + + expect(loading.find('.Level').prop('aria-valuenow')).toBe(26); }); - it('unmounts safely', () => { + it('cancels the animationFrame on unmount', () => { + const cancelAnimationFrameSpy = jest.spyOn(window, 'cancelAnimationFrame'); + const loading = mountWithAppProvider(); + expect(() => { loading.unmount(); }).not.toThrow(); + + expect(cancelAnimationFrameSpy).toHaveBeenCalledTimes(1); }); });