From efe262debac735bd98d0f00db52f97c07798ecb1 Mon Sep 17 00:00:00 2001 From: Nico <60229704+Marchand-Nicolas@users.noreply.github.com> Date: Fri, 27 Dec 2024 19:26:26 +0100 Subject: [PATCH] add tests --- tests/utils/braavosMobile.test.js | 86 +++++++++++++++++++++++++++++++ utils/braavosMobile.ts | 2 +- 2 files changed, 87 insertions(+), 1 deletion(-) create mode 100644 tests/utils/braavosMobile.test.js diff --git a/tests/utils/braavosMobile.test.js b/tests/utils/braavosMobile.test.js new file mode 100644 index 00000000..f7511826 --- /dev/null +++ b/tests/utils/braavosMobile.test.js @@ -0,0 +1,86 @@ +import { mainnet, sepolia } from "@starknet-react/chains"; +import { + ConnectorNotConnectedError, + UserNotConnectedError, +} from "@starknet-react/core"; +import { BraavosMobileConnector, getBraavosMobile } from "@utils/braavosMobile"; + +describe("BraavosMobileConnector class", () => { + let connector; + + beforeEach(() => { + connector = new BraavosMobileConnector(); + }); + + describe("id getter", () => { + it("should return 'braavosMobile'", () => { + expect(connector.id).toBe("braavosMobile"); + }); + }); + + describe("icon getter", () => { + it("should return the same icon for light and dark modes", () => { + expect(connector.icon.light).toBeDefined(); + expect(connector.icon.dark).toBeDefined(); + expect(connector.icon.light).toBe(connector.icon.dark); + }); + }); + + describe("name getter", () => { + it("should return 'Braavos (mobile)'", () => { + expect(connector.name).toBe("Braavos (mobile)"); + }); + }); + + describe("available method", () => { + it("should return true", () => { + expect(connector.available()).toBe(true); + }); + }); + + describe("wallet getter", () => { + it("should throw a ConnectorNotConnectedError", () => { + expect(() => connector.wallet).toThrow(ConnectorNotConnectedError); + }); + }); + + describe("disconnect method", () => { + it("should throw a UserNotConnectedError", () => { + expect(() => connector.disconnect()).toThrow(UserNotConnectedError); + }); + }); + + describe("account method", () => { + it("should throw a ConnectorNotConnectedError", () => { + expect(() => connector.account()).toThrow(ConnectorNotConnectedError); + }); + }); + + describe("chainId method", () => { + it("should return sepolia.id when NEXT_PUBLIC_IS_TESTNET is 'true'", async () => { + process.env.NEXT_PUBLIC_IS_TESTNET = "true"; + const result = await connector.chainId(); + expect(result).toBe(sepolia.id); + }); + + it("should return mainnet.id when NEXT_PUBLIC_IS_TESTNET is not 'true'", async () => { + process.env.NEXT_PUBLIC_IS_TESTNET = "false"; + const result = await connector.chainId(); + expect(result).toBe(mainnet.id); + }); + }); + + describe("ready method", () => { + it("should return true as a Promise", async () => { + const result = await connector.ready(); + expect(result).toBe(true); + }); + }); +}); + +describe("getBraavosMobile function", () => { + it("should return an instance of BraavosMobileConnector", () => { + const instance = getBraavosMobile(); + expect(instance).toBeInstanceOf(BraavosMobileConnector); + }); +}); diff --git a/utils/braavosMobile.ts b/utils/braavosMobile.ts index 571ebab6..f9031c6d 100644 --- a/utils/braavosMobile.ts +++ b/utils/braavosMobile.ts @@ -10,7 +10,7 @@ export const braavosMobileIcon = ""; // @ts-ignore -class BraavosMobileConnector extends Connector { +export class BraavosMobileConnector extends Connector { get id(): string { return "braavosMobile"; }