Skip to content

[SDK] React test coverage #5825

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 1 commit into from
Dec 21, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { describe, expect, it } from "vitest";
import { renderHook } from "~test/react-render.js";
import { useConnectionManager } from "./connection-manager.js";

describe("useConnectionManager", () => {
it("throws an error when used outside of ThirdwebProvider", () => {
expect(() => {
renderHook(() => useConnectionManager());
}).toThrow("useConnectionManager must be used within <ThirdwebProvider>");
});
});
19 changes: 19 additions & 0 deletions packages/thirdweb/src/react/core/utils/isSmartWallet.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
import { describe, expect, it } from "vitest";
import { ANVIL_CHAIN } from "~test/chains.js";
import { createWallet } from "../../../wallets/create-wallet.js";
import { hasSmartAccount } from "./isSmartWallet.js";

describe("isSmartWallet", () => {
it("should work if id is inApp and has smartAccount in wallet config", () => {
const wallet = createWallet("inApp", {
smartAccount: {
chain: ANVIL_CHAIN,
sponsorGas: true,
overrides: {
bundlerUrl: "your-bundler-url",
},
},
});
expect(hasSmartAccount(wallet)).toBe(true);
});
});
57 changes: 57 additions & 0 deletions packages/thirdweb/src/react/core/utils/storage.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
import { beforeEach, describe, expect, it, vi } from "vitest";
import type { AsyncStorage } from "../../../utils/storage/AsyncStorage.js";
import type { AuthArgsType } from "../../../wallets/in-app/core/authentication/types.js";
import {
LAST_AUTH_PROVIDER_STORAGE_KEY,
getLastAuthProvider,
setLastAuthProvider,
} from "./storage.js";

describe("Auth Provider Storage", () => {
let mockStorage: AsyncStorage;

beforeEach(() => {
mockStorage = {
getItem: vi.fn(),
setItem: vi.fn(),
removeItem: vi.fn(),
};
});

describe("setLastAuthProvider", () => {
it("should store the auth provider in storage", async () => {
const authProvider: AuthArgsType["strategy"] = "email";
await setLastAuthProvider(authProvider, mockStorage);

expect(mockStorage.setItem).toHaveBeenCalledWith(
LAST_AUTH_PROVIDER_STORAGE_KEY,
authProvider,
);
});
});

describe("getLastAuthProvider", () => {
it("should retrieve the last auth provider from storage", async () => {
const mockAuthProvider: AuthArgsType["strategy"] = "google";
vi.mocked(mockStorage.getItem).mockResolvedValue(mockAuthProvider);

const result = await getLastAuthProvider(mockStorage);

expect(mockStorage.getItem).toHaveBeenCalledWith(
LAST_AUTH_PROVIDER_STORAGE_KEY,
);
expect(result).toBe(mockAuthProvider);
});

it("should return null if no auth provider is stored", async () => {
vi.mocked(mockStorage.getItem).mockResolvedValue(null);

const result = await getLastAuthProvider(mockStorage);

expect(mockStorage.getItem).toHaveBeenCalledWith(
LAST_AUTH_PROVIDER_STORAGE_KEY,
);
expect(result).toBeNull();
});
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
import { describe, expect, it } from "vitest";
import { structuralSharing } from "./structuralSharing.js";

describe("structuralSharing", () => {
it("should return the old data if it is deeply equal to the new data", () => {
const oldData = { a: 1, b: { c: 2 } };
const newData = { a: 1, b: { c: 2 } };
const result = structuralSharing(oldData, newData);
expect(result).toBe(oldData);
});

it("should return a new object with shared structure for equal parts", () => {
const oldData = { a: 1, b: { c: 2 }, d: 3 };
const newData = { a: 1, b: { c: 2 }, d: 4 };
const result = structuralSharing(oldData, newData);
expect(result).not.toBe(oldData);
expect(result).not.toBe(newData);
expect(result.a).toBe(oldData.a);
expect(result.b).toBe(oldData.b);
expect(result.d).toBe(newData.d);
});

it("should handle arrays correctly", () => {
const oldData = [1, 2, [3, 4]];
const newData = [1, 2, [3, 5]];
const result = structuralSharing(oldData, newData);
expect(result).not.toBe(oldData);
expect(result).not.toBe(newData);
expect(result[0]).toBe(oldData[0]);
expect(result[1]).toBe(oldData[1]);
expect(result[2]).not.toBe(oldData[2]);
});

it("should handle undefined oldData", () => {
const oldData = undefined;
const newData = { a: 1 };
const result = structuralSharing(oldData, newData);
expect(result).toBe(newData);
});

it("should handle NaN values correctly", () => {
const oldData = { a: Number.NaN };
const newData = { a: Number.NaN };
const result = structuralSharing(oldData, newData);
expect(result).toBe(oldData);
});

it("should handle objects with different constructors", () => {
class CustomClass {}
const oldData = new CustomClass();
const newData = { a: 1 };
const result = structuralSharing(oldData, newData);
expect(result).toBe(newData);
});
});
81 changes: 81 additions & 0 deletions packages/thirdweb/src/react/core/utils/walletIcon.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
import { describe, expect, it } from "vitest";
import { genericWalletIcon, getSocialIcon, socialIcons } from "./walletIcon.js";

const emailIcon =
"";
const phoneIcon =
"";
const guestIcon =
"";
const passkeyIcon =
"";

describe("walletIcon", () => {
it("should return google icon", () => {
expect(getSocialIcon("google")).toBe(socialIcons.google);
});

it("should return coinbase icon", () => {
expect(getSocialIcon("coinbase")).toBe(socialIcons.coinbase);
});

it("should return apple icon", () => {
expect(getSocialIcon("apple")).toBe(socialIcons.apple);
});

it("should return facebook icon", () => {
expect(getSocialIcon("facebook")).toBe(socialIcons.facebook);
});

it("should return phone icon", () => {
expect(getSocialIcon("phone")).toBe(phoneIcon);
});

it("should return email icon", () => {
expect(getSocialIcon("email")).toBe(emailIcon);
});

it("should return passkey icon", () => {
expect(getSocialIcon("passkey")).toBe(passkeyIcon);
});

it("should return discord icon", () => {
expect(getSocialIcon("discord")).toBe(socialIcons.discord);
});

it("should return line icon", () => {
expect(getSocialIcon("line")).toBe(socialIcons.line);
});

it("should return x icon", () => {
expect(getSocialIcon("x")).toBe(socialIcons.x);
});

it("should return farcaster icon", () => {
expect(getSocialIcon("farcaster")).toBe(socialIcons.farcaster);
});

it("should return telegram icon", () => {
expect(getSocialIcon("telegram")).toBe(socialIcons.telegram);
});

it("should return twitch icon", () => {
expect(getSocialIcon("twitch")).toBe(socialIcons.twitch);
});

it("should return github icon", () => {
expect(getSocialIcon("github")).toBe(socialIcons.github);
});

it("should return steam icon", () => {
expect(getSocialIcon("steam")).toBe(socialIcons.steam);
});

it("should return guest icon", () => {
expect(getSocialIcon("guest")).toBe(guestIcon);
});

it("should return generic wallet icon for unknown provider", () => {
expect(getSocialIcon("unknown")).toBe(genericWalletIcon);
});
});
3 changes: 3 additions & 0 deletions packages/thirdweb/src/react/core/utils/walletIcon.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,9 @@ export const genericWalletIcon =
const passkeyIcon =
"";

/**
* @internal
*/
export const socialIcons = {
google: googleIconUri,
apple: appleIconUri,
Expand Down
Loading
Loading