From cd4def85427424be6969b8bc0f76a382986116fb Mon Sep 17 00:00:00 2001 From: Muhammad Zourdy Date: Tue, 9 Aug 2022 12:42:45 +0200 Subject: [PATCH] Refactor test for use-game hooks --- .../GameWithHooks/hooks/use-game/index.tsx | 2 ++ .../use-game-check-game-field.test.ts | 29 +++++++++++++++++++ 2 files changed, 31 insertions(+) create mode 100644 src/modules/GameWithHooks/hooks/use-game/use-game-check-game-field.test.ts diff --git a/src/modules/GameWithHooks/hooks/use-game/index.tsx b/src/modules/GameWithHooks/hooks/use-game/index.tsx index bef2ad56..db43ea15 100644 --- a/src/modules/GameWithHooks/hooks/use-game/index.tsx +++ b/src/modules/GameWithHooks/hooks/use-game/index.tsx @@ -7,6 +7,7 @@ interface ReturnType { level: LevelNames; isGameOver: boolean; isWin: boolean; + gameField: Field; settings: [number, number]; playerField: Field; onClickHandler: (coords: Coordinates) => void; @@ -57,6 +58,7 @@ export const useGame = (): ReturnType => { level, isGameOver, isWin, + gameField, settings: [size, bombs], playerField, onClickHandler, diff --git a/src/modules/GameWithHooks/hooks/use-game/use-game-check-game-field.test.ts b/src/modules/GameWithHooks/hooks/use-game/use-game-check-game-field.test.ts new file mode 100644 index 00000000..a7629b1f --- /dev/null +++ b/src/modules/GameWithHooks/hooks/use-game/use-game-check-game-field.test.ts @@ -0,0 +1,29 @@ +import { CellState, Field } from "@helpers/field"; +import { useGame } from "@modules/GameWithHooks/hooks/use-game/index"; +import { act, renderHook } from "@testing-library/react"; + +const { bomb: b } = CellState; + +const flatWithFilter = (field: Field, cond: number) => field.flat().filter((v) => v === cond); + +describe("useGame test cases", () => { + it("Render hook by default", () => { + const { result } = renderHook(useGame); + const { gameField } = result.current; + + expect(flatWithFilter(gameField, b)).toHaveLength(10); + }); + it("onReset game handler", () => { + const { result } = renderHook(useGame); + const { playerField, onClickHandler, onResetHandler } = result.current; + + expect(playerField).toHaveLength(9); + + act(() => onClickHandler([5, 5])); + act(onResetHandler); + + const { gameField } = result.current; + + expect(flatWithFilter(gameField, b)).toHaveLength(10); + }); +});